使用CSS做贝塞尔曲线

前言

在了解 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 轴的取值范围是 01,当取值超出范围时 cubic-bezier 将失效;Y 轴的取值没有规定,当然也毋须过大。

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

使用

在测试例子中:

  1. nbsp;html>    <span class="typ">Document</span>   .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,此时的速度曲线是:

使用CSS做贝塞尔曲线那么让我们在代码中加入 cubic-bezier(.17, .86, .73, .14):

  1. ....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);}...

登录后复制

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

使用CSS做贝塞尔曲线

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

  1. easecubic-bezier(.25, .1, .25, 1)linercubic-bezier(0, 0, 1, 1) / cubic-bezier(1, 1, 0, 0)ease-incubic-bezier(.42, 0, 1, 1)ease-outcubic-bezier(0, 0, .58, 1)ease-in-outcubic-bezier(.42, 0, .58, 1)In Out . Back(来回的缓冲效果):cubic-bezier(0.68, -0.55, 0.27, 1.55)

登录后复制

以上就是使用CSS做贝塞尔曲线的详细内容,更多请关注【创想鸟】其它相关文章!

声明:本站所有文章,如无特殊说明或标注,均为本站原创发布。任何个人或组织,在未征得本站同意时,禁止复制、盗用、采集、发布本站内容到任何网站、书籍等各类媒体平台。如若本站内容侵犯了原著者的合法权益,可联系我们进行处理。

点点赞赏,手留余香

给TA打赏
共0人
还没有人赞赏,快来当第一个赞赏的人吧!
    编程技术

    如何制作百度登录框架

    2025-3-29 18:01:29

    编程技术

    浅谈link与@import的区别

    2025-3-29 18:01:47

    0 条回复 A文章作者 M管理员
    欢迎您,新朋友,感谢参与互动!
      暂无讨论,说说你的看法吧
    个人中心
    购物车
    优惠劵
    今日签到
    私信列表
    搜索