【问题标题】:GSAP timeline various onComplete functions on different tweensGSAP 时间轴上不同补间的各种 onComplete 函数
【发布时间】:2015-12-17 09:44:31
【问题描述】:

首先我是 GSAP 和 ScrollMagic 的新手,如果我在这里问了一个愚蠢的问题,请原谅我。我一直在寻找互联网,但没有成功找到我的问题的正确答案。

无论如何,我正在尝试创建一个时间轴,在该时间轴上,每个“to”函数都将使用特定参数调用外部函数。

var controller = new ScrollMagic.Controller();
var timeline = new TimelineLite();
var div = $('div');

timeline.to(div, 0.5, {
   opacity: 0,
   onComplete: toggleOverlay(0)
}, "part-1")

.to(div, 0.5, {
   opacity: 1,
   onComplete: toggleOverlay(1)
}, "part-2")

.to(div, 0.5, {
   opacity: 0,
   onComplete: toggleOverlay(2)
}, "part-3");

var scene = new ScrollMagic.Scene({
   triggerElement: "#trigger-event",
   duration: 500
})
.setTween(timeline)
.addTo(controller);

function toggleOverlay(i){
   console.log(i);
}

这里发生了什么:一旦滚动位置到达“#trigger-event”,时间轴就会被调用。随后,将根据触发事件之后和结束(持续时间)之前的滚动位置调用'.to'函数。

我在这里面临的问题是 onComplete 函数是在页面加载时直接调用的。这可能与“.setTween(timeline)”有关,我可以想象它会加载到整个时间线中。

我的问题的解决方案是什么,或者什么是好的替代方法?

编辑:这是一个 JSFiddle:https://jsfiddle.net/04db5ja5/

感谢您的问候, 恩齐奥

【问题讨论】:

    标签: javascript animation gsap scrollmagic


    【解决方案1】:

    您已经使用括号() 立即调用了函数。阅读 this 答案,以更好地了解将函数分配给变量和实际立即执行之间的区别。

    在 GSAP 中,解决方法是将 triggerOverlay 函数分配给 onComplete 而不带括号,如下所示:

    ...
    onComplete: toggleOverlay
    ...
    

    要接收额外的参数,您需要将它们作为数组传递给 onCompleteParams,如下所示:

    ...
    onCompleteParams: [0]
    ...
    

    所以你的整体代码应该是这样的:

    ...
    timeline.to(div, 0.5, {
       opacity: 0,
       onComplete: toggleOverlay,
       onCompleteParams: [0]
    }, "part-1")
    
    .to(div, 0.5, {
       opacity: 1,
       onComplete: toggleOverlay,
       onCompleteParams: [1]
    }, "part-2")
    
    .to(div, 0.5, {
       opacity: 0,
       onComplete: toggleOverlay,
       onCompleteParams: [2]
    }, "part-3");
    ...
    

    【讨论】:

    • 直到现在我才知道。谢谢你:)
    • 最好先阅读 documentation ;)
    猜你喜欢
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 2016-02-09
    • 2015-09-03
    相关资源
    最近更新 更多