GitHub

CSS3动画中神奇的animation-timing-function

CSS3动画(animation)属性有如下几个:

属性 说明
animation-name name 指定元素要使用的keyframes名称
animation-duration time(ms、s) 指定动画时长
animation-timing-function linear、ease(默认)、ease-in、ease-out、ease-in-out、cubic-bezier(n,n,n,n) 设置动画将如何完成一个周期
animation-delay time(ms、s) 设置动画启动前的延迟间隔(只会执行一次)
animation-iteration-count 1(默认)、n、infinite 定义动画播放次数
animation-direction normal(默认)、reverse、alternate、alternate-reverse 指定是否轮流反向播放动画
animation-fill-mode none(默认)、forwards、backwards、both 规定当动画不播放时(当动画完成时,或当动画有一个延迟未开始播放时),要应用到元素的样式。
animation-play-state running、paused

指定动画运行或者暂停

 

本片博文主要记录一下 animation-timing-function 的各个值的动态效果,方便日后查阅。

1. linear:动画从头到尾的速度是相同的,匀速变化

 

 

 

2. ease:慢 -> 快 -> 慢

 

3. ease-in:慢 -> 匀速

 

4. ease-out:匀速 -> 慢

 

5. ease-in-out: 慢 -> 匀速 -> 慢

以上5个动画运行效果的总结只是基于视觉上的阐述,详细请参阅 详细说明

6. cubic-bezier(0.68, -0.55, 0.27, 1.55):4个参数自己设定

  贝塞尔函数常用来制作有反弹效果的动画,参数相关 查看详细

注意:上述6个方法均是在一个关键帧的前提下完成的,即

@keyframes move{
    from { margin: 0}
    to { margin: calc(100% - 4em); }  
}

当关键帧不唯一时,每个关键帧之间将应用整个动画设置的缓动函数,因为 animation-timing-function的定义就是 "关键帧之间的缓动函数"

@keyframes move{
    from { margin-left: 0; }
    50% { margin-left: calc(50% - 2em); }
    to { margin-left: calc(100% - 4em); }
}

如图所示,animation-timing-function 是 应用在每个关键帧之间的,所以不同关键帧可以设置不同的缓动动画

@keyframes move{
    from { margin-left: 0; animation-timing-function:linear; }
    50% { margin-left: calc(50% - 2em); animation-timing-function:ease-out;}
    to { margin-left: calc(100% - 4em); } /*最后一个关键帧设置无效,因为此关键帧为最后一帧*/
}

 参考动画:从AE到web

posted @ 2018-02-23 23:58  長风  阅读(649)  评论(0编辑  收藏  举报