.play()
优质
小牛编辑
125浏览
2023-12-01
.play( from:*, suppressEvents:Boolean ) : *
控制动画往正方向播放,可设定开始的时间点。
如果suppressEvents保持默认状态并跳到新的时间点,那么之前在新旧时间点之间设置的回调或函数不会被触发,相当于跳过了那些时间点。如果想触发,设为false。
//在当前位置开始播放
myAnimation.play();
//在2秒钟位置开始播放
myAnimation.play(2);
//在2秒钟位置开始播放,并且不阻止期间的函数、事件
myAnimation.play(2, false);
返回self,方便链式调用。
.play()适用于TimelineMaxTimelineLite
.play()的参数
参数名 | 类型 | 必填 | 说明 |
---|---|---|---|
from | Num/label | 否 | 动画开始播放的时间(或TimelineLite/TimelineMax的label)如果没有定义,它将从播放头当前的位置开始播放 |
suppressEvents | Boolean | 否 | 如果true(默认值),当播放头移动到from参数中定义的新位置时,不会触发任何事件或回调。 |
.play() 示例
#demo {
width: 692px;
height: 60px;
background-color: #333;
padding: 8px;
margin-bottom: 10px;
}
.box {
width: 50px;
height: 50px;
border-radius: 6px;
margin-top: 4px;
display: inline-block;
position: absolute;
}
.green {
background-color: #6fb936;
}
input[type="button"] {
-webkit-appearance: button;
padding: 8px;
margin-right: 5px;
margin-bottom: 5px;
}
var tm = new TimelineMax();
tm.to('.box', 6, {x: 500});
playBtn = document.getElementById("playBtn");
pauseBtn = document.getElementById("pauseBtn");
resumeBtn = document.getElementById("resumeBtn");
reverseBtn = document.getElementById("reverseBtn");
playFromBtn = document.getElementById("playFromBtn");
reverseFromBtn = document.getElementById("reverseFromBtn");
seekBtn = document.getElementById("seekBtn");
timeScaleSlowBtn = document.getElementById("timeScaleSlowBtn");
timeScaleNormalBtn = document.getElementById("timeScaleNormalBtn");
timeScaleFastBtn = document.getElementById("timeScaleFastBtn");
restartBtn = document.getElementById("restartBtn");
playBtn.onclick = function() {
//当前位置播放动画,如果动画播放完成, play() 无效
tm.play();
}
pauseBtn.onclick = function() {
tm.pause();
}
resumeBtn.onclick = function() {
//当前位置继续动画.
tm.resume();
}
reverseBtn.onclick = function() {
tm.reverse();
}
playFromBtn.onclick = function() {
//某时间点开始播放(秒).
tm.play(5);
}
reverseFromBtn.onclick = function() {
//某时间点开始返回 (秒).
tm.reverse(1);
}
seekBtn.onclick = function() {
//跳到特定时间 (秒)
tm.seek(3);
}
timeScaleSlowBtn.onclick = function() {
//减速.
tm.timeScale(0.5);
}
timeScaleNormalBtn.onclick = function() {
//恢复速度.
tm.timeScale(1);
}
timeScaleFastBtn.onclick = function() {
//加速.
tm.timeScale(2);
}
restartBtn.onclick = function() {
//重新开始.
tm.restart();
}