|
|
在CSS3中,可以利用transform功能实现文字或图像的旋转、缩放、倾斜、移动这4中类型的变形处理。
0 O7 f5 _/ E3 S/ E2 h1 b a' a1、浏览器支持
% s, K" z n( B2 m. K m. o5 G* i( o8 s7 o6 I }8 U: V
到目前为止:Safari3.1以上、Chrome8以上、Firefox4以上、Opera10以上浏览器支持该属性。
5 E) l3 i9 F) Q Y) x _4 U0 ]. j2、旋转
+ R# _' `2 Z& i2 l+ |8 h8 @2 h
! v* S: `; w4 y6 `使用rotate方法,在参数中加入角度值,角度值后面跟表示角度单位的“deg”文字即可,旋转方向为顺时针方向。3、缩放
: h3 g- R' Z) j4 [
. m7 W3 d1 W \6 s9 g" w( U2 ^% N使用scale方法来实现文字或图像的缩放处理,在参数中指定缩放倍率。- transform:scale(0.5);//缩小一半
复制代码 (1)可以分别指定元素的水平方向的放大倍率与垂直方向的放大倍率- transform:scale(0.5,2);//水平方向缩小一半,垂直方向放大一倍。
复制代码 4、倾斜9 u. q3 c5 l& q) m5 @3 S7 E
7 w; y+ {/ ^) V$ Y
使用skew方法实现文字或图像的倾斜处理,在参数中分别指定水平方向上的倾斜角度与垂直方向上的倾斜角度。- transform:skew(30deg,30deg);//水平方向上倾斜30度,垂直方向上倾斜30度。
复制代码 (1)只使用一个参数,省略另一个参数, ]: \' W) u* o. Z
这种情况下视为只在水平方向上进行倾斜,垂直方向上不倾斜。5、移动
. P% h0 j5 G- E7 |# j/ v% B ?5 w0 |$ U! i+ y1 a
使用translate方法来移动文字或图像,在参数中分别指定水平方向上的移动距离与垂直方向上的移动距离。- transform:translate(50px,50px);//水平方向上移动50px,垂直方向上移动50px
复制代码 (1)只使用一个参数,省略另一个参数
& N0 k6 @9 m! Z* |: w, H这种情况下视为只在水平方向上移动,垂直方向上不移动。- transform:translate(50px);
复制代码 6、对一个元素使用多种变形的方法 - transform:translate(150px,200px)rotate(45deg)scale(1.5);
复制代码 7、指定变形的基准点 J) k; k7 e ~' p9 P4 t* w
' w8 s/ _5 S. u
在使用transform方法进行文字或图像变形的时候,是以元素的中心点为基准点进行变形的。
) ?! g0 B" c4 j0 ztransform-origin属性' q' @- K# p3 Y' @) X3 u9 L: n
使用该属性,可以改变变形的基准点。- transform:rotate(45deg);transform-origin:leftbottom;//把基准点修改为元素的左下角
复制代码 (1)指定属性值) {7 a8 }* Q8 k/ q4 h
基准点在元素水平方向上的位置:left、center、right6 b" L0 v% ?# `4 A, t% \- u
基准点在元素垂直方向上的位置:top、center、bottom6 e: |! ]$ |( z! m
8、3D变形功能
1 Q$ B x' Q4 o* A1 p5 G5 o
- e+ y4 A, V8 z& s9 u/ N: h(1)旋转
! @5 X8 ~8 t% \: ^1 ^* I分别使用rotateX方法、rotateY方法、rotateZ方法使元素围绕X轴、Y轴、Z轴旋转,在参数中加入角度值,角度值后面跟表示角度单位的deg文字即可,旋转方向为顺时针旋转。- transform:rotateX(45deg);transform:rotateY(45deg);transform:rotateZ(45deg);transform:rotateX(45deg)rotateY(45deg)rotateZ(45deg);transform:scale(0.5)rotateY(45deg)rotateZ(45deg);
复制代码 (2)缩放6 a! a/ S2 R1 r, q* R9 S
分别使用scaleX方法、scaleY方法、scaleZ方法使元素按X轴、Y轴、Z轴进行缩放,在参数中指定缩放倍率。- transform:scaleX(0.5);transform:scaleY(1);transform:scaleZ(2);transform:scaleX(0.5)scaleY(1);transform:scale(0.5)rotateY(45deg);
复制代码 (3)倾斜
2 w0 T/ ?' q) {2 s分别使用skewX方法、skewY方法使元素在X轴、Y轴上进行顺时针方向倾斜(无skewZ方法),在参数中指定倾斜的角度- transform:skewX(45deg);transform:skewY(45deg);
复制代码 (4)移动
" P+ V5 G, S8 }分别使用translateX方法、translateY方法、translateZ方法、使元素在X轴、Y轴、Z轴方向上进行移动,在参数中加入移动距离。- transform:translateX(50px);transform:translateY(50px);transform:translateZ(50px);
复制代码 9、变形矩阵
: l. x3 B( U* K; \$ L
7 Z& n" p8 e+ f& O每种变形方法的背后都存在着一个对应的矩阵。: [7 Y( ^9 x/ l! P! A1 o" K+ d
(1)计算2D变形(3X3矩阵)- \begin{bmatrix}a&c&e\\b&d&f\\0&0&1\end{bmatrix}
复制代码 可以将这个2D变形矩阵书写为matrim(a,b,c,d,e,f),a~f均代表一个数字,用于决定怎样执行变形处理。
$ J7 E- M0 w' m( k(2)平移的2D矩阵- \begin{bmatrix}1&0&tx\\0&1&ty\\0&0&1\end{bmatrix}//效果一致:右移150px,下移150pxtransform:matrix(1,0,0,1,150,150);transform:translate(150px,150px);
复制代码 (3)计算3D变形
4 {' i! i* [* m1 @$ ? f3D缩放变形使用的4X4矩阵- \begin{bmatrix}sx&0&0&0\\0&sy&0&0\\0&0&sz&0\\0&0&0&1\end{bmatrix}transform:matrix3d(sx,0,0,0,0,sy,0,0,0,0,sz,0,0,0,0,1);//效果一致:X轴方向上缩小五分之一,Y轴方向上缩小一半。transform:scale3d(0.8,0.5,1);transform:matrix3d(0.8,0,0,0,0,0.5,0,0,0,0,1,0,0,0,0,1);
复制代码 (4)可通过矩阵执行多重变形处理
" f4 _* y, N1 Z) r2 D将需要的变形矩阵相乘得到一个新的变形矩阵可实现该处理。
1 f* ^/ L( w9 |0 F- ?到此这篇关于css3中transform属性实现的4种功能的文章就介绍到这了,更多相关css3中transform属性实现内容请搜索脚本之家以前的文章或继续浏览下面的相关文章,希望大家以后多多支持脚本之家!
' C) i3 E8 n3 e9 G" Z' e
/ S! u0 U8 S1 e' b来源:http://www.jb51.net/css/784776.html
) a, k% J7 P# O) Y% {1 L免责声明:如果侵犯了您的权益,请联系站长,我们会及时删除侵权内容,谢谢合作! |
|