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 相关文章推荐
使用Filters滤镜弥补CSS3的跨浏览器问题以及兼容低版本IE
Jan 23 HTML / CSS
详解CSS中iconfont的使用
Aug 04 HTML / CSS
利用CSS3的线性渐变linear-gradient制作边框的示例
Jun 02 HTML / CSS
html5 canvas绘制放射性渐变色效果
Jan 04 HTML / CSS
浅谈three.js中的needsUpdate的应用
Nov 12 HTML / CSS
html5 乒乓球(碰撞检测)实例二
Jul 25 HTML / CSS
HTML5无刷新改变当前url的代码
Mar 15 HTML / CSS
移动端Html5中百度地图的点击事件
Jan 31 HTML / CSS
使用canvas生成含有微信头像的邀请海报没有微信头像问题
Oct 29 HTML / CSS
Html5踩坑记之mandMobile使用小记
Apr 02 HTML / CSS
HTML5 FileReader对象的具体使用方法
May 22 HTML / CSS
Html5+CSS3+EL表达式问题小结
Dec 19 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
php分页函数
2006/07/08 PHP
PHP模块 Memcached功能多于Memcache
2011/06/14 PHP
PHPStrom 新建FTP项目以及在线操作教程
2016/10/16 PHP
PHP curl批处理及多请求并发实现方法分析
2018/08/15 PHP
Laravel修改验证提示信息为中文的示例
2019/10/23 PHP
JSQL 批量图片切换的实现代码
2010/05/05 Javascript
使用JS画图之点、线、面
2015/01/12 Javascript
基于Vuejs实现购物车功能
2016/08/02 Javascript
在vue项目中使用element-ui的Upload上传组件的示例
2018/02/08 Javascript
使用vue + less 实现简单换肤功能的示例
2018/02/21 Javascript
angular4笔记系列之内置指令小结
2018/11/09 Javascript
JavaScript实现简单贪吃蛇效果
2020/03/09 Javascript
jQuery事件模型默认行为执行顺序及trigger()与 triggerHandler()比较实例分析
2020/04/30 jQuery
js中!和!!的区别与用法
2020/05/09 Javascript
详解JavaScript 作用域
2020/07/14 Javascript
JS addEventListener()和attachEvent()方法实现注册事件
2021/01/11 Javascript
js实现碰撞检测
2021/01/29 Javascript
python实现分析apache和nginx日志文件并输出访客ip列表的方法
2015/04/04 Python
简单介绍使用Python解析并修改XML文档的方法
2015/10/15 Python
简单的Python调度器Schedule详解
2019/08/30 Python
Python3.7 pyodbc完美配置访问access数据库
2019/10/03 Python
如何解决django-celery启动后迅速关闭
2019/10/16 Python
python GUI库图形界面开发之PyQt5表单布局控件QFormLayout详细使用方法与实例
2020/03/06 Python
html5 Canvas实现图片旋转的示例
2018/01/15 HTML / CSS
LTD Commodities:礼品,独特发现,家居装饰,家用器皿
2017/08/11 全球购物
惊艳的手工时装首饰:Migonne Gavigan
2018/02/23 全球购物
Java基础类库面试题
2013/09/04 面试题
手术室护士自我鉴定
2013/10/14 职场文书
村委会主任先进事迹
2014/01/15 职场文书
学生评语大全
2014/04/18 职场文书
莫言诺贝尔获奖演讲稿
2014/05/21 职场文书
建筑工程质量通病防治方案
2014/06/08 职场文书
同学聚会通知书
2015/04/20 职场文书
民政局未婚证明
2015/06/15 职场文书
解决Navicat for MySQL 连接 MySQL 报2005错误的问题
2021/05/29 MySQL
Redis实现一个账号只能登录一个设备
2022/04/19 Redis