【原】CSS3的3D动画 ——3D旋转之骰子样式的钟表(2)下.md
之前看到智能社主页的那个骰子样式的钟表,最近研究了一下,虽然没有仔细看他是怎么做的,但是学了css3的动画之后想自己尝试着写一下,用到的原理可能和智能社网站的不太一样,我自己主要用到了css3和js。

- 程序写到一半,发现只有chrome和ff支持,而用ie11是没有效果的,然后用ie11去打开智能社网页,效果也是没有,调查了一下,应该是
transform-style:preserve-3d这个样式在ie11下还不支持,使得对象无法以3d的样式呈现,至于兼容方式,自己还没有花时间研究,所以这个效果暂时只能用chrome或者ff打开。 - 复习了一下关于时间获取的语句
var t = new Date(),另外还学习了如何获取当前时间的下一段时间的方式,比如获取当前时间的前一秒,思路是要用到时间戳getTime(),就是当前时间t到1970年的毫秒数,然后加上1000即可。具体代码如下:
var t = new Date(); //获取当前时间var t_d = t.getTime(); //获取时间戳t_d,就是t到1970年的毫秒数var t1 = new Date();//设置t1也是当前时间,这里我自己有个疑问,因为这里t1其实和t肯定是有一点时间差的,也许这个时间实在太短,可以忽略,或者我可以把这句接在var t的下面,让时间差尽量少); //把时间戳减少1000毫秒,通过setTime对t1进行操作,就可以让t1成为t的前一秒事件3. will-change: transform;这个属性是可以增加css3动画的流畅度的,具体原理可以查看这篇张鑫旭的博客:http://www.zhangxinxu.com/wordpress/2015/11/css3-will-change-improve-paint/
4. 写js的时候还是遇到了一些代码重复的问题,就比如如何将一个函数里要用到另一个函数里的变量,该怎么写,后来想到了用传参数的方法可以解决,把另一个函数fn2里的变量用t代替写在这个函数fn1的参数中,然后在fn2里调用fn1时,把参数传进fn1里即可,详细代码可以见下面
<style>ul{; list-style: none;}#wrap{ margin: 70px auto; width: 800px; height: 80px; padding: 30px; transform-origin: center center center; animation: move 5s linear infinite alternate; transform-style: preserve-3d; will-change: transform;}.outerbox{ perspective: 500px; height: 80px; margin: 10px; float: right; transform-origin: center center; transform-style: preserve-3d; transform: rotateY(10deg); will-change: transform;}.dice{ width: 80px; height: 80px; transform-style: preserve-3d;% -40px;,1.46); position: relative; will-change: transform;}.dice li{ width: 78px; height: 78px; border: 1px solid black; font: 50px/80px arial; font-weight: bold; text-align: center; position: absolute; opacity: 0.4; will-change: transform;}){ top: -80px; transform-origin: bottom; transform: rotateX(90deg);}){}){ top: 80px; transform-origin: top; transform: rotateX(-90deg);}){ transform: translateZ(-80px) rotateX(180deg);}){ left: 80px; transform-origin: left; transform: rotateY(90deg); }){ left: -80px; transform-origin: right; transform: rotateY(-90deg);}.dice .colon{;}@keyframes move{ %{transform: rotateX(5deg) rotateY(5deg);} %{transform: rotateX(-5deg) rotateY(-5deg);}}</style><script>window.onload = function(){ var aUl = document.getElementsByTagName('ul'); ;i<aUl.length;i++) {;; aUl[i].onOff = true; } function turn(obj,now,next){ //这里的now和next分别指的是另一个函数里要用到的变量,为了可以用它们,需要在这里先把它们当做参数写,然后在另外一个函数里调用时,将参数写进去 var aLi = obj.getElementsByTagName('li'); ; i<aLi.length; i++) { aLi[i].index = i; } ; ){; } if(obj.onOff){ aLi[obj.Index].innerHTML = now; obj.onOff = false; } if(now!==next){ aLi[obj.Index_].innerHTML = now;; obj.style.transform = 'rotateX('+obj.angle+'deg)'; obj.Index++; } ; i++) { aLi[i].style.opacity = 0.2; aLi[i].style.color = 'lightgrey'; } ){; } aLi[obj.Index].style.opacity = 0.8; aLi[obj.Index].style.color = 'black'; document.title=now+"::"+next; } function getTime(){ var t = new Date(); var iSec = t.getSeconds(); var iMin = t.getMinutes(); var iHour = t.getHours(); ; ); ; ); ; ); var t_d = t.getTime(); var t1 = new Date();); var iSec_ = t1.getSeconds(); var iMin_ = t1.getMinutes(); var iHour_ = t1.getHours(); ; ); ; ); ; ); ],iSecR,iSecR_); //这里调用的时候将对应的变量传给now和next上即可],iSecL,iSecL_);],iMinR,iMinR_);],iMinL,iMinL_);],iHourR,iHourR_);],iHourL,iHourL_); } getTime();); };</script></head><body> <div id="wrap"> <div class="outerbox"> <ul class="dice"> <li></li> <li></li> <li></li> <li></li> <li></li> <li></li> </ul> </div> <div class="outerbox"> <ul class="dice"> <li></li> <li></li> <li></li> <li></li> <li></li> <li></li> </ul> </div> <div class="outerbox"> <ul class="dice"> <li class="colon">:</li> <li></li> <li></li> <li></li> <li></li> <li></li> </ul> </div> <div class="outerbox"> <ul class="dice"> <li></li> <li></li> <li></li> <li></li> <li></li> <li></li> </ul> </div> <div class="outerbox"> <ul class="dice"> <li></li> <li></li> <li></li> <li></li> <li></li> <li></li> </ul> </div> <div class="outerbox"> <ul class="dice"> <li class="colon">:</li> <li></li> <li></li> <li></li> <li></li> <li></li> </ul> </div> <div class="outerbox"> <ul class="dice"> <li></li> <li></li> <li></li> <li></li> <li></li> <li></li> </ul> </div> <div class="outerbox"> <ul class="dice"> <li></li> <li></li> <li></li> <li></li> <li></li> <li></li> </ul> </div> </div> </body></html>【原】CSS3的3D动画 ——3D旋转之骰子样式的钟表(2)下.md的更多相关文章
- 【学】CSS3的3D动画 ——3D旋转之骰子样式的钟表(2)上
这个是3D旋转的进阶版,是一个类似与骰子的正方体.这个版本只有秒数的个位数,还没有写整个钟表,下面那个版本好好想想该怎么写 这个效果需要用到transform-style: preserve-3d. ...
- 【巩固】CSS3的3D动画 ——3D旋转(1)
最近学了妙味的css3的动画,2D,3D的都有,先写一个最简单的3d翻转效果,鼠标移入div,正反面翻转效果. 注意点有: 要给正反面外面加个父级: transform-style: preserve ...
- CSS3 动画3D视角下 旋转圆环
首先是 transform 属性: transform 属性向元素应用 2D 或 3D 转换.该属性允许我们对元素进行旋转.缩放.移动或倾斜. 加上对应属性则可得到3D透视效果下的形态 本次以圆形( ...
- 3D Grid Effect – 使用 CSS3 制作网格动画效果
今天我们想与大家分享一个小的动画概念.这个梦幻般的效果是在马库斯·埃克特的原型应用程序里发现的.实现的基本思路是对网格项目进行 3D 旋转,扩展成全屏,并呈现内容.我们试图模仿应用程序的行为,因此 ...
- 如何制作css3的3d动画——以骰子旋转为例,详解css3动画属性
首先先来看两个用css3实现的炫酷的3d动画效果 1 2 3 4 5 6 你没看错,这个炫酷的效果都是用css3实现的. 下面是动画实现所需要用到的几个css3属性. 1.perspective: ...
- CSS3中的3D动画实现(钟摆、魔方)--实现代码
CSS3中的3D动画实现(钟摆.魔方) transition-property 过渡动画属性 all|[attr] transition-duration 过渡时间 transition-delay ...
- [web前端] css3 transition属性实现3d动画效果
cp from : https://www.cnblogs.com/chrxc/p/5123375.html transition属性是一个很强大的3d动画属性,我动手试了一下,很多在网上很火的网页动 ...
- css3 transition属性实现3d动画效果
transition属性是一个很强大的3d动画属性,我动手试了一下,很多在网上很火的网页动画都可以用这个属性实现,只能说这个属性是在是太强大啦,本人在学习次属性之后才知道自己对css3的认识还是偏少, ...
- css3图书3D动画
css3图书3D动画,css3,立体特效,旋转效果,3D动画,css3图书3D动画是一款基于css3实现的立体旋转3D图书动画特效. 代码下载页:http://www.huiyi8.com/sc/71 ...
随机推荐
- 安装mongodb
安装mongodb的时候遇到一些麻烦 首先将安装包下下来 安装的是windows版本的 将bin文件夹加入环境变量后通过mongod和mongo指令就可以进行操作,很方便 用指令mongod --db ...
- VUE应用的一些感受
方便,数据绑定太方便了. 一个组件一个.vue文件特别清晰. 讲真vue比angular好学多了. webpack打包最近看懂,通过一个主文件把require的文件都打进来.业务代码放build里,引 ...
- PDF 补丁丁 0.4.3.1518 测试版发布:书签编辑器新增升级书签功能、优化PDF文档阅览器
新的 PDF 补丁丁测试版上线啦! 新版本增加了升级书签的功能(见工具栏的“←”按钮),可以方便地将下级书签升级为上级书签. 另外,新版本还增强了书签编辑器功能中的 PDF阅读器,从之前的单页阅读模式 ...
- 关于DButils的简单介绍
android中的orm框架,一行代码就可以进行增删改查:支持事务,默认关闭:可通过注解自定义表名,列名,外键,唯一性约束,NOT NULL约束,CHECK约束等(需要混淆的时候请注解表名和列名)等等 ...
- 获取本地soapUI项目路径
def projectDir = ${projectDir}
- Cloudera-Manager修改集群的IP
1.业务需求说明:由于公司网络进行了整改,随之而来的就是对应的ip网段发生了变化,其中我的hadoop的集群各主机的ip也相应的发生了改变,因此需要对各主机进行修改ip. 2.具体操作: 首先停止cd ...
- 将事件绑定在html标签中和js动态绑定的区别
一:绑定在标签中: 能够一眼看出那些元素绑定了什么事件. 只能将元素和事件逐一实现绑定. 二js动态绑定: 可以一次动态的给多个元素绑定事件,批量绑定事件. html标签绑定的缺点: ①:可能有时间差 ...
- cocos2dx 3.8版关于#include "GB2ShapeCache-x.h"
关于coco2d-x 3.8版的PhysicsEditor.exe1.09版的GB2ShapeCache-x.h.cpp中有些方法更新了和容器的使用方法,还有就是头文件include "CC ...
- js中退出语句break,continue和return 比较 (转载)
在 break,continue和return 三个关键字中, break,continue是一起的,return 是函数返回语句,但是返回的同时也将函数停止 首先:break和continue两个一 ...
- Ubuntu 14.04下安装Hadoop2.4.0 (单机模式)
转自 http://www.linuxidc.com/Linux/2015-01/112370.htm 一.在Ubuntu下创建Hadoop组和hadoop用户 增加hadoop用户组,同时在该组里增 ...