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实现彩色进度条动画的示例
Oct 29 HTML / CSS
html5服务器推送_动力节点Java学院整理
Jul 12 HTML / CSS
使用HTML5 IndexDB存储图像和文件的示例
Nov 05 HTML / CSS
值得收藏的HTML5资源(学习html5的朋友可以收藏下)
Jul 20 HTML / CSS
整理的15个非常有用的 HTML5 开发教程和速查手册
Oct 18 HTML / CSS
用html5实现语音搜索框的方法
Mar 18 HTML / CSS
极简的HTML5模版
Jul 09 HTML / CSS
详解HTML5中rel属性的prefetch预加载功能使用
May 06 HTML / CSS
使用数据结构给女朋友写个Html5走迷宫游戏
Nov 26 HTML / CSS
HTML5 通过Vedio标签实现视频循环播放的示例代码
Aug 05 HTML / CSS
纯CSS实现酷炫的霓虹灯效果
Apr 13 HTML / CSS
clear 万能清除浮动(clearfix:after)
May 21 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生成静态页面详解
2006/12/05 PHP
使用php伪造referer的方法 利用referer防止图片盗链
2014/01/20 PHP
Codeigniter上传图片出现“You did not select a file to upload”错误解决办法
2014/06/12 PHP
PHP中单例模式与工厂模式详解
2017/02/17 PHP
jQuery 可以拖动的div实现代码 脚本之家修正版
2009/06/26 Javascript
原生js实现改变随意改变div属性style的名称和值的结果
2013/09/26 Javascript
JavaScript中的值类型详细介绍
2014/12/29 Javascript
jquery Validation表单验证使用详解
2020/09/12 Javascript
JavaScript获取客户端IP的方法(新方法)
2016/03/11 Javascript
AngularJS打开页面隐藏显示表达式用法示例
2016/12/25 Javascript
详解vue父子模版嵌套案例
2017/03/04 Javascript
字太多用...代替的方法(两种)
2017/03/15 Javascript
vue中axios处理http发送请求的示例(Post和get)
2017/10/13 Javascript
Echarts之悬浮框中的数据排序问题
2018/11/08 Javascript
js中怎么判断两个字符串相等的实例
2019/01/17 Javascript
简单了解JavaScript作用域
2020/07/31 Javascript
[01:32:50]DOTA2-DPC中国联赛 正赛 DLG vs XG BO3 第一场 1月25日
2021/03/11 DOTA
Python的“二维”字典 (two-dimension dictionary)定义与实现方法
2016/04/27 Python
python逆序打印各位数字的方法
2018/06/25 Python
Django实现支付宝付款和微信支付的示例代码
2018/07/25 Python
Django实现跨域请求过程详解
2019/07/25 Python
Python如何基于smtplib发不同格式的邮件
2019/12/30 Python
在python3.64中安装pyinstaller库的方法步骤
2020/06/02 Python
Python爬虫进阶之爬取某视频并下载的实现
2020/12/08 Python
纯DOM+CSS3实现简单的小风车动画
2016/09/27 HTML / CSS
Origins悦木之源英国官网:雅诗兰黛集团高端植物护肤品牌
2017/11/06 全球购物
Onzie官网:美国时尚瑜伽品牌
2019/08/21 全球购物
JPA的优势都有哪些
2013/07/04 面试题
中秋节主持词
2014/04/02 职场文书
股东出资证明书(正规版)
2014/09/24 职场文书
班主任师德师风自我剖析材料
2014/10/02 职场文书
授权委托书协议书
2014/10/16 职场文书
前台接待岗位职责
2015/02/03 职场文书
交通事故协议书范本
2016/03/19 职场文书
创业计划书之便利店
2019/09/05 职场文书
MYSQL主从数据库同步备份配置的方法
2021/05/26 MySQL