前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >【全网最全的博客美化系列教程】19.旋转立方体的实现

【全网最全的博客美化系列教程】19.旋转立方体的实现

作者头像
Angel_Kitty
发布2020-02-17 09:47:22
8450
发布2020-02-17 09:47:22
举报
文章被收录于专栏:小樱的经验随笔

全网最全的博客美化系列教程相关文章目录

【全网最全的博客美化系列教程】01.添加Github项目链接

【全网最全的博客美化系列教程】02.添加QQ交谈链接

【全网最全的博客美化系列教程】03.给博客添加一只萌萌哒的小仓鼠

【全网最全的博客美化系列教程】04.访客量统计的实现

【全网最全的博客美化系列教程】05.公告栏个性时间显示的实现

【全网最全的博客美化系列教程】06.推荐和反对炫酷样式的实现

【全网最全的博客美化系列教程】07.添加一个分享的按钮吧

【全网最全的博客美化系列教程】08.自定义地址栏Logo

【全网最全的博客美化系列教程】09.添加"扩大/缩小浏览区域大小" 按钮

【全网最全的博客美化系列教程】10.小火箭置顶特效的实现

【全网最全的博客美化系列教程】11.鼠标点击爱心特效的实现

【全网最全的博客美化系列教程】12.修改鼠标图案

【全网最全的博客美化系列教程】13.鼠标点击效果升级的实现

【全网最全的博客美化系列教程】14.代码高亮设置的实现

【全网最全的博客美化系列教程】15.动画幻灯效果的实现

【全网最全的博客美化系列教程】16.给博客添加一个打赏的实现

【全网最全的博客美化系列教程】17.博客背景刷新切换效果的实现

【全网最全的博客美化系列教程】18.数学之美---动态几何线条的实现

【全网最全的博客美化系列教程】19.旋转立方体的实现

【全网最全的博客美化系列教程】20.给博客添加一个萌萌哒的看板娘

【全网最全的博客美化系列教程】21.给博客添加一个夜间模式吧

【全网最全的博客美化系列教程】22.添加一个文章目录特效

【全网最全的博客美化系列教程】23.图片水纹特效的实现

【全网最全的博客美化系列教程】24.给博客增加一个音乐播放器特效

【全网最全的博客美化系列教程】25.给博客增加一个音乐播放器特效

【全网最全的博客美化系列教程】26.评论头像旋转的实现

【全网最全的博客美化系列教程】27.IP地址定位及天气预报的实现

【全网最全的博客美化系列教程】28.3D标签云动画的实现

【全网最全的博客美化系列教程】29.自制HTML源码运行Javascript特效

【全网最全的博客美化系列教程】30.博客文章实现markdown书写机制

【全网最全的博客美化系列教程】31.用Canvas和requestAnimFrame做动画特效

【全网最全的博客美化系列教程】32.公告栏添加自己的头像

【全网最全的博客美化系列教程】33.添加一只舞动的小知音

【全网最全的博客美化系列教程】34.皮肤背景的选择与定制

实现过程

效果呈现如下:

很多人很好奇这个旋转立方体是怎么实现的,今天我们就来带大家一步步去实现我们的旋转立方体。

我们可以通过 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、然后让它旋转。

第一步,我们先给把正方体的六个面给定义一下:

代码语言:javascript
复制
/*最外层容器样式*/
.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):反转两个面形成正方体上下两个面

实现过程如下:

代码语言:javascript
复制
/*定义大正方体六个面旋转样式*/
.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,我们即可实现旋转功能。

最终完整实现代码如下:

代码语言:javascript
复制
<!DOCTYPE html>
<html>
<head>
   <meta charset="utf-8" />
   <style>
       /*最外层容器样式*/
       .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 .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 span {
           display: block;
           width: 100px;
           height: 100px;
           position: absolute;
           top: 50px;
           left: 50px;
      }

       .cube .in_pic {
           width: 100px;
           height: 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);
      }
   </style>
</head>
<body>
   <!-- 外层最大容器 -->
   <div class="wrap">
       <!--包裹所有元素的容器-->
       <div class="cube">
           <!--前面图片 -->
           <div class="out_front">
               <img src="https://i.loli.net/2018/05/03/5aeb0eef73838.jpg" class="pic" />
           </div>
           <!--后面图片 -->
           <div class="out_back">
               <img src="https://i.loli.net/2018/05/03/5aeb0f2fb9a83.jpg" class="pic" />
           </div>
           <!--左面图片 -->
           <div class="out_left">
               <img src="https://i.loli.net/2018/05/03/5aeb0f55411f0.jpg" class="pic" />
           </div>
           <!--右面图片 -->
           <div class="out_right">
               <img src="https://i.loli.net/2018/05/03/5aeb0f79a1124.jpg" class="pic" />
           </div>
           <!--上面图片 -->
           <div class="out_top">
               <img src="https://i.loli.net/2018/05/03/5aeb0f98a8b66.jpg" class="pic" />
           </div>
           <!--下面图片 -->
           <div class="out_bottom">
               <img src="https://i.loli.net/2018/05/03/5aeb0fdd51b7e.jpg" class="pic" />
           </div>

           <!--小正方体 -->
           <span class="in_front">
               <img src="https://i.loli.net/2018/05/03/5aeb100223dd0.jpg" class="in_pic" />
           </span>
           <span class="in_back">
                <img src="https://i.loli.net/2018/05/03/5aeb101c2c24b.jpg" class="in_pic" />
           </span>
           <span class="in_left">
               <img src="https://i.loli.net/2018/05/03/5aeb1038127b5.jpg" class="in_pic" />
           </span>
           <span class="in_right">
               <img src="https://i.loli.net/2018/05/03/5aeb0dce1ca55.jpg" class="in_pic" />
           </span>
           <span class="in_top">
               <img src="https://i.loli.net/2018/05/03/5aeb1057bb167.jpg" class="in_pic" />
           </span>
           <span class="in_bottom">
               <img src="https://i.loli.net/2018/05/03/5aeb107514579.jpg" class="in_pic" />
           </span>
       </div>
   </div>
</body>
</html>

添加方式:进入自己的博客园->设置,将以上html代码添加到“博客侧边栏公告”即可。

本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2020-02-07 ,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 全网最全的博客美化系列教程相关文章目录
  • 实现过程
相关产品与服务
图像处理
图像处理基于腾讯云深度学习等人工智能技术,提供综合性的图像优化处理服务,包括图像质量评估、图像清晰度增强、图像智能裁剪等。
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档