CSS3 animation-timing-function 属性

实例

从开头到结尾以相同的速度来播放动画:

  1. div
  2. {
  3. animation-timing-function:2s;
  4. -webkit-animation-timing-function:2s; /* Safari 和 Chrome */
  5. }

浏览器支持


IE Firefox Chrome Safari Opera
ie firefox chrome safari opera

Internet Explorer 10、Firefox 以及 Opera 支持 animation-timing-function 属性。

Safari 和 Chrome 支持替代的 -webkit-animation-timing-function 属性。

注释:Internet Explorer 9 以及更早的版本不支持 animation-timing-function 属性。

定义和用法

animation-timing-function 规定动画的速度曲线。

速度曲线定义动画从一套 CSS 样式变为另一套所用的时间。

速度曲线用于使变化更为平滑。

默认值: ease
继承性: no
版本: CSS3
JavaScript 语法: object.style.animationTimingFunction="linear"

语法

  1. animation-timing-function: value;

animation-timing-function 使用名为三次贝塞尔(Cubic Bezier)函数的数学函数,来生成速度曲线。您能够在该函数中使用自己的值,也可以预定义的值:

描述
linear 动画从头到尾的速度是相同的。
ease 默认。动画以低速开始,然后加快,在结束前变慢。
ease-in 动画以低速开始。
ease-out 动画以低速结束。
ease-in-out 动画以低速开始和结束。
cubic-bezier(n,n,n,n) 在 cubic-bezier 函数中自己的值。可能的值是从 0 到 1 的数值。

实例

实例 1

为了更好地理解不同的定时函数值,这里提供了设置五个不同值的五个不同的 div 元素:

  1. /* W3C 和 Opera: */
  2. #div1 {animation-timing-function: linear;}
  3. #div2 {animation-timing-function: ease;}
  4. #div3 {animation-timing-function: ease-in;}
  5. #div4 {animation-timing-function: ease-out;}
  6. #div5 {animation-timing-function: ease-in-out;}
  7. /* Firefox: */
  8. #div1 {-moz-animation-timing-function: linear;}
  9. #div2 {-moz-animation-timing-function: ease;}
  10. #div3 {-moz-animation-timing-function: ease-in;}
  11. #div4 {-moz-animation-timing-function: ease-out;}
  12. #div5 {-moz-animation-timing-function: ease-in-out;}
  13. /* Safari 和 Chrome: */
  14. #div1 {-webkit-animation-timing-function: linear;}
  15. #div2 {-webkit-animation-timing-function: ease;}
  16. #div3 {-webkit-animation-timing-function: ease-in;}
  17. #div4 {-webkit-animation-timing-function: ease-out;}
  18. #div5 {-webkit-animation-timing-function: ease-in-out;}

实例 2

与上例相同,但是通过 cubic-bezier 函数来定义速度曲线:

  1. /* W3C 和 Opera: */
  2. #div1 {animation-timing-function: cubic-bezier(0,0,1,1);}
  3. #div2 {animation-timing-function: cubic-bezier(0.25,0.1,0.25,1);}
  4. #div3 {animation-timing-function: cubic-bezier(0.42,0,1,1);}
  5. #div4 {animation-timing-function: cubic-bezier(0,0,0.58,1);}
  6. #div5 {animation-timing-function: cubic-bezier(0.42,0,0.58,1);}
  7. /* Firefox: */
  8. #div1 {-moz-animation-timing-function: cubic-bezier(0,0,1,1);}
  9. #div2 {-moz-animation-timing-function: cubic-bezier(0.25,0.1,0.25,1);}
  10. #div3 {-moz-animation-timing-function: cubic-bezier(0.42,0,1,1);}
  11. #div4 {-moz-animation-timing-function: cubic-bezier(0,0,0.58,1);}
  12. #div5 {-moz-animation-timing-function: cubic-bezier(0.42,0,0.58,1);}
  13. /* Safari 和 Chrome: */
  14. #div1 {-webkit-animation-timing-function: cubic-bezier(0,0,1,1);}
  15. #div2 {-webkit-animation-timing-function: cubic-bezier(0.25,0.1,0.25,1);}
  16. #div3 {-webkit-animation-timing-function: cubic-bezier(0.42,0,1,1);}
  17. #div4 {-webkit-animation-timing-function: cubic-bezier(0,0,0.58,1);}
  18. #div5 {-webkit-animation-timing-function: cubic-bezier(0.42,0,0.58,1);}

相关页面

CSS3 教程:CSS3 动画