实用的 CSS — 贝塞尔曲线(cubic-bezier)
来源:互联网 发布:爬虫可以爬哪些数据 编辑:程序博客网 时间:2024/06/05 20:15
原文:http://www.jianshu.com/p/d999f090d333
前言
在了解 cubic-bezier 之前,你需要对 CSS3 中的动画效果有所认识,它是 animation-timing-function 和 transition-timing-function 中一个重要的内容。
本体
简介
cubic-bezier 又称三次贝塞尔,主要是为 animation 生成速度曲线的函数,规定是 cubic-bezier(, , , )。
我们可以从下图中简要理解一下 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 轴任意),最后形成的曲线就是动画的速度曲线。
使用
在测试例子中:
Document
.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);
}
我们可以在浏览器中看到,当鼠标移到元素上时,元素开始向右移动,开始比较慢,之后则比较快,移开时按原曲线回到原点。
在例子中,当我们不为 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 值以及速度曲线
ease:cubic-bezier(.25, .1, .25, 1)
liner:cubic-bezier(0, 0, 1, 1) / cubic-bezier(1, 1, 0, 0)
ease-in:cubic-bezier(.42, 0, 1, 1)
ease-out:cubic-bezier(0, 0, .58, 1)
ease-in-out:cubic-bezier(.42, 0, .58, 1)
In Out . Back(来回的缓冲效果):cubic-bezier(0.68, -0.55, 0.27, 1.55)
效果参考
文章所提到的动画效果可以在下面站点中看到,当然你也可以大胆尝试:
英文版在线预览(Lea Verou)
中文版在线预览(更多效果)
在线生成系列
作者的《Loading》库
参考
MDN
W3School
- 实用的 CSS — 贝塞尔曲线(cubic-bezier)
- 实用的 CSS — 贝塞尔曲线(cubic-bezier)
- 实用的 CSS — 贝塞尔曲线(cubic-bezier)
- 实用的 CSS — 贝塞尔曲线(cubic-bezier)
- 贝塞尔曲线——cubic-bezier详解
- cubic-bezier贝塞尔曲线函数
- cubic-bezier贝塞尔曲线CSS3动画工具
- cubic-bezier贝塞尔曲线CSS3动画工具
- CSS3 三次贝塞尔曲线(cubic-bezier)
- HTML5基础加强css样式篇(css过渡属性简写,cubic-bezier过度曲线函数使用)(二十)
- UNITY贝塞尔曲线Bezier的一个细节
- bezier曲线的实现
- Bezier曲线的绘制
- Bezier曲线的绘制
- Bezier曲线的绘制
- 绘制贝塞尔Bezier曲线
- 贝塞尔曲线(Bezier Curves)
- iOS贝塞尔bezier曲线
- hanoi塔问题—函数的递归调用
- ASM恢复故障组
- 数据库系统概论学习攻略2
- net.sf.json——java.lang.VerifyError: net/sf/json/JSONObject
- 表单中post与get的区别
- 实用的 CSS — 贝塞尔曲线(cubic-bezier)
- (二) 从Angular1到Angular2需要的预备知识
- 如何编写自己的JavaScript组件
- VS环境下MFC的几种类型转换
- PyMC3
- 安卓开发之打包签名Keystore密码忘了解决办法
- 问题规模减小和递归求解主定理
- 最小费用最大流
- Linux下select, poll和epoll IO模型的详解