CSS进阶:试试酷炫的 3D 视角

2017 年 7 月 10 日 前端大全 伯乐在线

(点击上方公众号,可快速关注)


作者:伯乐在线/chokcoco

如有好文章投稿,请点击 → 这里了解详情


写这篇文章的缘由是因为看到了这个页面:


https://shakeduang.nuomi.com/campus/index.html?from=timeline&isappinstalled=1(移动端页面,使用模拟器观看)


运用 CSS3 完成的 3D 视角,虽然有一些晕3D,但是使人置身于其中的交互体验感觉非常棒,运用在移动端制作一些 H5 页面可谓十分博人眼球。


并且掌握原理之后制作起来也并不算废力,好好的研究了一番后将一些学习过程共享给大家。


下面进入正文:(一些 Gif 图片较大,需要等待一会)


3D 效果示意


百闻不如一见,先直观感受一下上述我所说的效果:



最好能点进去看看(http://codepen.io/Chokcoco/pen/mAyRGv),这里我使用了带背景色的 div 作为示例,我们的视角处于一个正方体中,正方体的旋转动画让我们有了 3D 的感觉。


那么原本的图长什么样呢?我们把距离拉远,一探究竟:


http://codepen.io/Chokcoco/pen/KgwqRd




是长这样的:



相较于第一种效果,其实所做的只是将我们的视角推进到了正方体当中,有了一种身临其景的感觉。


而合理的运用 CSS3 所提供的一些 3D 属性,很容易就能达到上述的效果。


制作这样一个 3D 图形,我在之前的文章已经很详细的讲述了过程,感兴趣的可以戳进去看看:


【CSS3进阶】酷炫的3D旋转透视


transform-style 与 perspective


再简单复述一下,主要是运用到了两个 CSS 属性:


transform-style


要利用 CSS3 实现 3D 的效果,最主要的就是借助 transform-style 属性。


transform-style 只有两个值可以选择:


// 语法:

transform-styleflat|preserve-3d;

transform-styleflat; // 默认,子元素将不保留其 3D 位置

transform-stylepreserve-3d; // 子元素将保留其 3D 位置。


当父元素设置了 transform-style:preserve-3d 后,就可以对子元素进行 3D 变形操作了,3D 变形和 2D 变形一样可以,使用 transform 属性来设置,或者可以通过制定的函数或者通过三维矩阵来对元素变型操作:当我们指定一个容器的 transform-style 的属性值为 preserve-3d 时,容器的后代元素便会具有 3D 效果,这样说有点抽象,也就是当前父容器设置了 preserve-3d 值后,它的子元素就可以相对于父元素所在的平面,进行 3D 变形操作。


  • 使用 translateX(length) 、translateY(length) 、 translateZ(length) 来进行 3D 位移操作,与 2D 操作一样,对元素进行位移操作,也可以合并为 translate3d(x,y,z) 这种写法;

  • 使用 scaleX() 、scaleY() 、scaleY() 来进行3D 缩放操作,也可以合并为 scale3d(number,number,number) 这种写法;

  • 使用 rotateX(angle) 、rotateY(angle) 、rotateZ(angle) 来进行 3D 旋转操作,也可以合并为 rotate3d(Xangle,Yangle,Zangle) 这种写法。


perspective


// 语法

perspectivenumber|none;


简单来说,当元素没有设置 perspective 时,也就是当 perspective:none/0 时所有后代元素被压缩在同一个二维平面上,不存在景深的效果。perspective 为一个元素设置三维透视的距离,仅作用于元素的后代,而不是其元素本身。


而如果设置 perspective 后,将会看到三维的效果。


我们上面之所以能够在正方体外围看到正方体,以及深入正方体内,都是因为 perspective 这个属性。它让我们能够选择推进视角,还是远离视角,因此便有了 3D 的感觉。


3D View页面的布局结构


为了完成这样一个效果,需要一个灵活的布局,去控制整个 3D 效果的展示。


下面是我觉得比较好的一种方式:


<!-- 最外层容器,控制图形的位置及在整个页面上的布局-->

<div class="container">

    <!-- 舞台层,设置 preserve-3d 与 perspective 视距  -->

    <div class="stage">

        <!-- 控制层,动画的控制层,通过这一层可以添加旋转动画或者触摸动画 -->

        <div class="control">

            <!-- 图片层,装入我们要拼接的图片 -->

            <div class="imgWrap">

                <div class="img img1"></div>

                <div class="img img2"></div>

                <div class="img img3"></div>

                <div class="img img4"></div>

            </div>

        </div>

    </div>

</div>


  • 最外层 container ,控制图形的位置及在整个页面上的布局;

  • stage 层,舞台层,从这里开始设置 3D 景深效果,添加 perspective 视距;

  • control 层,动画的控制层,通过这一层可以添加旋转动画或者在移动端的触摸动画,通过更改translateZ 属性也可以拉近拉远视角;

  • imgWrap 层,图片层,装入我们要拼接的图片,下文会提及。


图片拼接


图片拼接其实才是个技术活,需要许多的计算。


以上述 Demo 中的正方体为例子,class 为 img 的 div 块的高宽为 400px*400px。那么要利用 4 个 这样的 div 拼接成一个正方体,需要分别将 4 个 div 绕 Y 轴旋转 [90°, 180°, 270°, 360°],再 translateY(200px) 。


值得注意的是,一定是先旋转角度,再偏移距离,这个顺序很重要。


看看俯视图,也就是这个意思:



这是最简单的情况了,都是直角。


如果是一张图需要分割成八份,假设每张图分割出来的高宽为 400 400 , 8 张图需要做的操作是依次绕 Y 轴旋转 [45°, 90°, 135°, 180°, 225°, 270°, 315°, 360°] ,偏移的距离为 translateY(482.84px) ,也就是 (200 + 200√2)。


看看俯视图:



效果图(http://codepen.io/Chokcoco/pen/WGbERo):




图片分割


上面的示例都是使用的带背景色的 div 块,现在我们选取一张真正的图片,将其拼接成一个柱体。


下面这张图,大小为 3480px * 2000px :



我们把它分割为 20 份,拼成一个正 20 边形,当然不用一块一块切图下来,利用 background-position 就可以完成了。而且分割的份数越多,最终做出来的效果越像一个圆柱,效果也更加真实。


正 20 边形,需要 20 个 div ,假设容器是 .img-bg1 ~ .img-bg20 ,那么每块图片的宽度为 174px,依次需要递增的角度为 18° ,并且我们需要计算出需要偏移的距离为 translateZ(543px)。


可以利用一些 CSS 预处理器处理这段代码,下面是 Sass 的写法:


// Sass 的写法

$imgCount : 20 !default;

@ for $i from 1 through $imgCount {

.img-bg#{$i}{

background-position:($i * -174px + 174px) 0;

transformrotateY($i * 18deg) translateZ(543px);

}

}


看看效果: Demo(http://sbco.cc/demo/3dview/html/3dView2.html)



可以看到,图中近视为一个圆柱形,不过有一些小问题:


  • 选取的图片必须是左右首尾相连的的,不然圆柱结合处会有明显的不协调,这就要求要使用这种方式制作 H5 页面的时候,美术出的设计图必须左右相连无违和感。

  • 另外一点就是分割的块术,图片分割越多块,越近视为为一个圆柱,效果更佳。


控制 control 层,进入到圆柱画面内


做到这一步,只剩下最后一步,就是推进我们的视角,进入到圆柱内部,产生 3D 视图的感觉。


我们通过 class 为 control 这个 div 控制这个效果,不过这里控制我们进入圆柱

内部的属性不是调整修改 perspective 属性,而是调整 translateZ 属性。通过控制 translateZ 得到的画面更加真实,可以自己尝试一下分别控制 perspective 与 translateZ 得到的效果,便会有深刻的感受。


最后的效果: Demo(http://sbco.cc/demo/3dview/html/index.html),由于是移动端效果,打开模拟器观看更佳


整个效果图太大,只截取了部分制作成 GIF:



还有一个小问题,那就是进入到圆柱内部之后,整个图片都反了过来,所以我们可能需要利用PS将原图进行一次左右翻转,这样进入内部之后,看到的就是原图效果。


至此,整个页面就算完工了,接下来的就是添加一些 touch 事件,增添一些细节。可能写的过程中遗漏了一些细节,有什么很难一下理解过来的地方可以在评论留言。


本文示例 Demo 已上传在我的 Github 上:


Css33DView(https://github.com/chokcoco/Css33DView)


到此本文结束,如果还有什么疑问或者建议,可以多多交流,原创文章,文笔有限,才疏学浅,文中若有不正之处,万望告知。



觉得本文对你有帮助?请分享给更多人

关注「前端大全」,提升前端技能

登录查看更多
0

相关内容

3D是英文“Three Dimensions”的简称,中文是指三维、三个维度、三个坐标,即有长、有宽、有高,换句话说,就是立体的,是相对于只有长和宽的平面(2D)而言。
【实用书】Python机器学习Scikit-Learn应用指南,247页pdf
专知会员服务
267+阅读 · 2020年6月10日
【干货书】R语言书: 编程和统计的第一课程,
专知会员服务
115+阅读 · 2020年5月9日
【北京大学】CVPR 2020 | PQ-NET:序列化的三维形状生成网络
【经典书】Python计算机视觉编程,中文版,363页pdf
专知会员服务
140+阅读 · 2020年2月16日
姿势服装随心换-CVPR2019
专知会员服务
36+阅读 · 2020年1月26日
【书籍】深度学习框架:PyTorch入门与实践(附代码)
专知会员服务
165+阅读 · 2019年10月28日
初学者的 Keras:实现卷积神经网络
Python程序员
24+阅读 · 2019年9月8日
那些酷炫的深度学习网络图怎么画出来的?
极市平台
28+阅读 · 2019年6月16日
7 款实用到哭的App,只说一遍
高效率工具搜罗
84+阅读 · 2019年4月30日
怎么画高大上的神经网络结构?试试这个!
Python | Jupyter导出PDF,自定义脚本告别G安装包
程序人生
7+阅读 · 2018年7月17日
实战 | 用Python做图像处理(二)
七月在线实验室
17+阅读 · 2018年5月25日
推荐一些适合小白练手的Python项目
数据挖掘入门与实战
6+阅读 · 2018年5月17日
如何上手深度学习中的图像领域?有这个资源库就够了
数据挖掘入门与实战
5+阅读 · 2018年4月13日
用Python制作3D动画
Python程序员
30+阅读 · 2018年1月17日
3D Deep Learning on Medical Images: A Review
Arxiv
12+阅读 · 2020年4月1日
Learning Implicit Fields for Generative Shape Modeling
Arxiv
10+阅读 · 2018年12月6日
Arxiv
4+阅读 · 2018年6月14日
Arxiv
5+阅读 · 2018年3月30日
Arxiv
10+阅读 · 2018年2月17日
VIP会员
相关VIP内容
【实用书】Python机器学习Scikit-Learn应用指南,247页pdf
专知会员服务
267+阅读 · 2020年6月10日
【干货书】R语言书: 编程和统计的第一课程,
专知会员服务
115+阅读 · 2020年5月9日
【北京大学】CVPR 2020 | PQ-NET:序列化的三维形状生成网络
【经典书】Python计算机视觉编程,中文版,363页pdf
专知会员服务
140+阅读 · 2020年2月16日
姿势服装随心换-CVPR2019
专知会员服务
36+阅读 · 2020年1月26日
【书籍】深度学习框架:PyTorch入门与实践(附代码)
专知会员服务
165+阅读 · 2019年10月28日
相关资讯
初学者的 Keras:实现卷积神经网络
Python程序员
24+阅读 · 2019年9月8日
那些酷炫的深度学习网络图怎么画出来的?
极市平台
28+阅读 · 2019年6月16日
7 款实用到哭的App,只说一遍
高效率工具搜罗
84+阅读 · 2019年4月30日
怎么画高大上的神经网络结构?试试这个!
Python | Jupyter导出PDF,自定义脚本告别G安装包
程序人生
7+阅读 · 2018年7月17日
实战 | 用Python做图像处理(二)
七月在线实验室
17+阅读 · 2018年5月25日
推荐一些适合小白练手的Python项目
数据挖掘入门与实战
6+阅读 · 2018年5月17日
如何上手深度学习中的图像领域?有这个资源库就够了
数据挖掘入门与实战
5+阅读 · 2018年4月13日
用Python制作3D动画
Python程序员
30+阅读 · 2018年1月17日
Top
微信扫码咨询专知VIP会员