转自Mlldxe Blog,通过 CSS 动画实现的立方体旋转,可以改变 CSS 代码中关键帧定义(@keyframes)来改变立方体的旋转方式。
我们可能会用到的标签属性如下:
标签 | 描述 |
---|---|
transform |
元素可以2D或3D转换 |
transform-style |
规定元素如何在 3D 空间中显示。 |
animation |
可以给元素设置动画 |
@keyframes 动画名 {from {}to {}} |
设置动画从开始到结束的 |
translateX(x) |
定义 3D 转化,仅使用用于 X 轴的值。 |
translateY(y) |
定义 3D 转化,仅使用用于 Y 轴的值。 |
translateZ(z) |
定义 3D 转化,仅使用用于 Z 轴的值。 |
translate3d(x,y,z) |
定义 3D 转化。 |
scaleX(x) |
定义 3D 缩放转换,通过给定一个 X 轴的值。 |
scaleY(y) |
定义 3D 缩放转换,通过给定一个 Y 轴的值。 |
scaleZ(z) |
定义 3D 缩放转换,通过给定一个 Z 轴的值。 |
rotateX(angle) |
定义沿 X 轴的 3D 旋转。 |
rotateY(angle) |
定义沿 Y 轴的 3D 旋转。 |
rotateZ(angle) |
定义沿 Z 轴的 3D 旋转。 |
rotate3d(x,y,z,angle) |
定义 3D 旋转。 |
1、先把正方体的六个面放在一起;
2、然后旋转各个面,让它形成一个立方体;
3、然后让它旋转。
第一步:定义正方体的六个面
/*最外层容器样式*/ .wrap{ width: 100px; height: 100px; margin: 150px; position: relative; } /*包裹所有容器样式*/ /*设置transform-style: preserve-3d,让其子元素在3D空间呈现*/ .cube{ width: 50px; height: 50px; margin: 0 auto; transform-style: preserve-3d; transform: rotateX(-30deg) rotateY(-80deg); animation: rotate linear 20s infinite; } @-webkit-keyframes rotate { from { transform: rotateX(0deg) rotateY(0deg); } to { transform: rotateX(360deg) rotateY(360deg); } } .cube div { position: absolute; width: 200px; height: 200px; opacity: 0.8; transition: all .4s; } /*定义所有图片样式*/ .pic { width: 200px; height: 200px; } /*定义小正方体样式*/ .cube span { display: block; width: 100px; height: 100px; position: absolute; top: 50px; left: 50px; } .cube .in_pic { width: 100px; height: 100px; }
在这里,我们把它分为三个部分。
1、translateZ:平移两个面形成正方体前后两个面
2、rotateX(90deg):反转两个面形成正方体左右两个面
3、rotateY(90deg):反转两个面形成正方体上下两个面
/*定义大正方体六个面旋转样式*/ .cube .out_front { transform: rotateY(0deg) translateZ(100px);} .cube .out_back { transform: translateZ(-100px) rotateY(180deg);} .cube .out_left { transform: rotateY(-90deg) translateZ(100px);} .cube .out_right { transform: rotateY(90deg) translateZ(100px);} .cube .out_top { transform: rotateX(90deg) translateZ(100px);} .cube .out_bottom { transform: rotateX(-90deg) translateZ(100px);} /*定义小正方体六个面旋转样式*/ .cube .in_front { transform: rotateY(0deg) translateZ(50px);} .cube .in_back { transform: translateZ(-50px) rotateY(180deg);} .cube .in_left { transform: rotateY(-90deg) translateZ(50px);} .cube .in_right { transform: rotateY(90deg) translateZ(50px);} .cube .in_top { transform: rotateX(90deg) translateZ(50px);} .cube .in_bottom { transform: rotateX(-90deg) translateZ(50px);} /*鼠标移入后样式*/ .cube:hover .out_front { transform: rotateY(0deg) translateZ(200px);} .cube:hover .out_back { transform: translateZ(-200px) rotateY(180deg);} .cube:hover .out_left { transform: rotateY(-90deg) translateZ(200px);} .cube:hover .out_right { transform: rotateY(90deg) translateZ(200px);} .cube:hover .out_top { transform: rotateX(90deg) translateZ(200px);} .cube:hover .out_bottom { transform: rotateX(-90deg) translateZ(200px);}
<!DOCTYPE html><html><head> <meta charset="utf-8" /> </head><body> <!-- 外层最大容器 --> <div class="wrap"> <!--包裹所有元素的容器--> <div class="cube"> <!--前面图片 --> <div class="out_front"> <img src="https://mlldxe.cn/wp-content/themes/kratos-pjax/magic_square/magic/magic_1.jpg" alt="" class="pic" /> </div> <!--后面图片 --> <div class="out_back"> <img src="https://mlldxe.cn/wp-content/themes/kratos-pjax/magic_square/magic/magic_2.jpg" alt="" class="pic" /> </div> <!--左面图片 --> <div class="out_left"> <img src="https://mlldxe.cn/wp-content/themes/kratos-pjax/magic_square/magic/magic_3.jpg" alt="" class="pic" /> </div> <!--右面图片 --> <div class="out_right"> <img src="https://mlldxe.cn/wp-content/themes/kratos-pjax/magic_square/magic/magic_4.jpg" alt="" class="pic" /> </div> <!--上面图片 --> <div class="out_top"> <img src="https://mlldxe.cn/wp-content/themes/kratos-pjax/magic_square/magic/magic_5.jpg" alt="" class="pic" /> </div> <!--下面图片 --> <div class="out_bottom"> <img src="https://mlldxe.cn/wp-content/themes/kratos-pjax/magic_square/magic/magic_6.jpg" alt="" class="pic" /> </div> <!--小正方体 --> <span class="in_front"> <img src="https://mlldxe.cn/wp-content/themes/kratos-pjax/magic_square/magic/magic_7.jpg" alt="" class="in_pic" /> </span> <span class="in_back"> <img src="https://mlldxe.cn/wp-content/themes/kratos-pjax/magic_square/magic/magic_8.jpg" alt="" class="in_pic" /> </span> <span class="in_left"> <img src="https://mlldxe.cn/wp-content/themes/kratos-pjax/magic_square/magic/magic_9.jpg" alt="" class="in_pic" /> </span> <span class="in_right"> <img src="https://mlldxe.cn/wp-content/themes/kratos-pjax/magic_square/magic/magic_10.jpg" alt="" class="in_pic" /> </span> <span class="in_top"> <img src="https://mlldxe.cn/wp-content/themes/kratos-pjax/magic_square/magic/magic_11.jpg" alt="" class="in_pic" /> </span> <span class="in_bottom"> <img src="https://mlldxe.cn/wp-content/themes/kratos-pjax/magic_square/magic/magic_12.jpg" alt="" class="in_pic" /> </span> </div> </div></body></html>
评论区