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的Media Queries(跨平台设计)
Jul 27 HTML / CSS
CSS3的Flexbox布局的简明入门指南
Apr 08 HTML / CSS
详解CSS3中nth-child与nth-of-type的区别
Jan 05 HTML / CSS
CSS3实现菜单悬停效果
Nov 17 HTML / CSS
HTML5移动开发图片压缩上传功能
Nov 09 HTML / CSS
html5+css3气泡组件的实现
Nov 21 HTML / CSS
HTML5 History API 实现无刷新跳转
Jan 11 HTML / CSS
详解HTML5 Canvas绘制不规则图形时的非零环绕原则
Mar 21 HTML / CSS
canvas之自定义头像功能实现代码示例
Sep 29 HTML / CSS
Html5之title吸顶功能
Jun 04 HTML / CSS
高清屏下canvas重置尺寸引发的问题的解决
Oct 14 HTML / CSS
关于html字符串正则判断和匹配的具体使用
Dec 12 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
三国漫画《火凤燎原》宣布动画化PV放出 预计2020年播出
2020/03/08 国漫
PHP 开发工具
2006/12/06 PHP
MySQL修改密码方法总结
2008/03/25 PHP
php反弹shell实现代码
2009/04/22 PHP
ThinkPHP3.2.2的插件控制器功能简述
2014/07/09 PHP
php中单个数据库字段多列显示(单字段分页、横向输出)
2014/07/28 PHP
基于PHP实现简单的随机抽奖小程序
2016/01/05 PHP
PHP实现的无限分类类库定义与用法示例【基于thinkPHP】
2018/08/06 PHP
新浪刚打开页面出来的全屏广告代码
2007/04/02 Javascript
Ext JS 4实现带week(星期)的日期选择控件(实战二)
2013/08/21 Javascript
Javascript农历与公历相互转换的简单实例
2016/10/09 Javascript
jQuery、layer实现弹出层的打开、关闭功能
2017/06/28 jQuery
微信小程序之页面跳转和参数传递的实现
2017/09/29 Javascript
js正则取值的结果数组调试方法
2018/10/10 Javascript
微信二次分享报错invalid signature问题及解决方法
2019/04/01 Javascript
微信小程序 WXML节点信息查询详解
2019/07/29 Javascript
Vue 中使用富文本编译器wangEditor3的方法
2019/09/26 Javascript
[57:12]完美世界DOTA2联赛循环赛 Inki vs Matador BO2第一场 10.31
2020/11/02 DOTA
Python实现爬取逐浪小说的方法
2015/07/07 Python
Python压缩解压缩zip文件及破解zip文件密码的方法
2015/11/04 Python
python类中super()和__init__()的区别
2016/10/18 Python
全面分析Python的优点和缺点
2018/02/07 Python
python cs架构实现简单文件传输
2020/03/20 Python
Python OpenCV实现鼠标画框效果
2020/08/19 Python
pytorch中的自定义数据处理详解
2020/01/06 Python
浅析两列自适应布局的3种思路
2016/05/03 HTML / CSS
高清安全摄像头系统:Lorex Technology
2018/07/20 全球购物
意大利在线购买隐形眼镜网站:VisionDirect.it
2019/03/18 全球购物
英国复古服装购物网站:Collectif
2019/10/30 全球购物
英国珠宝网站Argento: PANDORA、Olivia Burton和Nomination等
2020/05/08 全球购物
文化建设工作方案
2014/05/12 职场文书
学生不讲诚信检讨书
2014/09/29 职场文书
大学生学生会工作总结2015
2015/05/26 职场文书
我对PyTorch dataloader里的shuffle=True的理解
2021/05/20 Python
解决MySQL添加新用户-ERROR 1045 (28000)的问题
2022/03/03 MySQL
SQLServer权限之只开启创建表权限
2022/04/12 SQL Server