实用的 CSS — 贝塞尔曲线(cubic-bezier)

前言

在了解 cubic-bezier 之前,你需要对 CSS3 中的动画效果有所认识,它是 animation-timing-function 和 transition-timing-function 中一个重要的内容。

本体

简介

cubic-bezier 又称三次贝塞尔,主要是为 animation 生成速度曲线的函数,规定是 cubic-bezier(<x1>, <y1>, <x2>, <y2>)

我们可以从下图中简要理解一下 cubic-bezier

从上图我们需要知道的是 cubic-bezier 的取值范围:

  • P0:默认值 (0, 0)
  • P1:动态取值 (x1, y1)
  • P2:动态取值 (x2, y2)
  • P3:默认值 (1, 1)

我们需要关注的是 P1 和 P2 两点的取值,而其中 X 轴的取值范围是 0 到 1,当取值超出范围时 cubic-bezier 将失效;Y 轴的取值没有规定,当然也毋须过大。

最直接的理解是,将以一条直线放在范围只有 1 的坐标轴中,并从中间拿出两个点来拉扯(X 轴的取值区间是 [0, 1],Y 轴任意),最后形成的曲线就是动画的速度曲线。

使用

在测试例子中:

 
  1. <!DOCTYPE html>

  2. <html lang="zh-cn">

  3. <head>

  4. <meta charset="UTF-8">

  5. <title>Document</title>

  6.  
  7. <style>

  8. .animation {

  9. width: 50px;

  10. height: 50px;

  11. background-color: #ed3;

  12. -webkit-transition: all 2s;

  13. -o-transition: all 2s;

  14. transition: all 2s;

  15. }

  16. .animation:hover {

  17. -webkit-transform: translateX(100px);

  18. -ms-transform: translateX(100px);

  19. -o-transform: translateX(100px);

  20. transform: translateX(100px);

  21. }

  22. </style>

  23. </head>

  24. <body>

  25. <div class="animation"></div>

  26. </body>

  27. </html>

我们可以在浏览器中看到,当鼠标移到元素上时,元素开始向右移动,开始比较慢,之后则比较快,移开时按原曲线回到原点。

在例子中,当我们不为 transition 添加 cubic-bezier 或是其他 timing-function 时,默认的速度曲线是 ease,此时的速度曲线是:

那么让我们在代码中加入 cubic-bezier(.17, .86, .73, .14)

 
  1. ...

  2. .animation {

  3. ...

  4. -webkit-transition: all 2s cubic-bezier(.17, .86, .73, .14);

  5. -o-transition: all 2s cubic-bezier(.17, .86, .73, .14);

  6. transition: all 2s cubic-bezier(.17, .86, .73, .14);

  7. }

  8. ...

再刷新页面观察效果,会看到动画在执行过程中有一段很缓慢的移动,前后的速度相似,此时的运动曲线是:

几个常用的固定值对应的 cubic-bezier 值以及速度曲线

  1. ease:cubic-bezier(.25, .1, .25, 1)

  2. liner:cubic-bezier(0, 0, 1, 1) / cubic-bezier(1, 1, 0, 0)

  3. ease-in:cubic-bezier(.42, 0, 1, 1)

  4. ease-out:cubic-bezier(0, 0, .58, 1)

  5. ease-in-out:cubic-bezier(.42, 0, .58, 1)

  6. In Out . Back(来回的缓冲效果):cubic-bezier(0.68, -0.55, 0.27, 1.55)

效果参考

文章所提到的动画效果可以在下面站点中看到,当然你也可以大胆尝试:

参考

MDN
W3School

转载:http://www.jianshu.com/p/d999f090d333

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值