【转载】cubic-bezier贝塞尔曲线CSS3动画工具

转载自:https://blog.csdn.net/qq_25600055/article/details/51045163?ops_request_misc=%257B%2522request%255Fid%2522%253A%2522158958946519724835802697%2522%252C%2522scm%2522%253A%252220140713.130102334.pc%255Fall.57693%2522%257D&request_id=158958946519724835802697&biz_id=0&utm_medium=distribute.pc_search_result.none-task-blog-2allfirst_rank_v2~rank_v25-1-51045163.nonecase&utm_term=%E8%B4%9D%E5%A1%9E%E5%B0%94%E6%9B%B2%E7%BA%BF+css

工具及应用

这里给出两个在线动画调试工具。

cubic-bezier还是比较少用到,PC端中,有浏览器不兼容。但是手机端中,可以使用并带来炫酷的动画及体验。

贝塞尔曲线

贝塞尔曲线(Bézier curve),又称贝兹曲线或贝济埃曲线,是应用于二维图形应用程序的数学曲线。一般的矢量图形软件通过它来精确画出曲线,贝兹曲线由线段与节点组成,节点是可拖动的支点,线段像可伸缩的皮筋。

css3-transition

cubic-bezier即为贝塞尔曲线中的绘制方法。图上有四点,P0-3,其中P0、P3是默认的点,对应了[0,0], [1,1]。而剩下的P1、P2两点则是我们通过cubic-bezier()自定义的。cubic-bezier(x1, y1, x2, y2) 为自定义,x1,x2,y1,y2的值范围在[0, 1]。

而在CSS3中,常用的几个动画效果,用cubic-bezier表示分别为:

贝塞尔曲线进阶

1、线性曲线

1

线性贝塞尔曲线演示动画,t in [0,1]

2、二次曲线

为建构二次贝塞尔曲线,可以中介点Q0Q1作为由0至1的t

  • P0P1的连续点Q0,描述一条线性贝塞尔曲线。
  • P1P2的连续点Q1,描述一条线性贝塞尔曲线。
  • Q0Q1的连续点Bt),描述一条二次贝塞尔曲线。

2

三次贝塞尔曲线的结构

 

2

二次贝塞尔曲线演示动画,t in [0,1]

3、高阶曲线

为建构高阶曲线,便需要相应更多的中介点。对于三次曲线,可由线性贝塞尔曲线描述的中介点Q0Q1Q2,和由二次曲线描述的点R0R1所建构:

3

三次贝塞尔曲线的结构

 

3

三次贝塞尔曲线演示动画,t in [0,1]

 

对于四次曲线,可由线性贝塞尔曲线描述的中介点Q0Q1Q2Q3,由二次贝塞尔曲线描述的点R0R1R2,和由三次贝塞尔曲线描述的点S0S1所建构:

 

4

四次贝塞尔曲线的结构

 

4

四次贝塞尔曲线演示动画,t in [0,1]

使用方法

CSS3中,动画属性为transition,常用动画如下:

我们可以通过赋予transition-timing-function不同的值来更换不同的动画,结合cubic-bezier,我们可以做出更多表现的动画。

兼容方案

相比于兼容性不佳的PC端浏览器,一些动画只能用js来实现,而js也有相应的很熟悉的动画库jquery.easeing.js

下面的例子是分别用js及css3实现的效果:http://www.xuanfengge.com/demo/201505/easing/

实现起来也很简单

</head>
<body>
<div class=“demo demo1”>demo1</div>
<div class=“demo demo2”>demo2</div>

&lt;script&gt;
$(".demo1").animate({ left: '+=800px' }, 1200, 'easeInOutCirc', function(){
	console.log('end');
});

setTimeout(function(){
	$(".demo2").css({left: '800px'});
}, 100)
&lt;/script&gt;

</body>
</html>

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
< ! DOCTYPE html >
< html lang = "en" >
< head >
     < meta charset = "UTF-8" >
     < title > Document < / title >
     <script src = "http://cdnjs.gtimg.com/cdnjs/libs/jquery/2.1.1/jquery.js" > </script>
     <script src = "js/jquery.easing.1.3.js" > </script>
     <style>
     * { padding : 0 ; margin : 0 ; }
     .demo {
         position : absolute ;
         width : 40px ;
         height : 40px ;
         background : #39c ;
         margin : 100px ;
         left : 0 ;
     }
     .demo1 {
         top : 10px ;
     }
 
     .demo2 {
         top : 100px ;
           -webkit-transition : all 600ms cubic-bezier ( 0.47, 0, 0.745, 0.715 ) ;
           transition :          all 600ms cubic-bezier ( 0.47, 0, 0.745, 0.715 ) ;
     }
     .demo2:hover {
         left : 800px ;
     }
     </style>
< / head >
< body >
     < div class = "demo demo1" > demo1 < / div >
     < div class = "demo demo2" > demo2 < / div >
 
     <script>
     $ ( ".demo1" ) . animate ( { left : '+=800px' } , 1200 , 'easeInOutCirc' , function ( ) {
         console . log ( 'end' ) ;
     } ) ;
 
     setTimeout ( function ( ) {
         $ ( ".demo2" ) . css ( { left : '800px' } ) ;
     } , 100 )
     </script>
< / body >
< / html >
        <div class="person-messagebox">
            <div class="left-message"><a href="https://blog.csdn.net/qq_25600055">
                <img src="https://profile.csdnimg.cn/4/4/2/3_qq_25600055" class="avatar_pic" username="qq_25600055">
            </a></div>
            <div class="middle-message">
                                    <div class="title"><span class="tit "><a href="https://blog.csdn.net/qq_25600055" data-report-click="{&quot;mod&quot;:&quot;popu_379&quot;,&quot;ab&quot;:&quot;new&quot;}" target="_blank">173300598</a></span>
                    <!-- 等级,level -->
                                            <img class="identity-icon" src="https://csdnimg.cn/identity/blog7.png">                                            </div>
                <div class="text"><span>原创文章 21</span><span>获赞 83</span><span>访问量 95万+</span></div>
            </div>
                            <div class="right-message">
                                        <a class="btn btn-sm  bt-button personal-watch" data-report-click="{&quot;mod&quot;:&quot;popu_379&quot;,&quot;ab&quot;:&quot;new&quot;,&quot;extend1&quot;:&quot;个人信息未关注&quot;}">关注</a>
                                                            <a href="https://bbs.csdn.net/topics/395528783" target="_blank" class="btn btn-sm bt-button personal-messageboard">他的留言板
                    </a>
                                </div>
                        </div>
                    
    </div>
</article>
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值