纯CSS3实现一个旋转的3D立方体盒子
2015-08-03 16:22
489 查看
简介
上网易前端微专业课程,里面有一个课外作业是实现一个3D旋转立方体,花了点时间做了下,还有点意思,写个简单教程,供大家学习。先放上最终要实现的效果
注:代码在chrome 43.0.2357.124 m正常,其他浏览器未测试
步骤
1.在二维平面上放置好各个面
大家小时候可能都玩过“叠盒子”,就是在一张纸上线画出一个盒子的展开图,然后裁剪叠出一个盒子,类似下图这样:看到这个应该有点思路了吧,我们这里也按这个思路把立方体各个面先在平面上摆好,然后通过旋转各个面,组成立方体。
效果见代码-1
上面的代码有一个地方略有不同,就是前和后是叠在一起的,这个可以这样理解,我们先把“前”这个面剪下来,放在”后“上面,最后叠盒子的时候,把”前“垂直屏幕向外移动出来,完成拼盒子。为什么要这么做?因为这样”前“面移动比较少,写的CSS3样式更少
2.在三维空间旋转面,组成立方体盒子
最关键的一步到了,通过CSS3属性实现各个面的旋转,这里给出一个”左“面和”前“面的核心代码:.left{ transform: rotateY(90deg); // 沿Y轴旋转90度 transform-origin: right; // 以矩形的右边框为Y轴 } .front{ transform: translateZ(150px); //沿垂直屏幕往外移动150px }
关于旋转移动的属性rotateX, rotateY, rotateZ,translateZ等,请参考张鑫旭的博文
以此类推,我们可以把各个面都旋转好,立方体盒子已经拼好了!最终效果见代码-2
哦,这里还有一行代码值得一提
.stage{ perspective: 800px; //翻译成景深或视距 }
有个网友做了一个很好的示例说明perspective的概念
3.添加立方体旋转动画
静态盒子完成之后,下一步就是添加旋转动画了,主要思路是让包括这个盒子的容器div转起来,盒子就跟着转了。下面是沿着Z轴转的一个示例代码@keyframes rotate-frame{ //定义动画关键帧 0%{ transform: rotateZ(0deg); } 100%{ transform: rotateZ(360deg); } } .container{ transform-style:preserve-3d; //容器内的元素随着容器一起转 animation: rotate-frame 3s infinite linear; //应用关键帧动画 }
效果见代码-3
4.加点料
这样转有点傻,最后改成先沿X轴转,在沿Y轴转,主要是关键帧设置的变化。@keyframes rotate-frame{ 0% { transform: rotateX(0deg); } 25% { transform: rotateX(180deg); } 50% { transform: rotateX(360deg) rotateY(0deg); } 75% { transform: rotateX(360deg) rotateY(180deg); } 100% { transform: rotateX(360deg) rotateY(360deg); } } .container{ transform-origin: 50% 50% 75px; //改变旋转参考的平面 }
最终效果代码-4
小结
通过这个例子能基本熟悉CSS3 transform相关的属性,做了一个小的立方体,不足之处请小伙伴们指正。不禁脑洞再开,能不能做一个3D的魔方,类似于现实中玩的魔方那样的,实现各面的旋转,甚至自动解魔方,貌似挺有意义的,有时间试试~
相关文章推荐
- CSS样式属性
- 元素定位方式 之-----CSS属性定位
- CSS3.0盒模型display:-webkit-box;的使用
- html和css学习心得
- 10个CSS简写/优化技巧
- CSS特殊性
- 15-07-26 HTML--样式基本概念、选择器、样式属性
- CSS小技巧
- CSS样式表基础知识、样式表的分类及选择器
- 兼容主流浏览器的CSS透明代码
- WPF 几种常用控件样式的总结
- CSS精粹之布局技巧
- 推荐大家使用的CSS书写规范
- CSS性能优化
- 基于CSS3动态背景登录框代码
- html+css布局的三种方式
- css3中变形与动画(三)
- 关于 隐藏元素(样式为 display: none 的元素)及其子元素 获取不到高度的问题
- CSS学习笔记
- CSS a链接的四种状态