【学+原】CSS3的2D动画 ——仿NOMOS手表
看CSS3妙味课堂中有一课是介绍如何做钟表界面,然后三根针都能随着时间转动,然后自己在那个简易的版本上做了一些进一部改进。
- 最关键的知识点应该是
transform-origin这个样式,要选对旋转的中心点。分针秒针时针的旋转中心点应该是针的底部中间位置 - 这个实例还是让我第一次见到把
<style>设置了id,然后写进js里去操作的,因为表面的各种小时,秒的刻度的制作,需要用循环来写,直接写css样式里是不现实的。 - 另外就是要把
setInterval和transform:rotate结合起来使用,让秒钟动起来。 - 不要忘了,在秒钟动的同时,分针和时针都在一直变化着,所以要将每一秒后三根针的位置都要同时计算,按照比例来计算分针是时针的角度

<style id="css">ul{; list-style: none;}#cover{ width: 400px; height: 400px;%; border: 3px solid #504f4c; position: relative; background: #f1f1f3;}#center,#icon,#icon_inner,#center_inner{%; position: absolute;; margin: auto;}#icon{ width: 26px; height: 26px; background: #0677bf; }#center{ width: 8px; height: 8px; background: #b4bea5;; }#icon_inner{ width: 12px; height: 12px; background: #b94130; }#center_inner{ width: 4px; height: 4px; background: #b94130;; }#hour{ width: 6px; height: 105px; position: absolute; left: 197px; bottom: 208px; background:#0677bf; border-radius: 3px; transform-origin: 3px 110px;;}#minute{ width: 6px; height: 190px; position: absolute; left: 197px; bottom: 205px; background:#0677bf; border-radius: 3px; transform-origin: 3px 195px;;}#second{ width: 3px; height: 70px; position: absolute; left: 58.5px; bottom: 45px; background:#b94130; border-radius: 2px; transform-origin: 1.5px 55px; }#list_big li{ width: 1px; height: 15px; position: absolute; left: 199px; bottom: 380px; background: #171717; transform-origin: 1px 195px;}#list_small li{ width: 4px; height: 40px; border-radius: 2px; position: absolute; left: 198px; bottom: 335px; background: #171717; transform-origin: 2px 175px; }#list_big li:nth-of-type(5n+1){ width: 4px; border-radius: 2px;}#number li{ position: absolute; height: 40px; line-height: 40px;%; bottom: 330px; font-family: "arial narrow"; font-size: 50px;%);% 170px;}#mark{ width: 100px; position: absolute; top: 100px;%;%); font-family: arial;;}#mark_top{ position: absolute; text-align: center;%;%); font-size: 18px;}#mark_bottom{ position: absolute; top: 20px;%;%); text-align: center; font-size: 8px;}#cover_inner{ width: 120px; height: 120px;%; background: #e0dfdb; position: absolute; bottom: 50px;%;%);}#cover_inner li{ width: 2px; height: 12px; border-radius: 1px; position: absolute; left: 59px; bottom: 103px; background: #171717; transform-origin: 1px 55px; }#cover_inner li:nth-of-type(3n+1){ width: 4px; border-radius: 2px;}</style><script>window.onload=function(){ var oListB = document.getElementById('list_big'); var oListS = document.getElementById('list_small'); var oListI = document.getElementById('list_inner'); var oNum = document.getElementById('number'); var oCss = document.getElementById('css'); var listBHtml = ''; var listSHtml = ''; var listIHtml = ''; var numHtml = ''; var oCssHtml = oCss.innerHTML; ; i++) { listBHtml += '<li></li>'; +'deg);}' } ; i++) { listIHtml += '<li></li>';) +'deg);}' } ; i++) { listSHtml += '<li></li>';) +'deg);}' } ; i++) { ){ continue; }) +'deg);}' } oListB.innerHTML = listBHtml; oListS.innerHTML = listSHtml; oListI.innerHTML = listIHtml; oCss.innerHTML = oCssHtml; var oSec = document.getElementById('second'); var oMin = document.getElementById('minute'); var oHour = document.getElementById('hour'); getTime(); ); function getTime(){ var oDate = new Date(); var iSec = oDate.getSeconds(); ; ; +'deg)'; +'deg)'; +'deg)'; }};</script></head><body> <div id="cover"> <span id="icon"></span> <span id="center"></span> <span id="hour"></span> <span id="minute"></span> <div id="mark"> <span id="mark_top">N O M O S</span> <span id="mark_bottom">G L A S H U T T E</span> </div> <div id="cover_inner"> <ul id="list_inner"> </ul> <span id="icon_inner"></span> <span id="center_inner"></span> <span id="second"></span> </div> <ul id="list_big"> </ul> <ul id="list_small"> </ul> <ul id="number"> </li> </li> </li> <li></li> </li> </li> </ul> </div></body></html>【学+原】CSS3的2D动画 ——仿NOMOS手表的更多相关文章
- 14:CSS3 渐变(gradient)与 过度(transition)、CSS3 的2D动画
14:CSS3 渐变 CSS3 渐变(gradient)可以让你在两个或多个指定的颜色之间显示平稳的过渡. 以前,你必须使用图像来实现这些效果,现在通过使用 CSS3 的渐变(gradients)即可 ...
- 【学】CSS3的3D动画 ——3D旋转之骰子样式的钟表(2)上
这个是3D旋转的进阶版,是一个类似与骰子的正方体.这个版本只有秒数的个位数,还没有写整个钟表,下面那个版本好好想想该怎么写 这个效果需要用到transform-style: preserve-3d. ...
- 【原】CSS3的3D动画 ——3D旋转之骰子样式的钟表(2)下.md
之前看到智能社主页的那个骰子样式的钟表,最近研究了一下,虽然没有仔细看他是怎么做的,但是学了css3的动画之后想自己尝试着写一下,用到的原理可能和智能社网站的不太一样,我自己主要用到了css3和js. ...
- CSS3中2D/3D转换、过渡、动画
转换.过渡.动画 2D 转换 1.translate() 方法 通过 translate() 方法,元素从其当前位置移动,根据给定的 left(x 坐标) 和 top(y 坐标) 位置参数: 实例 d ...
- 《零基础学HTML5+CSS3(全彩版)》读书笔记
2019年1月31日星期四 1点 <零基础学HTML5+CSS3(全彩版)>开始全面学习 前提: 11月20日开始学Python,可能因为太累了,也可能遇到了瓶颈,进入了一个迷茫期,1月6 ...
- 9款超绚丽的HTML5/CSS3应用和动画特效
1.CSS3飘带状3D菜单 菜单带小图标 这次我们要来分享一款很特别的CSS3菜单,菜单的外观是飘带状的,并且每一个菜单项有一个精美的小图标,鼠标滑过菜单项时,菜单项就会向上凸起,像是飘带飘动一样,形 ...
- CSS3中的动画效果记录
今天要记录的是CSS3中的三种属性transform.transition以及animation,这三个属性大大提升了css处理动画的能力. 一.Transform 变形 CSS中transform ...
- 2D动画的制作
通过css3的transform transition可以实现平移,旋转,缩放,拉伸等效果 1.缩放 -webkit-transform: scale(1); -moz-transform: sca ...
- 如何制作css3的3d动画——以骰子旋转为例,详解css3动画属性
首先先来看两个用css3实现的炫酷的3d动画效果 1 2 3 4 5 6 你没看错,这个炫酷的效果都是用css3实现的. 下面是动画实现所需要用到的几个css3属性. 1.perspective: ...
随机推荐
- Makefile.am链接openCV库的写法
6 INCLUDES = `pkg-config opencv --cflags` -I./ 17 bin_PROGRAMS+=SegRecogServerDeme 18 SegRecogServer ...
- guava学习--事件驱动模型
转载:http://www.cnblogs.com/whitewolf/p/4132840.html http://www.cnblogs.com/peida/p/EventBus.html 更好 ...
- oracle sql
show user desc 'table' SELECT DISTINCT SELECT * FROM emp WHERE comm is NOT NULL; SELECT * FROM emp W ...
- [css]input text ie6/7 border兼容问题
[border:none;]当border为“none”时对IE6/7无效边框依然存在 [border:0;]当border为“0”时,所有浏览器都一致把边框隐藏 [border:0;]把border ...
- Java in a Nutshell学习笔记
1, bytecode永远是大段 2,其它语言要在java里运行,要么实现类似于javac的编译器,把该语言解释成为class文件.要么,直接重新实现JVM,直接解释该语言3,Java和C++区别: ...
- enmo_day_03
安装 装载点 : /u01 (第一个挂载点 LUN1) /u01 (第二个挂载点LUN2) /disk01 目录 : /u01/app/oracle /u01/app/app 文件 : 控制文件 :c ...
- AngularJS向指令传递数据
我今天要实现的功能是利用AngularJS来完成客户端过滤器. list.html页面主要代码如下: ...... <div class='tj_con_tr_ipt' ng-init=&quo ...
- Pig与Hive的区别
Language 在Hive中可以执行 插入/删除 等操作,但是Pig中我没有发现有可以 插入 数据的方法,请允许我暂且认为这是最大的不同点吧. Schemas Hive中至少还有一个“表”的概念, ...
- 转载--JAVA读取文件最佳实践
1. 前言 Java应用中很常见的一个问题,如何读取jar/war包内和所在路径的配置文件,不同的人根据不同的实践总结出了不同的方案,但其他人应用却会因为环境等的差异发现各种问题,本文则从原理上解释 ...
- js中的offsetWidth岁的BUG
---恢复内容开始--- 在js使用offsetWidth来操作控件的运动是会遇到: var oDiv = document.getElementById('div1') oDiv.style.wid ...