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中利用animation属性创建雪花飘落特效
May 14 HTML / CSS
css3中transition属性详解
Sep 02 HTML / CSS
浅析CSS3中鲜为人知的属性:-webkit-tap-highlight-color
Jan 12 HTML / CSS
关于HTML5的22个初级技巧(图文教程)
Jun 21 HTML / CSS
为你的html5网页添加音效示例
Apr 03 HTML / CSS
Html5 语法与规则简要概述
Jul 29 HTML / CSS
用html5绘制折线图的实例代码
Mar 25 HTML / CSS
浅谈HTML5 &amp; CSS3的新交互特性
Jul 19 HTML / CSS
CSS3 画基本图形,圆形、椭圆形、三角形等
Sep 20 HTML / CSS
CSS3 天气图标动画效果
Apr 06 HTML / CSS
css3新特性的应用示例分析
Mar 16 HTML / CSS
css实现左上角飘带效果的完整代码
Mar 18 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设计模式中单例模式的应用分析
2013/05/15 PHP
php file_get_contents取文件中数组元素的方法
2017/04/01 PHP
php实现对短信验证码发送次数的限制实例讲解
2021/03/04 PHP
取得窗口大小 兼容所有浏览器的js代码
2011/08/09 Javascript
浅谈javascript的原型继承
2012/07/25 Javascript
jquery的冒泡事件的阻止与允许(三种实现方法)
2013/02/01 Javascript
JSON+JavaScript处理JSON的简单例子
2013/03/20 Javascript
滚动条响应鼠标滑轮事件实现上下滚动的js代码
2014/06/30 Javascript
用js通过url传参把数据从一个页面传到另一个页面
2014/09/01 Javascript
JavaScript学习笔记之JS对象
2015/01/22 Javascript
javascript中Array数组的迭代方法实例分析
2015/02/04 Javascript
JavaScript中用toString()方法返回时间为字符串
2015/06/12 Javascript
jQuery对html元素的取值与赋值实例详解
2015/12/18 Javascript
数据结构中的各种排序方法小结(JS实现)
2016/07/23 Javascript
JS实现动态给标签控件添加事件的方法示例
2017/05/13 Javascript
封装运动框架实战左右与上下滑动的焦点轮播图(实例)
2017/10/17 Javascript
webpack打包并将文件加载到指定的位置方法
2018/02/22 Javascript
详解create-react-app 2.0版本如何启用装饰器语法
2018/10/23 Javascript
使用Vue 实现滑动验证码功能
2019/06/27 Javascript
SpringBoot在yml配置文件中配置druid的操作
2020/11/16 Javascript
js前端对于大量数据的展示方式及处理方法
2020/12/02 Javascript
[01:33]DOTA2上海特级锦标赛 LIQUID战队完整宣传片
2016/03/16 DOTA
python开发的小球完全弹性碰撞游戏代码
2013/10/15 Python
Python获取任意xml节点值的方法
2015/05/05 Python
Python使用multiprocessing实现一个最简单的分布式作业调度系统
2016/03/14 Python
Django应用程序中如何发送电子邮件详解
2017/02/04 Python
scrapy爬虫完整实例
2018/01/25 Python
python2.7无法使用pip的解决方法(安装easy_install)
2018/04/03 Python
Python将多个list合并为1个list的方法
2018/06/27 Python
Python tkinter三种布局实例详解
2020/01/06 Python
Python中无限循环需要什么条件
2020/05/27 Python
舞蹈教育学专业推荐信
2013/11/27 职场文书
法人授权委托书
2014/04/03 职场文书
大学生简短的自我评价
2014/09/12 职场文书
寒暑假实习证明书模板
2014/11/29 职场文书
红歌会主持词
2015/07/02 职场文书