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中的元素过渡属性transition示例详解
Nov 30 HTML / CSS
纯CSS3实现地球自转实现代码(图文教程附送源码)
Dec 26 HTML / CSS
CSS+jQuery实现的在线答题功能
Apr 25 HTML / CSS
利用html5 file api读取本地文件示例(如图片、PDF等)
Mar 07 HTML / CSS
关于HTML5你必须知道的28个新特性,新技巧以及新技术
May 28 HTML / CSS
HTML5之SVG 2D入门3—文本与图像及渲染文本介绍
Jan 30 HTML / CSS
html5教程实现Photoshop渐变色效果
Dec 04 HTML / CSS
处理HTML5新标签的浏览器兼容版问题
Mar 13 HTML / CSS
HTML5实现自带进度条和滑块滑杆效果
Apr 17 HTML / CSS
html5 canvas简单封装一个echarts实现不了的饼图
Jun 12 HTML / CSS
html5中嵌入视频自动播放的问题解决
May 25 HTML / CSS
CSS控制继承中的height能变为可继承吗
Jun 10 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
什么是短波收听SWL
2021/03/01 无线电
php随机显示图片的简单示例
2014/02/15 PHP
浅析PHP关键词替换的类(避免重复替换,保留与还原原始链接)
2015/09/22 PHP
PHP数组编码gbk与utf8互相转换的两种方法
2016/09/01 PHP
ThinkPHP框架实现的邮箱激活功能示例
2018/06/15 PHP
Laravel框架Eloquent ORM删除数据操作示例
2019/12/03 PHP
使javascript也能包含文件
2006/10/26 Javascript
JSON 学习之完全手册 图文
2007/05/29 Javascript
Javascript技巧之不要用for in语句对数组进行遍历
2010/10/20 Javascript
分享一个自己动手写的jQuery分页插件
2014/08/28 Javascript
js支持键盘控制的左右切换立体式图片轮播效果代码分享
2015/08/26 Javascript
AngularJS使用ngMessages进行表单验证
2015/12/27 Javascript
常见的javascript跨域通信方法
2015/12/31 Javascript
jQuery soColorPacker 网页拾色器
2016/06/22 Javascript
深入解析Javascript闭包的功能及实现方法
2016/07/10 Javascript
Bootstrap3下拉菜单的实现
2017/02/22 Javascript
设置cookie指定时间失效(实例代码)
2017/05/28 Javascript
js设置随机切换背景图片的简单实例
2017/11/12 Javascript
打通前后端构建一个Vue+Express的开发环境
2018/07/17 Javascript
angular中子控制器向父控制器传值的实例
2018/10/08 Javascript
JS块级作用域和私有变量实例分析
2019/05/11 Javascript
微信小程序scroll-view锚点链接滚动跳转功能
2019/12/12 Javascript
vue 移动端记录页面浏览位置的方法
2020/03/11 Javascript
Layer UI表格列日期格式化及取消自动填充日期的实现方法
2020/05/10 Javascript
以一个投票程序的实例来讲解Python的Django框架使用
2016/02/18 Python
Python连接MySQL并使用fetchall()方法过滤特殊字符
2016/03/13 Python
Python类中方法getitem和getattr详解
2019/08/30 Python
Python实现基于socket的udp传输与接收功能详解
2019/11/15 Python
Django model重写save方法及update踩坑详解
2020/07/27 Python
茵宝(Umbro)英国官方商店:英国足球服装生产商
2016/12/29 全球购物
应届护士推荐信
2013/11/16 职场文书
2014全国两会学习心得体会1000字
2014/03/10 职场文书
工会趣味活动方案
2014/08/18 职场文书
项目经理助理岗位职责
2015/04/13 职场文书
2015年工程部工作总结
2015/04/30 职场文书
Redis基本数据类型String常用操作命令
2022/06/01 Redis