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

作者: Jovey | 来源:发表于2016-03-16 14:58 被阅读38444次

欢迎移步我的博客阅读:《实用的 CSS — 贝塞尔曲线(cubic-bezier)》

前言

在了解 cubic-bezier 之前,你需要对 CSS3 中的动画效果有所认识,它是 animation-timing-functiontransition-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 轴的取值范围是 01,当取值超出范围时 cubic-bezier 将失效;Y 轴的取值没有规定,当然也毋须过大。

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

使用

在测试例子中:

<!DOCTYPE html>
<html lang="zh-cn">
<head>
  <meta charset="UTF-8">
  <title>Document</title>

  <style>
    .animation {
      width: 50px;
      height: 50px;
      background-color: #ed3;
      -webkit-transition:  all 2s;
           -o-transition:  all 2s;
              transition:  all 2s;
    }
    .animation:hover {
      -webkit-transform:  translateX(100px);
          -ms-transform:  translateX(100px);
           -o-transform:  translateX(100px);
              transform:  translateX(100px);
    }
  </style>
</head>
<body>
  <div class="animation"></div>
</body>
</html>

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

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

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

...
.animation {
  ...
  -webkit-transition:  all 2s cubic-bezier(.17, .86, .73, .14);
       -o-transition:  all 2s cubic-bezier(.17, .86, .73, .14);
          transition:  all 2s cubic-bezier(.17, .86, .73, .14);
}
...

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


几个常用的固定值对应的 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

相关文章

网友评论

  • f5f81b3b5d74:最近在看animation这块,感觉贝塞尔曲线和css animation最大的限制是不能做出物理弹簧效果因为他只有两个控制点。 可以参考这文章 https://medium.com/@dtinth/spring-animation-in-css-2039de6e1a03
  • 57f3ef7bd5be:在看别人的代码时候看到这个函数,有点懵逼。看了文章,再去看下MDN,有种豁然开朗的感觉。难怪自己实现的效果和别人有差,原来差在这里。
  • zrong:受教了
  • 6174c63eb15a:对这个的算法规律比较感兴趣
    df48eb0e9d82:@aibottlec 可以看看这篇文章 http://blog.csdn.net/gaoyongxing/article/details/5827855
  • 朵霞:cubic-bezier(.25, .1, .25, 1) 重点是这4个数字怎么得出来的
    4fc0579f2fc3:前两个是X轴坐标啊,后面2个是Y轴坐标
    51224fd4965f:@拜金女孩_ https://isux.tencent.com/css3/tools.html腾讯的在线生成工具
    c3cae9abfd70:@拜金女孩_ 根据想要的效果,在线生成啊
  • 朵霞:我也是前端 你除了简书还有别的地方更文么 感觉简书不太适合更新技术文章

本文标题:实用的 CSS — 贝塞尔曲线(cubic-bezier)

本文链接:https://www.haomeiwen.com/subject/pfpqlttx.html