想要做出一个会旋转的立方体,首先第一步,将立方体的6个面画出来。
html部分:
data:image/s3,"s3://crabby-images/8ceae/8ceae21d68dc7d571d9bb908d865f5b678b04bd5" alt=""
css部分及效果图:
data:image/s3,"s3://crabby-images/0654d/0654db1dcef8575d7cd0d8a830a2cd7777b3284f" alt=""
之后将上下左右四个面收起来,用transform:rotate(90deg)或transform:rotate(-90deg),让左边的沿着左边那个面的右边旋转90度。主要添加了如下代码:
data:image/s3,"s3://crabby-images/9e5c0/9e5c076bc37840a9ca0cb1f96778e1b85ff39132" alt=""
data:image/s3,"s3://crabby-images/2c2bf/2c2bf46c5c9af1799302e7d704edc1e2fd67ac6e" alt=""
在之后设置当鼠标进入到wrap时,让box转动,主要添加了如下代码:
data:image/s3,"s3://crabby-images/0b877/0b877b321ebd7e5bbcf30cb7a6a3d618c76f86b7" alt=""
这样,立方体的旋转效果就完成了。
完整代码如下:
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<meta http-equiv="X-UA-Compatible" content="ie=edge">
<title>Document</title>
</head>
<style>
#wrap{
width: 400px;
height: 400px;
border: 1px solid;
-webkit-perspective: 200px;
transform-style: preserve-3d;
}
.box{
width: 100px;
height: 100px;
position: relative;
left: 150px;
top: 150px;
transform-style: preserve-3d;
transform-origin: center center -50px;
transition: 3s;
}
#wrap:hover .box{
transform: rotateX(360deg);
}
.box div{
width: 100px;
height: 100px;
background-color: pink;
position: absolute;
font: 50px/100px "微软雅黑";
text-align: center;
}
.box div:nth-child(1){
z-index: 1;
}
.box div:nth-child(2){
transform: translateZ(-100px);
}
.box div:nth-child(3){
left: -100px;
transform-origin: right;
transform: rotateY(-90deg);
}
.box div:nth-child(4){
right: -100px;
transform-origin: left;
transform: rotateY(90deg);
}
.box div:nth-child(5){
top: -100px;
transform-origin: bottom;
transform: rotateX(90deg);
}
.box div:nth-child(6){
bottom: -100px;
transform-origin: top;
transform: rotateX(-90deg);
}
</style>
<body>
<div id="wrap">
<div class="box">
<div>前</div>
<div>后</div>
<div>左</div>
<div>右</div>
<div>上</div>
<div>下</div>
</div>
</div>
</body>
</html>
如果想将效果改成下图的形式:做出一个透明旋转形式该如何改呢?
data:image/s3,"s3://crabby-images/b04df/b04df6aeb9a7759e38b9776e10cfc2184a4e42b3" alt=""
首先在原代码的基础上,做如下改动:
data:image/s3,"s3://crabby-images/d1f66/d1f662ab338ed9587963377d56323618ba60df1c" alt=""
所有代码如下:
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<meta http-equiv="X-UA-Compatible" content="ie=edge">
<title>Document</title>
</head>
<style>
#wrap{
width: 400px;
height: 400px;
border: 1px solid;
-webkit-perspective: 200px;
/* transform-style: preserve-3d; */
background-color: pink;
}
.box{
width: 100px;
height: 100px;
background-color: pink;
position: relative;
left: 150px;
top: 150px;
transform-style: preserve-3d;
transform-origin: center center -50px;
transition: 3s;
}
#wrap:hover .box{
transform: rotateX(360deg);
}
.box div{
width: 100px;
height: 100px;
background-color: rgba(123,321,333,.3);
position: absolute;
font: 50px/100px "微软雅黑";
text-align: center;
backface-visibility: hidden;
}
.box div:nth-child(1){
z-index: 1;
}
.box div:nth-child(2){
transform: translateZ(-100px);
}
.box div:nth-child(3){
left: -100px;
transform-origin: right;
transform: rotateY(-90deg);
}
.box div:nth-child(4){
right: -100px;
transform-origin: left;
transform: rotateY(90deg);
}
.box div:nth-child(5){
top: -100px;
transform-origin: bottom;
transform: rotateX(90deg);
}
.box div:nth-child(6){
bottom: -100px;
transform-origin: top;
transform: rotateX(-90deg);
}
</style>
<body>
<div id="wrap">
<div class="box">
<div>前</div>
<div>后</div>
<div>左</div>
<div>右</div>
<div>上</div>
<div>下</div>
</div>
</div>
</body>
</html>
如果觉得第一种做立方体的办法太麻烦,每个面都要旋转太麻烦,可以让每个面都沿着中心基点旋转:
data:image/s3,"s3://crabby-images/5deb9/5deb94570851c2075760235edcf240801cd8d604" alt=""
网友评论