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 box-shadow阴影(外阴影与外发光)图示讲解
Aug 11 HTML / CSS
CSS3教程(10):CSS3 HSL声明设置颜色
Apr 02 HTML / CSS
一款纯css3实现的圆形旋转分享按钮旋转角度可自己调整
Sep 02 HTML / CSS
css3 伪元素和伪类选择器详解
Sep 04 HTML / CSS
使用CSS3来实现滚动视差效果的教程
Aug 24 HTML / CSS
使用 css3 实现圆形进度条的示例
Jul 05 HTML / CSS
使用纯 CSS 创作一个脉动 loader效果的源码
Sep 28 HTML / CSS
CSS3 filter(滤镜)实现网页灰色或者黑色模式的代码
Nov 30 HTML / CSS
Html5剪切板功能的实现代码
Jun 29 HTML / CSS
使用Html5、CSS实现文字阴影效果
Jan 17 HTML / CSS
html5 div布局与table布局详解
Nov 16 HTML / CSS
Html5 canvas画图白板踩坑
Jun 01 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/06/13 PHP
smarty获得当前url的方法分享
2014/02/14 PHP
ThinkPHP中U方法的使用浅析
2014/06/13 PHP
PHP abstract 抽象类定义与用法示例
2018/05/29 PHP
广告显示判断
2006/08/31 Javascript
jQuery + Flex 通过拖拽方式动态改变图片的代码
2011/08/03 Javascript
JavaScript中for-in遍历方式示例介绍
2014/02/11 Javascript
jquery.hotkeys监听键盘按下事件keydown插件
2014/05/11 Javascript
Nginx上传文件全部缓存解决方案
2015/08/17 Javascript
AngularJS基础 ng-hide 指令用法及示例代码
2016/08/01 Javascript
Vue.js动态添加、删除选题的实例代码
2016/09/30 Javascript
WEB开发之注册页面验证码倒计时代码的实现
2016/12/15 Javascript
ionic cordova一次上传多张图片(类似input file提交表单)的实现方法
2016/12/16 Javascript
AngularJS入门教程之Helloworld示例
2016/12/25 Javascript
通俗解释JavaScript正则表达式快速记忆
2017/08/23 Javascript
在Vue组件化中利用axios处理ajax请求的使用方法
2017/08/25 Javascript
React Native 截屏组件的示例代码
2017/12/06 Javascript
详解Immutable及 React 中实践
2018/03/01 Javascript
基于vue实现滚动条滚动到指定位置对应位置数字进行tween特效
2019/04/18 Javascript
微信小程序遍历Echarts图表实现多个饼图
2019/04/25 Javascript
react 中父组件与子组件双向绑定问题
2019/05/20 Javascript
JavaScript静态作用域和动态作用域实例详解
2019/06/17 Javascript
Angular进行简单单元测试的实现方法实例
2020/08/16 Javascript
用python代码做configure文件
2014/07/20 Python
使用python根据端口号关闭进程的方法
2018/11/06 Python
Matplotlib配色之Colormap详解
2021/01/05 Python
汽车驾驶求职信
2013/10/25 职场文书
七年级数学教学反思
2014/01/22 职场文书
职工运动会邀请函
2014/02/02 职场文书
趣味游戏活动方案
2014/02/07 职场文书
十佳护士先进事迹
2014/05/08 职场文书
党的群众路线教育实践活动学习笔记
2014/11/05 职场文书
公务员年度考核个人总结
2015/02/12 职场文书
观看《信仰》心得体会
2016/01/15 职场文书
解读Vue组件注册方式
2021/05/15 Vue.js
JAVA SpringMVC实现自定义拦截器
2022/03/16 Python