unity如何实现图片透视_「抖音最火」的3D旋转透视酷炫相册,如何用CSS3去实现...

前言

前段时间小编刷抖音的时候,刷到了咱们前端小伙伴制作的3D炫酷相册,居然那么火,细思一下,随着3D动画的普及,广泛的运作在各个平台,各官网都在实现3D页面。它可以更接近于真实的展示我们的产品和介绍,带来极强的视觉冲击感。所以说,为了让自己更加优秀,css3 3D动画必不可少。下面这篇文章,将带你初步了解CSS3实现酷炫的3D旋转透视

unity如何实现图片透视_「抖音最火」的3D旋转透视酷炫相册,如何用CSS3去实现..._第1张图片

要想自己的网页能有3D特效,必须要会透视。

透视 perspective(基础问题,可以在我的推荐书籍中学习到)

  • 在2D平面产生近大远小视觉立体,但是只是效果二维的
  • 如果想在网页产生3D效果需要透视(理解成3D物体投影在2D平面内)。
  • 模拟人类的视觉位置,可认为安排一只眼睛去看
  • 透视我们也称为视距:视距就是人的眼睛到屏幕的距离
  • 距离视觉点越近的在电脑平面成像越大,越远成像越小
  • 透视的单位是像素
unity如何实现图片透视_「抖音最火」的3D旋转透视酷炫相册,如何用CSS3去实现..._第2张图片

图片来源网络

正文:

CSS3 3D 转换的常用API介绍CSS3 3D 应用场景CSS3 3D 实现一个立方体

1.CSS3 3D 转换的常用API介绍

首先先上一张css 3D的坐标系:

unity如何实现图片透视_「抖音最火」的3D旋转透视酷炫相册,如何用CSS3去实现..._第3张图片

接下来我们来介绍几个常用的api:

旋转

  • rotateX()
  • rotateY()
  • rotateZ() 以上几个api分别代表绕x,y,z轴旋转,如下例子为绕x轴旋转的例子:
unity如何实现图片透视_「抖音最火」的3D旋转透视酷炫相册,如何用CSS3去实现..._第4张图片

相关代码如下:

位移(Transform)

  • translateX(x) 定义 3D 转化,仅使用用于 X 轴的值
  • translateY(y) 定义 3D 转化,仅使用用于 Y 轴的值
  • translateZ(z) 定义 3D 转化,仅使用用于 Z 轴的值 以上几个api分别代表相对x,y,z轴的位移,如下例子为向z轴位移的例子:
unity如何实现图片透视_「抖音最火」的3D旋转透视酷炫相册,如何用CSS3去实现..._第5张图片

这里我们需要注意的是为了能看出位移的效果,我们需要在父容器上加如下属性:

.d3-wrap { transform-style: preserve-3d; perspective: 500; /* 设置元素被查看位置的视图 */ -webkit-perspective: 500;}

当为元素定义 perspective 属性时,其子元素会获得透视效果,而不是元素本身。 代码如下:

.d3-wrap { position: relative; width: 300px; height: 300px; margin: 120px auto; transform-style: preserve-3d; perspective: 500; -webkit-perspective: 500; transform: rotateX(0) rotateY(45deg); transform-origin: center center;}.transformZ { width: 200px; height: 200px; background-color: #06c; transition: transform 2s; animation: transformZ 6s infinite;}@keyframes transformZ { 0% { transform: translateZ(100px); } 100% { transform: translateZ(0); } }

3D缩放

  • scaleX(x) 给定一个 X 轴的3D 缩放转换值
  • scaleY(x) 给定一个 Y 轴的3D 缩放转换值
  • scaleZ(x) 给定一个 Z 轴的3D 缩放转换值 缩放设置和上面的类似,这里就不做过多介绍了。

理论上说以上三种常见变换已经够用了,值得关注的是我们要想让元素呈现出3D效果,以下不可忽视的API也很重要:

unity如何实现图片透视_「抖音最火」的3D旋转透视酷炫相册,如何用CSS3去实现..._第6张图片

2.CSS3 3D 应用场景

css 3D主要应用在网站的交互和模型效果上,比如:

  • 3D轮播图
  • 3D产品介绍
  • 室内3D仿真
  • h5 3D活动页面,比较典型的就是某年淘宝的年终总结H5
  • 3D数据可视化成图
  • 3D模型图 其实如果css 3D用的熟悉了,一些基本的3D模型完全可以用css画出来。

3.CSS3 3D 实现一个立方体

unity如何实现图片透视_「抖音最火」的3D旋转透视酷炫相册,如何用CSS3去实现..._第7张图片

核心思路就是用6个面去拼接,通过设置rotate和translate来调整相互之间的位置,如下:

unity如何实现图片透视_「抖音最火」的3D旋转透视酷炫相册,如何用CSS3去实现..._第8张图片

具体代码如下:

.container { position: relative; width: 300px; height: 300px; margin: 120px auto; transform-style: preserve-3d; /* 为了让其更有立体效果 */ transform: rotateX(-30deg) rotateY(45deg); transform-origin: 150px 150px 150px; animation: rotate 6s infinite;}.container .page { position: absolute; width: 300px; height: 300px; text-align: center; line-height: 300px; color: #fff; background-size: cover;}.container .page:first-child { background-image: url(./my.jpeg); background-color: rgba(0,0,0,.2);}.container .page:nth-child(2) { transform: rotateX(90deg); transform-origin: 0 0; transition: transform 10s; background-color: rgba(179, 15, 64, 0.6); background-image: url(./my2.jpeg);}.container .page:nth-child(3) { transform: translateZ(300px); background-color: rgba(22, 160, 137, 0.7); background-image: url(./my3.jpeg);}.container .page:nth-child(4) { transform: rotateX(-90deg); transform-origin: -300px 300px; background-color: rgba(210, 212, 56, 0.2); background-image: url(./my4.jpeg);}.container .page:nth-child(5) { transform: rotateY(-90deg); transform-origin: 0 0; background-color: rgba(201, 23, 23, 0.6); background-image: url(./my5.jpeg);}.container .page:nth-child(6) { transform: rotateY(-90deg) translateZ(-300px); transform-origin: 0 300px; background-color: rgba(16, 149, 182, 0.2); background-image: url(./my6.jpeg);}

html结构

A
B
C
D
E
F

扩展

我们可以基于上面介绍的,给父元素添加动画或者拖拽效果,这样就可以做成更有交互性的3D方块了,比如置骰子游戏vr场景3D相册等等,具体实现我会抽空依次总结出来,记得关注哦~

unity如何实现图片透视_「抖音最火」的3D旋转透视酷炫相册,如何用CSS3去实现..._第9张图片

作者:徐小夕_Lab实验室
链接:https://juejin.im/post/5dd16b39f265da0bca78958e


喜欢小编的可以点个赞关注小编哦,小编每天都会给大家分享文章。

我自己是一名从事了多年的前端老程序员,小编为大家准备了新出的前端编程学习资料,免费分享给大家!

如果你也想学习前端,那么帮忙转发一下然后再关注小编后私信【1】可以得到我整理的这些前端资料了(私信方法:点击我头像进我主页有个上面有个私信按钮)

你可能感兴趣的:(unity如何实现图片透视)