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中设置3D变形的transform-style属性详解
May 23 HTML / CSS
CSS3实现歌词进度文字颜色填充变化动态效果的思路详解
Jun 02 HTML / CSS
如何在网站上添加谷歌定位信息
Apr 16 HTML / CSS
html5 touch事件实现触屏页面上下滑动(二)
Mar 10 HTML / CSS
HTML5+CSS3实现无插件拖拽上传图片(支持预览与批量)
Jan 05 HTML / CSS
利用HTML5画出一个坦克的形状具体实现代码
Jun 20 HTML / CSS
使用纯HTML5编写一款网页上的时钟的代码分享
Nov 16 HTML / CSS
HTML5 新标签全部总汇(推荐)
Jun 13 HTML / CSS
详解HTML5 window.postMessage与跨域
May 11 HTML / CSS
Canvas图片分割效果的实现
Jul 29 HTML / CSS
钉钉企业内部H5微应用开发详解
May 12 HTML / CSS
为什么你写的height:100%不起作用
May 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
PHP实现生成带背景的图形验证码功能
2016/10/03 PHP
php 访问oracle 存储过程实例详解
2017/01/08 PHP
利用Homestead快速运行一个Laravel项目的方法详解
2017/11/14 PHP
js键盘上下左右键怎么触发function(实例讲解)
2013/12/14 Javascript
jquery插件lazyload.js延迟加载图片的使用方法
2014/02/19 Javascript
jQuery判断checkbox是否选中的3种方法
2014/08/12 Javascript
Jquery实现瀑布流布局(备有详细注释)
2015/07/31 Javascript
简单实现JS对dom操作封装
2015/12/02 Javascript
AngularJS实现全选反选功能
2015/12/08 Javascript
理解javascript模块化
2016/03/28 Javascript
利用javascript实现的三种图片放大镜效果实例(附源码)
2017/01/23 Javascript
Angular2 父子组件通信方式的示例
2018/01/29 Javascript
Angular6封装http请求的步骤详解
2018/08/13 Javascript
koa socket即时通讯的示例代码
2018/09/07 Javascript
在vue中实现点击选择框阻止弹出层消失的方法
2018/09/15 Javascript
微信小程序 冒泡事件原理解析
2019/09/27 Javascript
Vue 解决通过this.$refs来获取DOM或者组件报错问题
2020/07/28 Javascript
vue实现把接口单独存放在一个文件方式
2020/08/13 Javascript
[37:29]完美世界DOTA2联赛PWL S2 LBZS vs Forest 第二场 11.19
2020/11/19 DOTA
Python实现的径向基(RBF)神经网络示例
2018/02/06 Python
python 处理string到hex脚本的方法
2018/10/26 Python
详解Python静态网页爬取获取高清壁纸
2019/04/23 Python
详解Python二维数组与三维数组切片的方法
2019/07/18 Python
python 并发下载器实现方法示例
2019/11/22 Python
python3 实现调用串口功能
2019/12/26 Python
python实现KNN近邻算法
2020/12/30 Python
毕业生个人求职的自我评价
2013/10/28 职场文书
党员的自我评价范文
2014/01/02 职场文书
学生会主席竞聘书
2014/03/31 职场文书
大学生党员自我评价范文
2014/04/09 职场文书
期中考试反思800字
2014/05/01 职场文书
乡镇挂职心得体会
2014/09/04 职场文书
检察机关个人对照检查材料
2014/09/15 职场文书
初中数学教学随笔
2015/08/15 职场文书
js中Object.create实例用法详解
2021/10/05 Javascript
动画《新网球王子 U-17 WORLD CUP》希腊队PV公开
2022/04/02 日漫