欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

CSS3中的transform属性进行2D和3D变换的基本用法

程序员文章站 2022-06-29 17:59:05
这篇文章主要介绍了使用CSS3中的transform属性进行2D和3D变换的基本用法,文中同时介绍了使用perspective-origin定义初始位置的方法,需要的朋友可以参考下... 16-05-12...

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

css code复制内容到剪贴板
  1. transform: transform-function;   
  2. -webkit-transform: transform-function; /* safari and chrome */  
  3. -moz-transform: transform-function; /* firefox */  
  4. -o-transform: transform-function; /* opera */  
  5. -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

javascript code复制内容到剪贴板
  1. /* safari and chrome 网页倾斜50度 */  
  2. -webkit-transform: rotate(50deg);  

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

xml/html code复制内容到剪贴板
  1. <div id="div1"><!-- perspective -->  
  2.   <div id="div2">3d</div><!-- transform -->  
  3. </div>  

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

xml/html code复制内容到剪贴板
  1. /* 目前并非所有浏览器皆支援 */   
  2. -webkit-perspective:150px;   
  3. -moz-perspective:150px;  

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

css code复制内容到剪贴板
  1. /* perspective-origin 参数预设是50% 50% */  
  2. -webkit-perspective-origin: 40% 60%;/* safari and chrome */  
  3. -webkit-perspective-origin: 40px 60px;/* safari and chrome */  
  4. -moz-perspective-origin:left bottombottom/* firefox */  

注意:perspective和perspective-origin受影响的是子元素,而非元素本身
最后就可以对div做3d的效果(rotatex和rotatey)

css code复制内容到剪贴板
  1. -webkit-transform: rotatex(290deg);   
  2. -webkit-transform: rotatey(290deg);   
  3. -moz-transform: rotatex(290deg);   
  4. -moz-transform: rotatey(290deg);