温馨提示×

温馨提示×

您好,登录后才能下订单哦!

密码登录×
登录注册×
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》

CSS3中transform属性如何进行2D和3D变换

发布时间:2021-08-30 14:45:46 来源:亿速云 阅读:109 作者:小新 栏目:web开发

这篇文章给大家分享的是有关CSS3中transform属性如何进行2D和3D变换的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。

transform 2D
之前有看到google将搜寻的页面倾斜,这个功能透过CSS3的transform就可以达成
CSS3 2D transform特性可以旋转、倾斜、放大缩小和移动元素,对网页的视觉观感上提供很大的帮助
使用方法:

transform: transform-function;   
-webkit-transform: transform-function; /* Safari and Chrome */  
-moz-transform: transform-function; /* Firefox */  
-o-transform: transform-function; /* Opera */  
-ms-transform:transform-function; /* IE9以上 */

变形函式 transform-function:
函式里的θ参数要有单位,有三种单位可以使用:deg (角度) 、 rad (弧度) 、 grad (梯度)。
1.rotate(θ):以参考点为中心轴 2D 旋转 θ 度。
2.skew(θx,θy):以参考点为中心轴沿着横向倾斜 θx 度、纵向倾斜 θy 度( 可以拆开成skewX(θ)和skewY(θ) )
3.scale(x,y):指定元素由参考点 2D 横向缩放 x 倍、纵向缩放 y 倍( 可以拆开成scaleX(x)和scaleY(y),此函式的参数不需要单位 )
4.translate(x,y):指定元素由参考点 2D 横向移动 x 距离、纵向移动 y 距离( 可以拆开成translateX(x)和translateY(y),此函式的参数单位为px )
5.matrix(a,b,c,d,e,f):指定元素由参考点依据数学变形矩阵 (transformation matrix) 的 6 个参数值产生 2D 变形( 此函式的参数为数字,不需要单位 )
Sample

/* Safari and Chrome 网页倾斜50度 */  
-webkit-transform: rotate(50deg);

transform 3D & perspective
CSS3的transform可以做2D的操作,当然也有3D
但需要再一个拥有perspective属性的父元素才能显现3D的效果
例如:

<div id="div1"><!-- perspective -->  
  <div id="div2">3D</div><!-- transform -->  
</div>

perspective属性固名思义就是透视的意思;该属性可以定义3D视觉的角度,让底下子元素使用3D特效时能够完整显示。

perspective使用方法
perspective:150px;

/* 目前并非所有浏览器皆支援 */   
-webkit-perspective:150px;   
-moz-perspective:150px;

另外还有个属性叫perspective-origin
功能是用来定义X和Y轴为基础的3D位置(定义初始位置)
perspective-origin使用方法:
属性值:(x轴:left、center、right、长度、百分比) (y轴:top、center、bottom、长度、百分比)

/* perspective-origin 参数预设是50% 50% */  
-webkit-perspective-origin: 40% 60%;/* Safari and Chrome */  
-webkit-perspective-origin: 40px 60px;/* Safari and Chrome */  
-moz-perspective-origin:left bottombottom; /* Firefox */

注意:perspective和perspective-origin受影响的是子元素,而非元素本身

最后就可以对div做3D的效果(rotateX和rotateY)

-webkit-transform: rotateX(290deg);   
-webkit-transform: rotateY(290deg);   
-moz-transform: rotateX(290deg);   
-moz-transform: rotateY(290deg);

感谢各位的阅读!关于“CSS3中transform属性如何进行2D和3D变换”这篇文章就分享到这里了,希望以上内容可以对大家有一定的帮助,让大家可以学到更多知识,如果觉得文章不错,可以把它分享出去让更多的人看到吧!

向AI问一下细节

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

AI