「抖音最火」的3D旋转透视酷炫相册,如何用CSS3去实现
ann3311 2024-12-02 15:18 14 浏览 0 评论
前言
前段时间小编刷抖音的时候,刷到了咱们前端小伙伴制作的3D炫酷相册,居然那么火,细思一下,随着3D动画的普及,广泛的运作在各个平台,各官网都在实现3D页面。它可以更接近于真实的展示我们的产品和介绍,带来极强的视觉冲击感。所以说,为了让自己更加优秀,css3 3D动画必不可少。下面这篇文章,将带你初步了解CSS3实现酷炫的3D旋转透视
要想自己的网页能有3D特效,必须要会透视。
透视 perspective(基础问题,可以在我的推荐书籍中学习到)
- 在2D平面产生近大远小视觉立体,但是只是效果二维的
- 如果想在网页产生3D效果需要透视(理解成3D物体投影在2D平面内)。
- 模拟人类的视觉位置,可认为安排一只眼睛去看
- 透视我们也称为视距:视距就是人的眼睛到屏幕的距离
- 距离视觉点越近的在电脑平面成像越大,越远成像越小
- 透视的单位是像素
正文:
1.CSS3 3D 转换的常用API介绍
首先先上一张css 3D的坐标系:
接下来我们来介绍几个常用的api:
旋转
- rotateX()
- rotateY()
- rotateZ() 以上几个api分别代表绕x,y,z轴旋转,如下例子为绕x轴旋转的例子:
相关代码如下:
<style> .d3-wrap { position: relative; width: 300px; height: 300px; margin: 120px auto; /* 规定如何在 3D 空间中呈现被嵌套的元素 */ transform-style: preserve-3d; transform: rotateX(0) rotateY(45deg); transform-origin: 150px 150px 150px; } .rotateX { width: 200px; height: 200px; background-color: #06c; transition: transform 2s; animation: rotateX 6s infinite; } @keyframes rotateX { 0% { transform: rotateX(0); } 100% { transform: rotateX(360deg); } } </style> <div class="d3-wrap"> <div class="rotateX"></div> </div> 复制代码
位移(Transform)
- translateX(x) 定义 3D 转化,仅使用用于 X 轴的值
- translateY(y) 定义 3D 转化,仅使用用于 Y 轴的值
- translateZ(z) 定义 3D 转化,仅使用用于 Z 轴的值 以上几个api分别代表相对x,y,z轴的位移,如下例子为向z轴位移的例子:
这里我们需要注意的是为了能看出位移的效果,我们需要在父容器上加如下属性:
.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也很重要:
2.CSS3 3D 应用场景
css 3D主要应用在网站的交互和模型效果上,比如:
- 3D轮播图
- 3D产品介绍
- 室内3D仿真
- h5 3D活动页面,比较典型的就是某年淘宝的年终总结H5
- 3D数据可视化成图
- 3D模型图 其实如果css 3D用的熟悉了,一些基本的3D模型完全可以用css画出来。
3.CSS3 3D 实现一个立方体
核心思路就是用6个面去拼接,通过设置rotate和translate来调整相互之间的位置,如下:
具体代码如下:
.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结构
<div class="container"> <div class="page">A</div> <div class="page">B</div> <div class="page">C</div> <div class="page">D</div> <div class="page">E</div> <div class="page">F</div> </div>
扩展
我们可以基于上面介绍的,给父元素添加动画或者拖拽效果,这样就可以做成更有交互性的3D方块了,比如置骰子游戏,vr场景,3D相册等等,具体实现我会抽空依次总结出来,记得关注哦~
作者:徐小夕_Lab实验室
链接:https://juejin.im/post/5dd16b39f265da0bca78958e
喜欢小编的可以点个赞关注小编哦,小编每天都会给大家分享文章。
我自己是一名从事了多年的前端老程序员,小编为大家准备了新出的前端编程学习资料,免费分享给大家!
如果你也想学习前端,那么帮忙转发一下然后再关注小编后私信【1】可以得到我整理的这些前端资料了(私信方法:点击我头像进我主页有个上面有个私信按钮)
相关推荐
- 香港什么值得买&什么值得吃&索尼黑卡晒图(附真人秀)
-
作者:vickining从去年9月到今年4月一共去了香港三次共9天,基本都在油尖旺、铜锣湾和中环地区活动,离岛和迪斯尼海洋世界等都打算留在下次,澳门是单独去了两天(话说真心喜欢澳门这个小清新和纸醉金...
- 那些贵得“不要不要”,但妈妈们还是“要要要”的神器们
-
那些贵得“不要不要”,但妈妈们还是“要要要”的神器们上次分享了一篇咪宝的鞋,结果被值友们燃情批判——因为好多鞋不是“大牌”……唉,地主家也没有余粮啊!好吧,多谢大家对咪宝的关心^_^这次代表月亮满足你...
- 新消费观察丨电商公布2024年度十大商品 购物车里写满了“拒绝内耗”
-
封面新闻记者付文超12月23日,淘宝发布了2024年度十大商品,引发全网讨论。今年入选的商品分别是丑鱼拖鞋、太空船票、一级能效空调、无边抱枕、谷子、打工人立牌、蕉绿绿植、“不要脸”防晒服、数字卡券、...
- 淘宝热卖春晚明星同款,靠谱吗?(淘宝app春晚)
-
除夕夜,在央视春晚播出的同时,“李思思荧光口红”“马丽大衣”等成为网络热搜。记者发现,电商平台上不少商家蹭热点,以同款口红、同款大衣为推荐语来推广商品。有商家称,会根据网络热搜连夜上架“同款商品”,春...
- 淘宝“逢考必胜”战袍、旗袍热卖!还记得高考那天你穿了什么吗?
-
文|陈晨又到一年高考时,有关于高考和青春的记忆往往在这个时候泛滥。“高考前一晚,全班去操场跑圈,边唱歌边鼓舞打气,也许是玩的太嗨了,那年我们班考的特别差,但我现在回想起来高考印象最深的还是那个画面。”...
- 淘宝:2024 年度十大商品公布 热门盘点
-
【淘宝公布2024年度十大商品】12月23日,淘宝正式揭晓2024年度十大商品榜单。奥运期间全红婵带火的丑鱼拖鞋、双11淘宝直播间预售的国内首张低轨道旅行“太空船票”等商品上榜。因政...
- 《哪吒2》周边线上热销 天猫潮玩负责人称还能至少再火爆1个月
-
新京报贝壳财经讯(记者程子姣)由导演饺子历时5年打磨的《哪吒之魔童闹海》(下称《哪吒2》)无疑是今年开年最受观众喜爱的电影。2月8日,新京报贝壳财经记者从淘宝了解到,目前平台上由饺子创作的哪吒系列形象...
- 淘宝公布2024年度十大商品 黑神话悟空概念商品等上榜
-
12月23日,淘宝发布了2024年度十大商品。今年入选的商品分别是丑鱼拖鞋、太空船票、一级能效空调、无边抱枕、谷子、打工人立牌、蕉绿绿植、防晒服、数字卡券、黑神话悟空概念商品。全红婵脚蹬丑鱼拖鞋出现在...
- 东方甄选终于“入淘”:8月29日开播,俞敏洪带队
-
“脱抖”风波后,东方甄选宣布入驻淘宝直播。8月24日,记者从东方甄选获悉,淘宝首秀时间定为8月29日,新东方创始人俞敏洪、东方甄选CEO东方小孙带队,东方甄选众多主播将在淘宝开启全天直播。这也是该团队...
- 劲爆!2023年个人/个体户也可以入驻京东主站开店了!
-
据悉,2023年1月1日起,京东将接受个人/个体工商户入驻开店,大部分类目将对个人卖家开放!...
- 天猫上开设专卖店,那么下面是一些入驻资料可能需要准备的:
-
如果你想让你的品牌或店铺在天猫上开设专卖店,那么下面是一些入驻资料可能需要准备的:1.营业执照:作为一个企业或个体经营者,在向天猫申请开店之前,你需要拥有一份有效的营业执照。2.经营许可证:除了营...
- 安装师傅怎么实现入驻天猫商城(天猫安装店怎么入驻)
-
在日常生活中我们会在天猫购买一些大型商品如桌椅空调家电方面的商品,但这些大家居类目是需要有安装师傅的,可大家不知道天猫安装师傅怎么入驻?那么接下来,我们就来给大家讲解一下这方面的内容。...
- 双十二来临,接到这类电话千万要注意,杭州有人刚刚被骗近万元
-
钱江晚报·小时新闻记者边程壹通讯员符栩潇年底购物高峰一波接着一波,“双十二”又要到了。大家在买买买的同时,接到此类客服电话一定要多留个心眼。不管是“退货返钱”、“退货理赔”还是“快递丢失要赔款”...
- 去旅游,淘宝可以淘出什么好物?双十二网购推荐篇
-
收拾行李时,别忘了带上这些旅游好物!淘宝下单买买买!爱了爱了!【境外电话卡、流量卡】出境旅游的小伙伴必备品。比开通漫游优惠多呢。【电源转换器】各国及地区电力环境不同,电器的电压适用范围也不同,出境小伙...
- 双十二买什么?淘宝热搜榜刮起科技风
-
双十一才过去一个月,双十二又打着“买买买”的旗号兵临城下。刚在上月的一役中耗尽心力,双十二都不知道买什么好了?淘宝可从来没让你操心这种事,在1212前夕,淘宝发布了一份1212万能榜单,当中包含了一系...
你 发表评论:
欢迎- 一周热门
- 最近发表
- 标签列表
-
- 淘宝店铺优惠券怎么用 (36)
- 淘宝图片上传 (53)
- 购买天猫专卖店 (31)
- 淘宝搭配套餐怎么弄 (31)
- 淘宝试用什么意思 (39)
- 淘宝动态评分 (34)
- 淘宝保证金在哪里交 (32)
- 淘宝宝贝降权 (32)
- 淘宝恶意点击 (32)
- 淘宝查号 (31)
- 淘宝系统异常 (31)
- 天猫平台 (33)
- 淘宝信誉等级划分 (31)
- 天猫网店开店费用 (32)
- 淘宝假一赔三申请 (37)
- 淘宝会员打折 (35)
- 淘宝好评率 (32)
- 淘宝如何加入购物车 (33)
- 淘宝涨价 (35)
- 淘宝如何刷信誉 (32)
- 天猫直播入口 (34)
- 淘宝上架 (33)
- 淘宝帐号 (33)
- 淘宝不能发货 (33)
- 淘宝排名查询 (32)