我们可以通过 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;
}
第二步:旋转各个面,变成3D立方体
在这里,我们把它分为三个部分。
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);
}
第三步:通过旋转div
,实现旋转功能
<!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>
在相应的地方放置css
,可将3D旋转魔方放置在侧边栏。添加方式:进入自己的博客园->设置,将以上html代码添加到“博客侧边栏公告”即可。
END:效果演示3D旋转魔方
以下是使用到的图片:
好的,不客气,已剽
当然会添加来源的啦。
感谢大佬的分享~
感谢大佬