web前端⼊门到实战:css3贝塞尔曲线(cubic-bezier)
css3 animation模块,其中animation-timing-function 和 transition-timing-function两个属性来控制动画速度分别提供了
ease,liner,ease-in,ease-out,ease-in-out⼏个预设速度,还可以同过cubic-bezier来⾃定义速度,想要深⼊了解CSS3动画,实现随⼼所欲的动画效果,还是有必要理解下其中的原理。
CSS3动画速度的控制通过三次贝塞尔曲线函数实现,定义规则为
cubic-bezier (x1,y1,x2,y2)
cubic-bezier⼜称三次贝塞尔,主要是为 animation ⽣成速度曲线的函数,规定是 cubic-bezier(, , , )。 从下图中简要理解⼀下 cubic-bezier:
从上图我们需要知道的是 cubic-bezier 的取值范围:
P0:默认值 (0, 0)
P1:动态取值 (x1, y1)
P2:动态取值 (x2, y2)
P3:默认值 (1, 1)
css最新
我们需要关注的是 P1 和 P2 两点的取值,⽽其中 X 轴的取值范围是 0 到 1,当取值超出范围时 cubic-bezier 将失效;Y 轴的取值没有规定,当然也⽏须过⼤。 形成P0到P3曲线就是贝塞尔曲线。
⼀条直线放在范围只有 1 的坐标轴中,并从中间拿出两个点来拉扯(x1,y1,x2,y2),最后形成的曲线就是动画的速度曲线。
.animation {
transition: all 2s cubic-bezier(.65,.13,.22,.88);
}
web前端开发学习Q-q-u-n: 767273102 ,分享学习的⽅法和需要注意的⼩细节,不停更新最新的教程和学习⽅法(详细的前端项⽬实战教学视频)
CSS3提供的⼏个预设速度:
⼏个常⽤的固定值对应的 cubic-bezier 值以及速度曲线
1.ease 对应⾃定义cubic-bezier(.25,.01,.25,1),效果为先慢后快再慢;
2.linear 对应⾃定义cubic-bezier(0,0,1,1),效果为匀速直线;
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),效果为先慢后快再慢。
来回缓冲效果:cubic-bezier(0.68, -0.55, 0.27, 1.55) 如下图
版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系QQ:729038198,我们将在24小时内删除。
发表评论