CSS3 旋转立方体问题详解


Posted in HTML / CSS onJanuary 09, 2020

3D坐标概念

CSS3 旋转立方体问题详解 

  • 当元素进行旋转时,他的坐标轴也跟着他进行旋转
  • 注意-y方向问题

旋转立方体的效果

CSS3 旋转立方体问题详解 

分析

  •  一个容器包含6个div
  • position:absolute 之后6个面完全重合
  • 通过trandform:rotateX/Y/Z(),translateX/Y/Z()调整到相应位置
  • 添加transition动画效果
  • 注意这里面的旋转是绕着他的中心线进行旋转的所以唯一100px
  • 他在旋转时,他的坐标轴也是跟着他进行旋转的(这很重要)

代码

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <meta http-equiv="X-UA-Compatible" content="ie=edge">
    <title>Document</title>
    <style>
        *{
            margin: 0px;
            padding: 0px;

        }
        body{
            perspective: 800px;
            background: #000000;
        }
        #container{
            height: 200px;
            width: 200px;
            margin: 100px auto 0;
            position: relative;
            transform-style: preserve-3d;
            animation: move 1s ease infinite;

        }
        @keyframes move{
            from{
                transform: rotateY(0deg) rotateZ(0deg);
            }
            to{
                transform: rotateY(360deg) rotateZ(360deg);
            }
            
        }
        #container>div{
            height: 100%;
            width: 100%;
            border-radius: 5px;
            background: rgba(255,255,255,0.5);
            position: absolute;
            left: 0px;
            right: 0px;
            text-align: center;
            line-height: 200px;
            font-size: 30px;
        }
        #one{
            transform:rotateX(-90deg) translateZ(100px);
        }
        #two{
            transform:translateZ(100px) ;
        }
        #three{
            transform: rotateY(-90deg) translateZ(100px);
        }
        #four{
            transform: rotateY(-180deg) translateZ(100px);
        }
        #five{
            transform: rotateY(90deg) translateZ(100px);
        }
        #six{
            transform: translateZ(-100px);
        }
        
    </style>
</head>
<body>
    <div id="container">
        <div id="one">1</div>
        <div id="two">2</div>
        <div id="three">3</div>
        <div id="four">4</div>
        <div id="five">5</div>
        <div id="six">6</div>
    </div>
</body>
</html>

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

HTML / CSS 相关文章推荐
CSS3制作精致的照片墙特效
Jun 07 HTML / CSS
Web前端绘制0.5像素的几种方法
Aug 11 HTML / CSS
CSS3 按钮边框动画的实现
Nov 12 HTML / CSS
HTML5 新事件 小结
Jul 16 HTML / CSS
HTML5视频支持检测(检查浏览器是否支持视频播放)
Jun 08 HTML / CSS
使用javascript和HTML5 Canvas画的四渐变色播放按钮效果
Apr 10 HTML / CSS
HTML5 Canvas 旋转风车绘制
Aug 18 HTML / CSS
HTML5拖拽API经典实例详解
Apr 20 HTML / CSS
导出HTML5 Canvas图片并上传服务器功能
Aug 16 HTML / CSS
Html5 video标签视频的最佳实践
Feb 26 HTML / CSS
AmazeUI 按钮交互的实现示例
Aug 24 HTML / CSS
带你了解CSS基础知识,样式
Jul 21 HTML / CSS
详解如何使用CSS3中的结构伪类选择器和伪元素选择器
Jan 06 #HTML / CSS
css3 flex布局 justify-content:space-between 最后一行左对齐
Jan 02 #HTML / CSS
详解CSS3新增的背景属性
Dec 25 #HTML / CSS
CSS3实现缺角矩形,折角矩形以及缺角边框
Dec 20 #HTML / CSS
css3实现背景动态渐变效果
Dec 10 #HTML / CSS
css3动画 小球滚动 js控制动画暂停
Nov 29 #HTML / CSS
CSS3实现酷炫的3D旋转透视效果
Nov 21 #HTML / CSS
You might like
在任意字符集下正常显示网页的方法二(续)
2007/04/01 PHP
php强制下载类型的实现代码
2011/04/21 PHP
解决cPanel无法安装php5.2.17
2014/06/22 PHP
php使用wordwrap格式化文本段落的方法
2015/03/17 PHP
使用图灵api创建微信聊天机器人
2015/07/23 PHP
Zend Framework入门教程之Zend_Registry组件用法详解
2016/12/09 PHP
thinkPHP框架实现类似java过滤器的简单方法示例
2018/09/05 PHP
PHP rmdir()函数的用法总结
2019/07/02 PHP
php DES加密算法实例分析
2019/09/18 PHP
javascript中2个感叹号的用法实例详解
2014/09/04 Javascript
浅谈String.valueOf()方法的使用
2016/06/06 Javascript
微信和qq时间格式模板实例详解
2016/10/21 Javascript
jQuery插件ajaxFileUpload使用详解
2017/01/10 Javascript
JavaScript实现的搜索及高亮显示功能示例
2017/08/14 Javascript
基于对象合并功能的实现示例
2017/10/10 Javascript
基于jQuery解决ios10以上版本缩放问题
2017/11/03 jQuery
浅谈vue-router2路由参数注意的问题
2017/11/08 Javascript
d3.js实现自定义多y轴折线图的示例代码
2018/05/30 Javascript
对Vue table 动态表格td可编辑的方法详解
2018/08/28 Javascript
微信小程序开发摇一摇功能
2019/11/22 Javascript
[04:45]上海特级锦标赛主赛事第三日TOP10
2016/03/05 DOTA
Python检测QQ在线状态的方法
2015/05/09 Python
Python绘制的二项分布概率图示例
2018/08/22 Python
详解如何从TensorFlow的mnist数据集导出手写体数字图片
2019/08/05 Python
python GUI库图形界面开发之PyQt5时间控件QTimer详细使用方法与实例
2020/02/26 Python
Python面向对象程序设计之私有变量,私有方法原理与用法分析
2020/03/23 Python
Python3 hashlib密码散列算法原理详解
2020/03/30 Python
Python爬虫之App爬虫视频下载的实现
2020/12/08 Python
html5 canvas简单封装一个echarts实现不了的饼图
2018/06/12 HTML / CSS
大专毕业生自我鉴定
2013/11/21 职场文书
幼儿园园长岗位职责
2013/11/26 职场文书
党员思想汇报范文
2013/12/30 职场文书
2016国庆节67周年红领巾广播稿
2015/12/18 职场文书
党校团干班培训心得体会
2016/01/06 职场文书
心得体会该怎么写呢?
2019/06/27 职场文书
Java中Quartz高可用定时任务快速入门
2022/04/03 Java/Android