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实例分享--超炫checkbox复选框和radio单选框
Sep 01 HTML / CSS
CSS3中Animation属性的使用详解
Aug 06 HTML / CSS
CSS3弹性盒模型开发笔记(二)
Apr 26 HTML / CSS
CSS超出文本指定宽度用省略号代替和文本不换行
May 05 HTML / CSS
CSS3实现多重边框的方法总结
May 31 HTML / CSS
Css3新特性应用之形状总结
Dec 08 HTML / CSS
详解css position 5种不同的值的用法
Jul 30 HTML / CSS
详解利用css3的var()实现运行时改变scss的变量值
Mar 02 HTML / CSS
html5 学习简单的拾色器
Sep 03 HTML / CSS
使用HTML5拍照示例代码
Aug 06 HTML / CSS
基于html5 canvas做批改作业的小插件
May 20 HTML / CSS
HTML页面点击按钮关闭页面的多种方式
Dec 24 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获取文件夹大小函数用法实例
2015/07/01 PHP
js类中的公有变量和私有变量
2008/07/24 Javascript
JavaScript中清空数组的三种方法分享
2011/04/07 Javascript
编写针对IE的JS代码两种编写方法
2013/01/30 Javascript
jquery的ajaxSubmit()异步上传图片并保存表单数据演示代码
2013/06/04 Javascript
JS代码判断IE6,IE7,IE8,IE9的函数代码
2013/08/02 Javascript
angularjs的一些优化小技巧
2014/12/06 Javascript
jQuery实现跨域
2015/02/03 Javascript
javascript显式类型转换实例分析
2015/04/25 Javascript
JavaScript验证Email(3种方法)
2015/09/21 Javascript
AngularJS中监视Scope变量以及外部调用Scope方法
2016/01/23 Javascript
js仿淘宝和百度文库的评分功能
2016/05/15 Javascript
原生JS实现垂直手风琴效果
2017/02/19 Javascript
通过vue提供的keep-alive减少对服务器的请求次数
2018/04/01 Javascript
vue工程全局设置ajax的等待动效的方法
2019/02/22 Javascript
create-react-app使用antd按需加载的样式无效问题的解决
2019/02/26 Javascript
[02:33]DOTA2英雄基础教程 司夜刺客
2013/12/04 DOTA
详解python开发环境搭建
2016/12/16 Python
python实现稀疏矩阵示例代码
2017/06/09 Python
python 数据的清理行为实例详解
2017/07/12 Python
一篇文章快速了解Python的GIL
2018/01/12 Python
python批量实现Word文件转换为PDF文件
2018/03/15 Python
python基于FTP实现文件传输相关功能代码实例
2019/09/28 Python
python垃圾回收机制(GC)原理解析
2019/12/30 Python
世界上最大的在线汽车租赁预订平台:Rentalcars.com(支持中文)
2018/10/12 全球购物
求职信范文怎么写
2014/01/29 职场文书
主持词开场白
2014/03/17 职场文书
我爱读书演讲稿
2014/05/07 职场文书
施工安全承诺书
2014/05/22 职场文书
小学数学教研活动总结
2014/07/01 职场文书
渠道运营商合作协议书范本
2014/10/06 职场文书
学生党员检讨书范文
2014/12/27 职场文书
客户答谢会致辞
2015/01/20 职场文书
建筑工程材料员岗位职责
2015/04/11 职场文书
《女娲补天》读后感5篇
2019/12/31 职场文书
IDEA 链接Mysql数据库并执行查询操作的完整代码
2021/05/20 MySQL