详解CSS3的perspective属性设置3D变换距离的方法


Posted in HTML / CSS onMay 23, 2016

perspective属性对于3D变形来说至关重要。该属性会设置查看者的位置,并将可视内容映射到一个视锥上,继而投到一个2D视平面上。如果不指定透视,则Z轴空间中的所有点将平铺到同一个2D视平面中,并且变换结果中将不存在景深概念。

上面的描述可能让人难以理解一些,其实对于perspective属性,我们可以简单的理解为视距,用来设置用户和元素3D空间Z平面之间的距离。而其效应由他的值来决定,值越小,用户与3D空间Z平面距离越近,视觉效果更令人印象深刻;反之,值越大,用户与3D空间Z平面距离越远,视觉效果就很小。

在3D变形中,对于某些变形,例如下面的示例演示的沿Z轴的变形,perspective属性对于查看变形的效果来说必不可少。

我们先来看一个简单的实例,制作一个扑克牌3D旋转效果,并且一个在扑克牌的父元素添加了视距perspective,而另一个却没有设置:

HTML

XML/HTML Code复制内容到剪贴板
  1. <div>  
  2.     <img src="images/cardKingClub.png" alt="" width="142" height="200" />  
  3.     <img src="images/cardKingClub.png" alt="" width="142" height="200" />  
  4. </div>  
  5. <div>  
  6.     <img src="images/cardKingClub.png" alt="" width="142" height="200" />  
  7.     <img src="images/cardKingClub.png" alt="" width="142" height="200" />  
  8. </div>  

CSS

CSS Code复制内容到剪贴板
  1. div {   
  2.     width500px;   
  3.     height300px;   
  4.     margin30px auto;   
  5.     positionrelative;   
  6.     backgroundurl(images/bg-grid.jpg) no-repeat center center;   
  7.     background-size: 100% 100%;   
  8. }   
  9. div img {   
  10.     positionabsolute;   
  11.     top: 50%;   
  12.     left: 50%;   
  13.     margin-left: -71px;   
  14.     margin-top: -100px;    
  15.     transform-origin: bottombottom;   
  16. }   
  17. div img:nth-child(1){   
  18.     opacity: .5;   
  19.     z-index: 1;   
  20. }   
  21. div img:nth-child(2){   
  22.     z-index: 2;   
  23.     transform: rotateX(45deg);   
  24. }   
  25. div:nth-of-type(2){   
  26.     perspective: 500px;   
  27. }  

其效果如下:
详解CSS3的perspective属性设置3D变换距离的方法

上图的效果完全说明了一切。父节点没有设置perspective的情况下,梅花King的3D旋转效果不明显,而在父节点设置perspective后,梅花King才像个3D旋转。

上例简单的演示了perspective的使用方法,我们回过头来,看看perspective的使用语法:

CSS Code复制内容到剪贴板
  1. perspective:none | <length>  

perspective属性包括两个属性:none和具有单位的长度值。其中perspective属性的默认值为none,表示无限的角度来看3D物体,但看上去是平的。另一个值<length>接受一个长度单位大于0的值。而且其单位不能为百分比值。<length>值越大,角度出现的越远,从而创建一个相当低的强度和非常小的3D空间变化。反之,此值越小,角度出现的越近,从而创建一个高强度的角度和一个大型3D变化。

比如你站在10英尺和1000英尺的地方看一个10英尺的立方体。在10英尺的地方,你距离立方体是一样的尺寸。因此视角转变远远大于站在1000英尺处的,立体尺寸是你距离立方体距离的百分之一。同样的思维适用于perspective的<length>值。我们一起来看一个实例,来加强这方面的理解:

HTML

XML/HTML Code复制内容到剪贴板
  1. <div class="wrapper w2">  
  2.     <div class="cube">  
  3.         <div class="side  front">1</div>  
  4.         <div class="side   back">6</div>  
  5.         <div class="side  right">4</div>  
  6.         <div class="side   left">3</div>  
  7.         <div class="side    top">5</div>  
  8.         <div class="side bottom">2</div>  
  9.     </div>  
  10. </div>  
  11. <div class="wrapper w1">  
  12.     <div class="cube">  
  13.         <div class="side  front">1</div>  
  14.         <div class="side   back">6</div>  
  15.         <div class="side  right">4</div>  
  16.         <div class="side   left">3</div>  
  17.         <div class="side    top">5</div>  
  18.         <div class="side bottom">2</div>  
  19.     </div>  
  20. </div>  

CSS

CSS Code复制内容到剪贴板
  1. .wrapper {   
  2.     width: 50%;   
  3.     floatleft;   
  4. }   
  5. .cube {   
  6.     font-size: 4em;   
  7.     width: 2em;   
  8.     margin: 1.5em auto;   
  9.     transform-style: preserve-3d;   
  10.     transform: rotateX(-40deg) rotateY(32deg);   
  11. }   
  12. .side {   
  13.     positionabsolute;   
  14.     width: 2em;   
  15.     height: 2em;   
  16.     background: rgba(255, 99, 71, 0.6);   
  17.     border1px solid rgba(0, 0, 0, 0.5);   
  18.     colorwhite;   
  19.     text-aligncenter;   
  20.     line-height: 2em;   
  21. }   
  22. .front {   
  23.     transform: translateZ(1em);   
  24. }   
  25. .top {   
  26.     transform: rotateX(90deg) translateZ(1em);   
  27. }   
  28. .rightright {   
  29.     transform: rotateY(90deg) translateZ(1em);   
  30. }   
  31. .left {   
  32.     transform: rotateY(-90deg) translateZ(1em);   
  33. }   
  34. .bottombottom {   
  35.     transform: rotateX(-90deg) translateZ(1em);   
  36. }   
  37.   
  38. .back {   
  39.     transform: rotateY(-180deg) translateZ(1em);   
  40. }   
  41. .w1 {   
  42.     perspective: 100px;   
  43. }   
  44. .w2{   
  45.     perspective: 1000px;   
  46. }  

效果如下图所示:
详解CSS3的perspective属性设置3D变换距离的方法

依据上面的介绍,我们可对perspective取值做一个简单的结论:

 1.perspective取值为none或不设置,就没有真3D空间。
 2.perspective取值越小,3D效果就越明显,也就是你的眼睛越靠近真3D。
 3.perspective的值无穷大,或值为0时与取值为none效果一样。
为了更好的理解perspective属性,我们很有必要把他和translateZ的关系结合起来。其实也可以把perspective的值简单的理解为人的眼睛到显示器的距离,而translate就是3D物体距离源点的距离,下面引用W3C的一张图来解说perspective和translateZ的关系。
详解CSS3的perspective属性设置3D变换距离的方法

上图显示了perspective属性和translateZ的位置比例。要顶部的图,Z是半个d,为了使用原始圆(轮廓)看起来出现在Z轴上(虚线圆),画布上的实体圆将扩大两部,如浅蓝色的圆。在底部图中显示,圆按比例缩小,致使虚线圆出现在画布后面,并且z的大小是距原始位置三分之一。

在3D变形中,除了perspective属性可以激活一个3D空间之外,在3D变形的函数中的perspective()也可以激活3D空间。他们不同的地方是:perspective用在舞台元素上(变形元素们的共同父元素);perspective()就是用在当前变形元素上,并且可以与其他的transform函数一起使用。例如,我们可以把:

CSS Code复制内容到剪贴板
  1. .stage {   
  2.     perspective: 600px  
  3. }  

写成:

CSS Code复制内容到剪贴板
  1. .stage .box {   
  2.     transform: perspective(600px);   
  3. }  

来看一个简单示例:

HTML

XML/HTML Code复制内容到剪贴板
  1. <div class="stage">  
  2.     <div class="container">  
  3.         <img src="images/cardKingClub.png" alt="" width="142" height="200" />  
  4.     </div>  
  5. </div>  
  6. <div class="stage">  
  7.     <div class="container">  
  8.         <img src="images/cardKingClub.png" alt="" width="142" height="200" />  
  9.     </div>  
  10. </div>  

CSS

CSS Code复制内容到剪贴板
  1. .stage {   
  2.     width500px;   
  3.     height300px;   
  4.     margin30px auto;   
  5.     positionrelative;   
  6.     backgroundurl(images/bg-grid.jpg) no-repeat center center;   
  7.     background-size: 100% 100%;   
  8. }   
  9. .container {   
  10.     positionabsolute;   
  11.     top: 50%;   
  12.     left: 50%;   
  13.     width142px;   
  14.     height200px;   
  15.     border1px dotted orange;   
  16.     margin-left: -71px;   
  17.     margin-top: -100px;    
  18. }   
  19. .container img{   
  20.     transform: rotateY(45deg);   
  21. }   
  22. .stage:nth-child(1) .container{   
  23.     perspective: 600px;   
  24. }   
  25. .stage:nth-child(2) img {   
  26.     transform:perspective(600px) rotateY(45deg);   
  27. }  

效果如下所示:
详解CSS3的perspective属性设置3D变换距离的方法

上图效果可以看出,虽然书写的形式,属性名称不一致,但是效果却一样。

虽然perspective属性和perspective()函数所起的功能是一样的,但其取值以及以运用的对像有所不同:

1. perspective属性可以取值为none或长度值;而perspective()函数取值只能大于0,如果取值为0或比0小的值,将无法激活3D空间;
2.perspective属性用于变形对像父元素;而perspective()函数用于变形对像自身,并和transform其他函数一起使用。
 

perspective-origin属性

perspective-origin属性是3D变形中另一个重要属性,主要用来决定perspective属性的源点角度。它实际上设置了X轴和Y轴位置,在该位置观看者好像在观看该元素的子元素。

perspective-origin属性的使用语法也很简单:

复制代码
代码如下:
perspective-origin:[<percentage> | <length> | left | center | right | top | bottom] | [[<percentage> | <length> | left | center | right] && [<percentage> | <length> | top | center | bottom]]

该属性的默认值为“50% 50%”(也就是center),其也可以设置为一个值,也可以设置为两个长度值:

 第一个长度值指定相对于元素的包含框的X轴上的位置。它可以是长度值(以受支持的长度单位表示)、百分比或以下三个关键词之一:left(表示在包含框的X轴方向长度的0%),center(表示中间点),或right(表示长度的100%)。
 第二个长度值指定相对于元素的包含框的Y轴上的位置。它可以是长度值、百分比或以下三个关键词之一:top(表示在包含框的Y轴方向长度的0%),center(表示中间点),或bottom(表示长度的100%)。
注意,为了指转换子元素变形的深度,perspective-origin属性必须定义父元素上。通常perspective-origin属性本身不做任何事情,它必须被定义在设置了perspective属性的元素上。换句话说,perspective-origin属性需要与perspective属性结合起来使用,以便将视点移至元素的中心以外位置,如下图所示:
详解CSS3的perspective属性设置3D变换距离的方法

往往我们看一样东西不可能一直都在中心位置看,想换个角度,换个位置一看究竟,这个时候就离不开perspective-origin这个属性,下面来自于W3C官网的图可以简单阐述这一观点:
详解CSS3的perspective属性设置3D变换距离的方法

HTML / CSS 相关文章推荐
使用 css3 transform 属性来变换背景图的方法
May 07 HTML / CSS
各大浏览器 CSS3 和 HTML5 兼容速查表 图文
Apr 01 HTML / CSS
利用CSS3的transform做的动态时钟效果
Sep 21 HTML / CSS
一款纯css3实现的圆形旋转分享按钮旋转角度可自己调整
Sep 02 HTML / CSS
HTML5-WebSocket实现聊天室示例
Dec 15 HTML / CSS
HTML5实现Notification API桌面通知功能
Mar 02 HTML / CSS
html5应用缓存_动力节点Java学院整理
Jul 13 HTML / CSS
解决H5的a标签的download属性下载service上的文件出现跨域问题
Jul 16 HTML / CSS
Html5内唤醒百度、高德APP的实现示例
May 20 HTML / CSS
使用HTML5和CSS3制作一个模态框的示例
Mar 07 HTML / CSS
小程序瀑布流解决左右两边高度差距过大的问题
Feb 20 HTML / CSS
使用 CSS 轻松实现一些高频出现的奇形怪状按钮
Dec 06 HTML / CSS
CSS3中设置3D变形的transform-style属性详解
May 23 #HTML / CSS
css 元素选择器的简单实例
May 23 #HTML / CSS
css sprite简单实例
May 23 #HTML / CSS
CSS3中的Transition过度与Animation动画属性使用要点
May 20 #HTML / CSS
CSS3制作炫酷的下拉菜单及弹起式选单的实例分享
May 17 #HTML / CSS
CSS3中各种颜色属性的使用教程
May 17 #HTML / CSS
使用CSS3美化HTML表单的技巧演示
May 17 #HTML / CSS
You might like
PHP函数import_request_variables()用法分析
2016/04/02 PHP
基于JQuery的密码强度验证代码
2010/03/01 Javascript
Web开发者必备的12款超赞jQuery插件
2010/12/03 Javascript
基于jquery的jqDnR拖拽溢出的修改
2011/02/12 Javascript
jquery文字上下滚动的实现方法
2013/03/22 Javascript
jQuery实现图片放大预览实现原理及代码
2013/09/12 Javascript
给js文件传参数(详解)
2014/07/13 Javascript
Javascript 赋值机制详解
2014/11/23 Javascript
JS数组的常见用法实例
2015/02/10 Javascript
javascript实现加载xml文件的方法
2015/11/24 Javascript
基于javascript编写简单日历
2016/05/02 Javascript
URL的参数中有加号传值变为空格的问题(URL特殊字符)
2016/11/04 Javascript
微信小程序 中wx.chooseAddress(OBJECT)实例详解
2017/03/31 Javascript
浅谈Vue的加载顺序探讨
2017/10/25 Javascript
webpack热模块替换(HMR)/热更新的方法
2018/04/05 Javascript
VeeValidate 的使用场景以及配置详解
2019/01/11 Javascript
javascript系统时间设置操作示例
2019/06/17 Javascript
[05:37]DOTA2-DPC中国联赛 正赛 Elephant vs iG 选手采访
2021/03/11 DOTA
使用PyCharm配合部署Python的Django框架的配置纪实
2015/11/19 Python
Python使用爬虫猜密码
2016/02/19 Python
Python 的内置字符串方法小结
2016/03/15 Python
解决seaborn在pycharm中绘图不出图的问题
2018/05/24 Python
美国网上书店:Barnes & Noble
2018/08/15 全球购物
Wojas罗马尼亚网站:波兰皮鞋品牌
2018/11/01 全球购物
大专学生推荐信范文
2013/11/19 职场文书
园林技术个人的自我评价
2014/01/08 职场文书
新学期家长寄语
2014/01/19 职场文书
试用期员工考核制度
2014/01/22 职场文书
网络工程专业自荐信范文
2014/03/16 职场文书
小学一年级学生评语
2014/04/22 职场文书
勤奋学习演讲稿
2014/05/10 职场文书
优秀团员事迹材料1500字
2014/08/31 职场文书
缓刑人员思想汇报
2014/10/11 职场文书
2014年妇女工作总结
2014/12/06 职场文书
新手入门Mysql--概念
2021/06/18 MySQL
php 文件上传至OSS及删除远程阿里云OSS文件
2021/07/04 PHP