CSS3 三维变形实现立体方块特效源码


Posted in HTML / CSS onDecember 15, 2016

前言

三维变换使用基于二维变换的相同属性,如果您熟悉二维变换,你们发现3D变形的功能和2D变换的功能类似。3D变形与2D变形的最大不同就在于其参考的坐标轴不同,2D变形的坐标轴是平面的,只存在X轴和Y轴,而3D变形的坐标轴则是X、Y、Z三条轴组成的立体空间,X轴正向是朝右,Y周正向是朝下,Z轴正向是朝屏幕外。

静态效果图如下:

CSS3 三维变形实现立体方块特效源码

实例代码

<!DOCTYPE HTML>
<html>
    <head>
        <meta charset="utf-8">
        <meta name="apple-mobile-web-app-capable" content="yes" />
        <meta name="viewport" content="width=device-width, initial-scale=1.0, maximum-scale=1.0, user-scalable=0" />
        <title>CSS3三维变形</title>
        <!--  -->
        <style type="text/css">
         * {
          margin: 0;
          padding: 0;
         }
         
         .box {
          position:relative;
          top: 100px;
          width:300px;
          height: 300px;
          margin: 0 auto;
          background-color: #ccc;
          /*
           透视效果
           越大透视距离越平面,反之亦然
          */
          perspective:800px;
         }
         .content {
          /*3d视图*/
          transform-style: preserve-3d;
          /*过度动画*/
          transition: all 3s linear;
          width:200px;
          height: 200px;
          position: absolute;
          top: 50px;
       left: 50px;
         }
         /*
          经过顺时针旋转
         */
         .content:hover {
          transform: rotateX(180deg) rotateY(180deg);
         }
         /*
          方块公共样式
         */
         .side {
          position: absolute;
       height: 200px;
       width: 200px;
       border: 2px solid #000;
       background: rgba(0,0,0,0.3);
       color: #fff;
       line-height: 200px;
       font-size: 30px;
       font-weight: bold;
       text-align: center;
       text-shadow: 0 -1px 0 rgba(0,0,0,0.2);
         }
         /*
          前
         */
         .side1 {
           transform: translateZ(100px);
         }
         /*
          后
         */
         .side2 {
          transform: rotateX(180deg) translateZ(100px);
         } 
         /*
          左
         */
         .side3 {
          transform: rotateY(-90deg) translateZ(100px);
         }
         /*
          右
         */
         .side4 {
          transform: rotateY(90deg) translateZ(100px);
         }
         /*
          上
         */
         .side5 {
          transform: rotateX(90deg) translateZ(100px);
         }
         /*
          下
         */
         .side6 {
          transform: rotateX(-90deg) translateZ(100px);
         }
        </style>
    </head>
    <body>
     <!-- begin -->
     <div class="box">
      <div class="content">
       <div class="side side1">1</div>
             <div class="side side2">2</div>
             <div class="side side3">3</div>
             <div class="side side4">4</div>
             <div class="side side5">5</div>
             <div class="side side6">6</div>
      </div>
     </div>
     <!-- end -->
    </body>
</html>

总结

以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作能带来一定的帮助,如果有疑问大家可以留言交流。

HTML / CSS 相关文章推荐
详解CSS3阴影 box-shadow的使用和技巧总结
Dec 03 HTML / CSS
使用CSS3实现SVG路径描边动画效果入门教程
Oct 21 HTML / CSS
CSS3关于z-index不生效问题的解决
Feb 19 HTML / CSS
webapp字号大小跟随系统字号大小缩放的示例代码
Dec 26 HTML / CSS
Html5实现iPhone开机界面示例代码
Jun 30 HTML / CSS
HTML5 Canvas入门学习教程
Mar 17 HTML / CSS
Html5 web本地存储实例详解
Jul 28 HTML / CSS
使用canvas来完成线性渐变和径向渐变的功能的方法示例
Jul 25 HTML / CSS
跨域修改iframe页面内容详解
Oct 31 HTML / CSS
HTML5去掉输入框type为number时的上下箭头的实现方法
Jan 03 HTML / CSS
Html5定位终极解决方案
Feb 05 HTML / CSS
html+css实现赛博朋克风格按钮
May 26 HTML / CSS
css3学习之2D转换功能详解
Dec 23 #HTML / CSS
CSS实现鼠标滑过鼠标点击代码写法
Dec 26 #HTML / CSS
学做Bootstrap的第一个页面
May 15 #HTML / CSS
css3实现背景模糊的三种方式
HTML5如何适配 iPhone IOS 底部黑条
CSS3画一个阴阳八卦图
CSS中一些@规则的用法小结
Mar 09 #HTML / CSS
You might like
PHP远程连接MYSQL数据库非常慢的解决方法
2008/07/05 PHP
有关php运算符的知识大全
2011/11/03 PHP
javascript阻止scroll事件多次执行的思路及实现
2013/11/08 Javascript
bootstrap和jQuery.Gantt的css冲突 如何解决
2016/05/29 Javascript
激动人心的 Angular HttpClient的源码解析
2017/07/10 Javascript
详解vue-cli项目中用json-sever搭建mock服务器
2017/11/02 Javascript
使用vue引入maptalks地图及聚合效果的实现
2020/08/10 Javascript
通过实例解析javascript Date对象属性及方法
2020/11/04 Javascript
Python采用raw_input读取输入值的方法
2014/08/18 Python
Python实现基于TCP UDP协议的IPv4 IPv6模式客户端和服务端功能示例
2018/03/22 Python
python实现txt文件格式转换为arff格式
2018/05/31 Python
用Python编写一个简单的CS架构后门的方法
2018/11/20 Python
python日志logging模块使用方法分析
2019/05/23 Python
Python 实现OpenCV格式和PIL.Image格式互转
2020/01/09 Python
用Python做一个久坐提醒小助手的示例代码
2020/02/10 Python
tensorflow多维张量计算实例
2020/02/11 Python
python输出pdf文档的实例
2020/02/13 Python
python实现简单颜色识别程序
2020/02/19 Python
pytorch随机采样操作SubsetRandomSampler()
2020/07/07 Python
Opencv常见图像格式Data Type及代码实例
2020/11/02 Python
使用CSS3的::selection改变选中文本颜色的方法
2015/09/29 HTML / CSS
英国最受欢迎的价格比较网站之一:MoneySuperMarket
2018/12/19 全球购物
有趣、实用和鼓舞人心的产品:Inspire Uplift
2019/11/05 全球购物
几个判断型的面试题
2012/07/03 面试题
专升本自我鉴定
2013/10/10 职场文书
高三自我评价
2014/02/01 职场文书
《美丽的公鸡》教学反思
2014/02/25 职场文书
2014年师德承诺书
2014/05/23 职场文书
教师党员个人剖析材料
2014/09/29 职场文书
2016反腐倡廉警示教育心得体会
2016/01/13 职场文书
2019年思想汇报
2019/06/20 职场文书
公司员工违法违章行为检讨书
2019/06/24 职场文书
话题作文之呼唤
2019/12/18 职场文书
用Python远程登陆服务器的步骤
2021/04/16 Python
JS实现扫雷项目总结
2021/05/19 Javascript
mysql中between的边界,范围说明
2021/06/08 MySQL