GSAP 时间轴上不同补间的各种 onComplete 函数
GSAP timeline various onComplete functions on different tweens
首先,我是 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/
感谢您的问候,
恩齐奥
您已经通过括号 ()
立即调用了函数。阅读 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");
...
首先,我是 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/
感谢您的问候, 恩齐奥
您已经通过括号 ()
立即调用了函数。阅读 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");
...