3分钟带你轻松了解贝塞尔曲线(cubic-bezier)

3分钟带你轻松了解贝塞尔曲线(cubic-bezier)1 前言 在了解 cubic bezier 之前 你需要对 CSS3 中的动画效果有所认识 它是 animation timing function 和 transition timing function 中一个重要的内容 2 定义与用法 ubic bezier 函数定义了一个贝塞尔曲线 Cubic Bezier

大家好,我是讯享网,很高兴认识大家。

1、前言

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

2、定义与用法

ubic-bezier() 函数定义了一个贝塞尔曲线(Cubic Bezier)。

贝塞尔曲线曲线由四个点 P0,P1,P2 和 P3 定义。P0 和 P3 是曲线的起点和终点。P0是(0,0)并且表示初始时间和初始状态,P3是(1,1)并且表示最终时间和最终状态。

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-oxySbEai-1585104986408)(D:\DAYNOTE\贝塞尔曲线1.PNG)]
讯享网

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-OJzgwDqH-1585104986410)(D:\DAYNOTE\贝塞尔曲线2.PNG)]

从上图我们需要知道的是 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 轴任意),最后形成的曲线就是动画的速度曲线。

cubic-bezier() 可用于 animation-timing-function 和 transition-timing-function 属性。

3、语法

讯享网cubic-bezier(x1,y1,x2,y2) 
描述
x1,y1,x2,y2 必需。数字值,x1 和 x2 需要是 0 到 1 的数字。

4、案例分析

<!DOCTYPE html>
<html lang="en">
    <head>
        <meta charset="UTF-8">
        <title>cubic-bezier</title>
        <style type="text/css">
            .box{
                margin: 0 auto;
                width: 100px;
                height: 100px;
                text-align: center;
                vertical-align: center;
            }
            .box:hover{
                margin: auto;
                width: 100px;
                height: 100px;
                background-color: #41ffaa;
                transition: width 2s;
                transition-timing-function: cubic-bezier(0.1, 0.7, 1.0, 0.1);
            }
        </style>
    </head>
    <body>
    <div class="box">贝塞尔曲线</div>
    </body>
</html>
小讯
上一篇 2025-02-13 20:15
下一篇 2025-03-26 09:50

相关推荐

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容,请联系我们,一经查实,本站将立刻删除。
如需转载请保留出处:https://51itzy.com/kjqy/29349.html