CSS3实现3D旋转魔方

Published in Jan-29-2021


转自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;
   }


第二步:旋转各个面,变成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>







评论区