Maison >interface Web >js tutoriel >Effets spéciaux de déformation et d'animation CSS3_form

Effets spéciaux de déformation et d'animation CSS3_form

WBOY
WBOYoriginal
2016-05-16 15:49:201859parcourir

Ce qui suit vous montrera les effets de déformation et d'animation de CSS3 à travers des images et des textes

Plusieurs propriétés de l'animation CSS3 : transformation, transition et animation.

Introduit ci-dessous : transition.

1. Exemple

Tout d’abord, comprenons l’effet d’animation de la transition à travers un exemple.

Placez la souris dessus et la largeur du div passera de 100px à 200px.

<style type="text/css"> 
div{  
width: 100px; 
height: 100px;  
background-color: red; 
} 
div:hover{ 
width: 200px; 
}</style><div></div>

Cet effet est en fait une animation, mais il change très rapidement et n'est pas fluide.

Si vous souhaitez que la largeur du div passe en douceur à 200 pixels dans les 5 secondes suivant le placement de la souris dessus. Ajoutez simplement une ligne de code

Copier le code Le code est le suivant :

div: survol {
largeur : 200px ;
transition:largeur 5 s facilité d'entrée ;}

Cet effet est en fait une animation, mais il change très rapidement et n'est pas fluide.

Si vous souhaitez que la largeur du div passe en douceur à 200 pixels dans les 5 secondes suivant le placement de la souris dessus. Ajoutez simplement une ligne de code

Copier le code Le code est le suivant :

div: survol {
largeur : 200px ;
transition:largeur 5 s facilité d'entrée ;}

Ce qui est utilisé ici est l'attribut de transition, qui est utilisé pour obtenir une transition en douceur des valeurs d'attribut et produire des effets d'animation visuelle.

La transition utilisée ci-dessus est une abréviation et contient quatre attributs : transition-property, transition-duration, transition-timing-function et transition-delay, qui seront introduits un par un ci-dessous.

2. transition

CSS3 ajoute un nouvel attribut de transition, qui peut rendre l'effet plus délicat et plus fluide lorsque le style d'un élément déclenché par un événement change.

transition est utilisé pour décrire comment faire en sorte que les valeurs d'attribut CSS passent en douceur d'une valeur à une autre au cours d'une période de temps. Cet effet de transition peut être déclenché par un clic de souris, obtention du focus, clic ou toute modification de l'élément.

Syntaxe :

transition :
[<'transition-property'> || <'transition-duration'> || <'transition-timing-function'> ||
<'transition-delay'> [, [<'transition-property'> || <'transition-duration'> || 
<'transition-timing-function'> || <'transition-delay'>]]*

La transition a quatre valeurs d'attribut :

transition-property : La propriété pour effectuer la transition.

transition-duration : Précisez le temps nécessaire pour terminer la transition.

Fonction de synchronisation de transition, pendant la période de durée, le taux de transformation de transition change. Une compréhension simple consiste à spécifier la fonction de transition.

transition-delay : temps de retard de transition.

1. propriété de transition

Transition-property est utilisé pour spécifier quelle propriété utilise l'effet d'animation de transition.

Syntaxe :

Copier le code Le code est le suivant :

propriété de transition : aucun | tous [ d884a6b931fdbb356017136528ef8576
aucun : aucun effet de transition n'est appliqué à tous les attributs.

tout : Valeur par défaut. Lorsque la valeur est tout, l'effet de transition sera exécuté lorsqu'une valeur d'attribut de l'élément change.

ident : nom de l'attribut de l'élément. Spécifiez des attributs spécifiques via ident. Si un effet de transition ne peut pas être appliqué à l'un des multiples attributs spécifiés, les autres attributs prendront quand même effet.

Les attributs de transition ne peuvent avoir des effets de transition que s'ils ont une

valeur médiane (attributs qui doivent être animés). Toutes les valeurs d'attribut CSS et les types de valeurs pouvant obtenir des effets de transition sont répertoriés dans w3c

Property Name  
Typebackground-color 
as colorbackground-position 
as repeatable list of simple list of length, percentage, or calcborder-bottom-color 
as colorborder-bottom-width 
as lengthborder-left-color 
as colorborder-left-width 
as lengthborder-right-color 
as colorborder-right-width 
as lengthborder-spacing 
as simple list of lengthborder-top-color 
as colorborder-top-width 
as lengthbottom 
as length, percentage, or calcclip 
as rectanglecolor 
as colorfont-size 
as lengthfont-weight 
as font weightheight  
as length, percentage, or calcleft 
as length, percentage, or calcletter-spacing 
as lengthline-height  
as either number or lengthmargin-bottom 
as lengthmargin-left 
as lengthmargin-right 
as lengthmargin-top  
as lengthmax-height  
as length, percentage, or calcmax-width 
as length, percentage, or calcmin-height 
as length, percentage, or calcmin-width 
as length, percentage, or calcopacity 
as numberoutline-color 
as coloroutline-width 
as lengthpadding-bottom 
as lengthpadding-left 
as lengthpadding-right 
as lengthpadding-top 
as lengthright  
as length, percentage, or calctext-indent 
as length, percentage, or calctext-shadow 
as shadow listtop  
as length, percentage, or calcvertical-align  
as lengthvisibility  
as visibilitywidth 
as length, percentage, or calcword-spacing 
as lengthz-index 
as integer

Remarque : Toutes les modifications d'attributs ne déclencheront pas l'effet d'animation de transition, comme la largeur adaptative de la page. Lorsque le navigateur modifie la largeur, l'effet de transition ne sera pas déclenché. Cependant, les modifications apportées aux types d'attributs indiqués dans le tableau ci-dessus déclencheront un effet d'action de transition.

Par exemple : vous pouvez animer plusieurs attributs en même temps, comme définir des effets d'animation pour la hauteur et la hauteur de ligne en même temps, de sorte que le div devienne plus grand et que le texte soit toujours centré verticalement.

<!DOCTYPE html><html><head> 
<meta charset="utf-8"> 
<title>变形与动画</title> 
<style type="text/css">div { 
width: 300px; 
height: 200px; 
line-height: 200px; 
text-align: center; 
background-color: orange; 
margin: 20px auto; 
-webkit-transition-property: height line-height; 
transition-property: height line-height; 
-webkit-transition-duration: 1s; 
transition-duration: 1s; 
-webkit-transition-timing-function: ease-out; 
transition-timing-function: ease-out; 
-webkit-transition-delay: .2s; 
transition-delay: .2s;}div:hover { 
height: 100px; 
line-height: 100px;}</style></head><body> 
<div>文字垂直居中</div></body></html>

2. durée de transition

La durée de transition est utilisée pour définir le temps nécessaire pour passer de l'ancien attribut au nouvel attribut, c'est-à-dire la durée.

3. fonction de synchronisation de transition

Syntaxe :

Copier le code Le code est le suivant :

ff090e1dc4fab42543f9679c8cd9fa30 = ease | linear | ease-in | ease-out | ease-in-out | step-start | step-end | steps(979e7f42ea08258251c39ffe96b911f2[, [ start | end ] ]?) | cubic-bezier(d80b5def5ed1be6e26d91c2709f14170, d80b5def5ed1be6e26d91c2709f14170, d80b5def5ed1be6e26d91c2709f14170, d80b5def5ed1be6e26d91c2709f14170)

transition-timing-function属性指的是过渡的“缓动函数”。通过这个函数会建立一条加速度曲线,因此在整个transition变化过程中,变化速度可以不断改变。主要包括以下几种函数。

ease:默认值,元素样式从初始状态过渡到终止状态速度由快到慢,逐渐变慢。linear:意思是线性过渡,即过渡过程恒速。ease-in:速度越来越快,呈现加速状态,通常称为“渐显效果”。ease-out:速度越来越慢,呈现减速状态,通常称为“渐隐效果”。ease-in-out速度先加速后减速,称为“渐显渐隐效果”。

举例:鼠标经过问号,帮助信息渐显渐隐。

<!doctype html><html><head> 
<meta charset="utf-8"> 
<title>transition-demo by starof</title> 
<style>#help{ 
width:20px; 
height:20px; 
border-radius:10px; 
color:#fff; 
background:#000; 
text-align:center; 
position:relative; 
margin:50px 20px; 
cursor:pointer;}#help .tips{ 
position:absolute; 
width:300px; 
height:100px; 
background:#000; 
top:-30px; 
left:35px; 
border-radius:10px; 
opacity:0; 
/*渐隐效果*/ 
transition: opacity .8s ease-in-out; 
-moz-transition: opacity .8s ease-in-out; 
-webkit-transition: opacity .8s ease-in-out;}.tips:before{ 
content:""; 
border-width:10px; 
border-style:solid; 
 border-color:transparent #000 transparent transparent; 
 position:absolute; 
 left:-20px; 
 top:30px;}#help:hover .tips{ 
 opacity:0.5; 
 /*渐显效果*/ 
 transition: opacity .8s ease-in-out; 
 -moz-transition: opacity .8s ease-in-out; 
 -webkit-transition: opacity .8s ease-in-out;}</style></head><body> 
 <div id="help">  
 &#63;  
 <div >帮助信息</div> 
</div></body></html>

4、transition-delay

transition-delay设置改变属性值后多长时间开始执行动画。

5、属性简写

在改变多个css属性的transition效果时,把几个transition声明用逗号隔开,然后每个属性就都有各自的过渡时间和效果。

Note:第一个时间是时长,第二个是延时。

复制代码 代码如下:

a{
transition: background 0.8s ease-in 0.3,
color 0.6s ease-out 0.3;}

 三、贝塞尔曲线和transition

transition的数学模型就是贝塞尔曲线,下面介绍。

曲线其实就是两点之间插值的效果,贝塞尔曲线是一种插值算法,比线性插值复杂一点。

贝塞尔曲线:起始点,终止点(也称锚点),控制点。通过调整控制点,贝塞尔曲线的形状发生变化。

k阶贝塞尔插值算法需要k+1个控制点。

一阶贝塞尔曲线(线段):意思就是从P0到P1的连续点,用来描述一段线段。一次贝塞尔插值就是线性插值。

 

二阶贝塞尔曲线(抛物线):P0-P1是曲线在P0处的切线。

三阶贝塞尔曲线:

transition用到的就是三阶贝塞尔插值算法,如下图。

时间在0,1区间,待变换属性也认为是0,1区间。P0和P3的坐标一直是(0,0)和(1,1)。transition-timing-function属性用来确定P1和P2的坐标。

 

ease [0, 0] [0.25, 0.1] [0.25, 1.0] [1.0,1.0]
linear [0, 0] [0.0, 0.0] [1.0, 1.0] [1.0,1.0]
ease-in [0, 0] [0.42, 0] [1.0, 1.0] [1.0,1.0]
ease-out [0, 0] [0, 0] [0.58, 1.0] [1.0,1.0]
ease-in-out [0, 0] [0.42, 0] [0.58, 1.0] [1.0,1.0]
step-start steps(1,start)
step-end steps(1,end)
cubic-bezier(x1,y1,x2,y2) [0, 0] [x1, y1] [x2, y2] [1.0,1.0]

四、其他相关资料

canvas画贝塞尔曲线

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8">
<title>bezier demo</title>
</head>
<body>
<div style="width:800px;height:600px;background-color:#fac0c0;">
<canvas id="cvs" width="800" height="600">骚瑞,您的浏览器不支持canvas</canvas>
</div>
<script type="text/javascript">var cvs=document.getElementById("cvs"),
context=cvs.getContext("2d"),points=[];function getXY(node){var x=0,y=0;if (node.offsetParent)
{while (node.offsetParent)
{x += node.offsetLeft;y += node.offsetTop;node = node.offsetParent;}}
else {node.x && (x += node.x);node.y && (y += node.y);}return [x,y];}
function drawPoint(x,y,c,b) {!b && (b=2);context.fillStyle=c || "red";
context.fillRect(x,y,b,b);}function bezier(points,t){var i,n=points.length-1,x=0,y=0;function fn(p,n,i,t){return arrangement(n,i)*p*Math.pow(1-t,n-i)*Math.pow(t,i);}for(i=0;i<n+1;i++){x+=fn(points[i][0],n,i,t);
y+=fn(points[i][1],n,i,t);}return [x,y];}function factorial(n){if(isNaN(n) || n<=0 || Math.floor(n)!==n){return 1;}var s=1;
while(n){s*=n--;}return s;}function arrangement(n,r){return factorial(n)/(factorial(r)*factorial(n-r));}
cvs.addEventListener("click",function(event){var i,point=getXY(this),x=event.clientX-point[0]+(document.documentElement.scrollLeft || document.body.scrollLeft),y=event.clientY-point[1]+(document.documentElement.scrollTop || document.body.scrollTop);points.push([x,y]);context.clearRect(0,0,screen.width,screen.height);context.beginPath();
//pointsfor(i=0;i<points.length;i++){drawPoint(points[i][0],points[i][1],"blue",4);}//bezierfor (i = 0; i < 1; i += 0.001)
{drawPoint.apply(this, bezier(points,i));}//lineif(points.length==1){context.moveTo(points[0][0],points[0][1]);}else if (points.length>1){for(i=0;i<points.length;i++){context.lineTo(points[i][0],points[i][1]);}
context.lineWidth=0.2;context.stroke();context.closePath();}},true);</script>
</body>
</html>

 

希望这些内容可以帮助到大家,谢谢。

Déclaration:
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn