zoukankan      html  css  js  c++  java
  • 【全网最全的博客美化系列教程】19.旋转立方体的实现

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

    【全网最全的博客美化系列教程】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、然后让它旋转。

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

    /*最外层容器样式*/
    .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);
    }

    第三步,让它旋转起来。

    通过旋转div,我们即可实现旋转功能。

    最终完整实现代码如下:

    <!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代码添加到“博客侧边栏公告”即可。

  • 相关阅读:
    利用kettle中的JS来完成ETL数据校验
    spring cloud学习地址
    centos7 卸载 gitlab
    为什么WEB-INF外的jsp无法根据cookie享受国际化
    改变maven父子项目视图为树状
    maven profiles、filters、resources学习笔记 及 常用 plugin demo
    Tomcat 签名认证配置简例
    CentOS 开机启动
    Tomcat 关闭时报错
    比较全的log4j示例
  • 原文地址:https://www.cnblogs.com/ECJTUACM-873284962/p/12274087.html
Copyright © 2011-2022 走看看