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的transform做的动态时钟效果
Sep 21 HTML / CSS
利用CSS3参考手册和CSS3代码生成工具加速来学习网页制
Jul 11 HTML / CSS
一款基于css3和jquery实现的动画显示弹出层按钮教程
Jan 04 HTML / CSS
详解CSS3的图层阴影和文字阴影效果使用
Jun 09 HTML / CSS
CSS3 mask 遮罩的具体使用方法
Nov 03 HTML / CSS
CSS3 文字动画效果
Nov 12 HTML / CSS
HTML5仿手机微信聊天界面
Mar 18 HTML / CSS
html5之Canvas路径绘图、坐标变换应用实例
Dec 26 HTML / CSS
html5指南-1.html5全局属性(html5 global attributes)深入理解
Jan 07 HTML / CSS
整理HTML5中表单的常用属性及新属性
Feb 19 HTML / CSS
有关HTML5中背景音乐的自动播放功能
Oct 16 HTML / CSS
通过feDisplacementMap和feImage实现水波特效
Apr 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 iconv 解决utf-8和gb2312编码转换问题
2010/04/12 PHP
php模拟socket一次连接,多次发送数据的实现代码
2011/07/26 PHP
关于PHP session 存储方式的详细介绍
2013/06/25 PHP
php获取指定日期之间的各个周和月的起止时间
2014/11/24 PHP
Zend Framework入门应用实例详解
2016/12/11 PHP
PHP实现中国公民身份证号码有效性验证示例代码
2017/05/03 PHP
Laravel框架Auth用户认证操作实例分析
2019/09/29 PHP
Mootools 1.2教程 定时器和哈希简介
2009/09/15 Javascript
Javascript select下拉框操作常用方法
2009/11/09 Javascript
JavaScript制作的可折叠弹出式菜单示例
2014/04/04 Javascript
JavaScript运行机制之事件循环(Event Loop)详解
2014/10/10 Javascript
Bootstrap的图片轮播示例代码
2015/08/31 Javascript
js正则表达式验证邮件地址
2015/11/12 Javascript
javascript中select下拉框的用法总结
2016/01/07 Javascript
关于Bootstrap弹出框无法调用问题的解决办法
2016/03/10 Javascript
vue v-model表单控件绑定详解
2017/05/17 Javascript
使用Angular CLI从蓝本生成代码详解
2018/03/24 Javascript
vue 监听屏幕高度的实例
2018/09/05 Javascript
解决vue keep-alive 数据更新的问题
2018/09/21 Javascript
Vue组件通信的几种实现方法
2019/04/25 Javascript
使用Python脚本将绝对url替换为相对url的教程
2015/04/24 Python
python 实现红包随机生成算法的简单实例
2017/01/04 Python
python下载文件记录黑名单的实现代码
2017/10/24 Python
基于Python实现的微信好友数据分析
2018/02/26 Python
使用Django简单编写一个XSS平台的方法步骤
2019/03/25 Python
Python函数基础实例详解【函数嵌套,命名空间,函数对象,闭包函数等】
2019/03/30 Python
python把ipynb文件转换成pdf文件过程详解
2019/07/09 Python
python实现将视频按帧读取到自定义目录
2019/12/10 Python
如何使用 Flask 做一个评论系统
2020/11/27 Python
Tomcat Mysql datasource数据源配置
2015/12/28 面试题
董事长岗位职责
2013/11/30 职场文书
高三生物教学反思
2014/01/25 职场文书
学生干部培训方案
2014/06/12 职场文书
2015年女生节活动总结
2015/02/27 职场文书
离婚律师函范本
2015/05/27 职场文书
小孩不笨观后感
2015/06/03 职场文书