可以这么说,3D变换是基于三维坐标系的。以下是“盗用”的图

CSS3中的3D变换主要包括以下几个功能函数:

  • 3D位移:包括translateZ()和translate3d();
  • 3D旋转:包括rotateX()、rotateY()、rotateZ()和rotate3d();
  • 3D缩放:包括scaleZ()和scale3d();
  • 3D矩阵:matrix3d();

一、translate3d()

具体的css使用为

transform: translate3d(tx, ty, tz);

  tx、ty、tz应该不用多介绍了。

 二、translateZ()

让元素在3D空间沿Z轴进行位移。具体的css使用为

transform: translateZ(t);

当t为负值的时候,意味着元素在Z轴越移越远,我们人眼看到的就是元素变得越来越小。反之,元素在Z轴越移越近,导致元素变得越大。

translateZ()等同于translate3d(0,0,tz)。

三、rotateX()、rotateY()、rotateZ()和rotate3d()

rotateX(a)、rotateY(a)、rotateZ(a)函数让一个元素围绕X、Y、Z轴旋转。a表示旋转角度值。若为正值,元素顺时针旋转;反之为逆时针。

rotate3d(x,y,z,a),其中,

x(y)(z)取值为0~1的数值,用来描述元素围绕X(Y)(Z)轴旋转的矢量值;

a为角度值,指定元素的空间旋转角度。

当x,y,z三个值同时为0时,元素的3D空间不做任何旋转。rotateX(a)等价于rotate(1,0,0,,a)、rotateY(a)等价于rotate(0,1,0,a)、rotateZ(a)等价于rotate(0,0,1,a)。

四、scaleZ()和scale3d()

即3D缩放。当scale3d()中x轴和Y轴同为1,即scale3d(1,1,sz),其效果等同于scaleZ(sz)。

(个人觉的,除了让元素只在Z轴上按比例缩放、各值取(-1)达到对称变换这些用途具有实用性之外,一般不会去同时缩放x,y吧,因为前者是基于相似图形,具有可控性,后     者要求想象能力实在是太高了>_<)

五、matrix3d()

3D矩阵在此不再赘述,学好图形学中的矩阵变换就行。

实际应用的时候,你必须关注的问题

  相关属性有一个叫做perspective属性,翻译为中文叫做:透视,视角。通俗一点地将就是“看东西的角度,你的眼睛所在的点”。但是在css3 3D变换中,透视点是在浏览器的前方。有人是这么解析的“比方说,一个1680像素宽的显示器中有张图片,应用了3D transform,同时,该元素或该元素父辈元素设置的perspective大小为2000像素。则这张图片呈现的3D效果就跟你本人在1.2个显示器宽度的地方(1680*1.2≈2000)看到的真实效果一致!!”~注意:属性值不能为负值。

更有趣的是:perspective有两种设置方式,一种是在容器上,一种是在自身元素上。需要注意的一点是:当容器里面只有一个元素的时候,这两种设置方法所表现出来的效果是一样。那这两种设置方法的差异在哪里呢?

且看下图(还是盗用别人的):

区别很明显,在以整个容器为视角对象的时候,你看到了不同形态的正方形,而当以每个方块为视角对象的时候,所有方块在perspective相同的情况下所表现出来的效果是一样的。打个通俗的比方是:有若干形态相同的杯子摆在橱柜里,你在橱柜外面,不断调整你眼睛所在的位置进行观察,你会看不同的场景图,这所谓的不同是你视角变化的时候前后对照的表现;而如果夸张一点,假如你有n只眼睛,一只眼睛看一个杯子,然后你同方向移动你那n只眼睛,每只眼睛看到的杯子形态还是一样的,这不是视角变化前后的对照,是同一时刻,每只眼睛看到的东西的对照。

还有一个相关属性叫做:perspective-origin。“就是你的眼睛往哪里看”。

还有一个相关属性叫做:transform-style: flat|preserve-3d,flat为默认值,表示的是平面,preserve-3d表示3D透视,实现3d效果。transform-style设置在容器上。

还有一个相关属性叫做:backface-visibility:hidden。因为在css3的3D世界中,我们可以看到背后的元素,但是这却和现实世界不相符,所以就有将backface-visibility设置为hidden的做法。

相关实践代码可以github上的获取: https://github.com/Gyingguo/css3-demo

参考资料: 《图解css3核心技术与案例实战》张鑫旭博客 CSS3 3D transform变换

CSS3 3D变换的更多相关文章

  1. css3 3D变换和动画

    3D变换和动画 建立3D空间,transform-style: preserve-3d perspective: 100px; 景深 perspective-origin:center center ...

  2. CSS3 3D变换实例 滚动的正方体

    笔记: 2D变换 transform 位移   translateX() translateY()  简写:translate(X值,Y值)  正值向右,负值向左 旋转 rotate()  rotat ...

  3. css3 3d变换和动画——回顾

    1.transform-style 属性指定嵌套原始是怎样在三维空间中呈现. 语法:transform-style: flat | preserve-3d flat 表示所有子元素在2D平面呈现. p ...

  4. CSS3之3D变换实例详解

    CSS3的3D效果很赞,本文实现简单的两种3D翻转效果.首先看效果和源代码,文末是文绉绉的总结部分^_^ 以下CSS代码为了简洁没有添加前缀,请视情况自行添加(自动化时代推荐使用其他的一些方法,如gu ...

  5. 好吧,CSS3 3D transform变换,不过如此!

    一.写在前面的秋裤 早在去年的去年,我就大肆介绍了2D transform相关内容.看过海贼王的都知道,带D的家伙都不是好惹的,2D我辈尚可以应付,3D的话,呵呵,估计我等早就在千里之外被其霸气震晕了 ...

  6. 好吧,CSS3 3D transform变换,不过如此!——张鑫旭

    一.写在前面的秋裤 早在去年的去年,我就大肆介绍了2D transform相关内容.看过海贼王的都知道,带D的家伙都不是好惹的,2D我辈尚可以应付,3D的话,呵呵,估计我等早就在千里之外被其霸气震晕了 ...

  7. IT兄弟连 HTML5教程 CSS3属性特效 3D变换1

    3D变换较2D变换多了一下的转换属性,3D转换属性及描述如表1: 表1  3D转换属性 3D的转换方法如表2: 表2  3D转换方法     1  transform-style transform- ...

  8. CSS3之3d变换与关键帧

    3d变换是在transform基础上实现的 transform-style:preserve-3d; 建立3d空间 perspective:; 景深(设置用户看的距离) perspective-ori ...

  9. CSS3 3D transform变换

    .实际应用-图片的旋转木马效果 您可以狠狠地点击这里:图片的旋转木马效果demo 建议在足够新版本的FireFox浏览器或Safari浏览器下观看,Chrome可能需要居中定位查看,下图为效果缩略图: ...

随机推荐

  1. 学习c编程的第三天

    #include<stdio.h> int add(int,int); int main(){ int x=add(1,2); printf("%d",x); retu ...

  2. 瀑布流ListView

    前言 终于忙完了一段时间,现在前段时间写的一个瀑布流ListView到想法分享下,这个东西是扩展自Listview,当列表内容拉到最后后触发刷新操作,以便抓取更多到数据. 先贴下整个代码,先有个整体到 ...

  3. centos下安装php环境

    centos下安装php环境 安装apache yum install httpd-devel 启动apache /etc/init.d/httpd start 安装mysql yum install ...

  4. php5 date()获得的时间不是当前时间

    php自5.10起加入了时区的设置,在php中显示的时间都是格林威治标准时间,因此便与中国的用户会差八个小时. 修改php.ini中的 date.timezone 参数: [Date] ; Defin ...

  5. 【转】利用DCC32实现命令行批量编译

    *.dof [Compiler] A=1 B=0 C=1 D=1 E=0 F=0 G=1 H=1 I=1 J=1 K=0 L=1 M=0 N=1 O=1 P=1 Q=0 R=0 S=0 T=0 U=0 ...

  6. asp.net 发布后用IP访问正常,用机器名访问布局出错

    问题如题[发布后IP访问正常,用机器名访问布局出现问题] 出现此问题的原因:IE文档模型发生变化,比如ip访问时IE文档模型为:IE10,换用机器名访问时,文档模型变为IE7 解决方法:设置默认IE版 ...

  7. STM32F0xx_USART收发配置详细过程

    前言 串口对于处理器来说算是一种标配,也是在软件开发中必不可少的,那就是使用串口来调试信息(打印出相应的信息).STM32F0系列的芯片,串口根据型号不同,数量也不同,从1个到8个不等. 今天主要总结 ...

  8. 解决 MVC 用户上线下线状态问题

    以前工作项目中就有一个微博类功能,其中也出现了用户在线和离线的问题. 但是因为初入程序猿 使用的是 Session _end 上个事件. Session _end 这个事件不需要怎么解释吧 就是在se ...

  9. .NET开源工作流RoadFlow-系统布署及注意事项

    非常感谢您在百忙之中抽空来了解RoadFlow,下面我们说一下如果在自己本地搭建环境吧. 1.环境要求 数据库:sqlserver2005以上版本.服务器:IIS6.0以上,或iisexpress.d ...

  10. DB2执行脚本

    经常会遇到数据库脚本放在.sql文件中,那么怎么去执行这个脚本,而不需要将脚本中的东西粘贴出来再数据库链接工具中执行呢? 下面是DB2数据库脚本执行的办法 环境介绍: 脚本文件名:Script.sql ...