分别用canvas和css3的transform做出钟表的效果
两种方式实际上在js上的原理都是一样的。都是获取时间对象,再获取时间对象的时分秒,时分秒乘以其旋转一刻度(一秒、一分、一小时)对应的角度。css3中要赋值于transform:rotate(角度),canvas中要注意的是 arc旋转的不是角度而是弧度,所以要进行转换。最后开一个一秒变化一次的定时器,让函数每秒走一次,就实现了钟表的效果。
1、canvas下的钟表设计
首先就是html布局,canvas的布局很简单
<canvas style="background-color:#ccc;" width="500px" height="500px" id="canvas1"></canvas>
背景色设为#ccc是为了区别浏览器底色与画布底色
下来就是js,先把基本的canvas套路写出来
var oC=document.getElementById('canvas1');
var oCG=oC.getContext('2d');
当然要在window.onload下执行。
在画钟表之前先获取
var oDate=new Date();
var oSecs=oDate.getSeconds();
var oMins=oDate.getMinutes()+oSecs/60;
var oHours=oDate.getHours()+oMins/60;
var oSecsValue=(oSecs*6-90)*Math.PI/180;
var oMinsValue=(oMins*6-90)*Math.PI/180;
var oHoursValue=(oHours*30-90)*Math.PI/180;
}
为什么后三句都要减90,附一张图大家就懂了,因为arc画圆,起始点时从右边0处开始,而时钟是从上边-90开始,所以要-90,+oSecs/60和+oMins/60是为了让秒钟走的时候时钟也跟着走秒钟走到30秒,分钟多走半个格子。分钟走了30分,时钟多走半个格子。 弧度=角度*Math.PI/180

下来就是画时钟了
function time(){
//构建时钟的最小间隔60个
oCG.beginPath();
for(var i=0;i<60;i++){
oCG.moveTo(250,250);//移画布中心到250,250
oCG.arc(250,250,200,6*i*Math.PI/180,6*(i+1)*Math.PI/180,false);
};
oCG.closePath();
oCG.stroke();
//建一个覆盖于最小间隔的遮罩层,半径比它小
oCG.beginPath();
oCG.arc(250,250,180,0,360*Math.PI/180,false);
oCG.fillStyle='#ccc';
oCG.closePath();
oCG.fill();
//构建小时间隔12个
oCG.beginPath();
for(var i=0;i<12;i++){
oCG.moveTo(250,250);//移画布中心到250,250
oCG.arc(250,250,200,30*i*Math.PI/180,30*(i+1)*Math.PI/180,false);
oCG.lineWidth='5';
};
oCG.closePath();
oCG.stroke();
//再做一个遮罩层,目的是让小时的线长一点
oCG.beginPath();
oCG.arc(250,250,160,0,360*Math.PI/180,false);
oCG.fillStyle='#ccc';
oCG.closePath();
oCG.fill();
//时针的做法
oCG.beginPath();
oCG.moveTo(250,250);//移画布中心到250,250
oCG.arc(250,250,100,oHoursValue,oHoursValue,false);
oCG.lineWidth=8;
oCG.closePath();
oCG.stroke();
//分针的做法
oCG.beginPath();
oCG.moveTo(250,250);//移画布中心到250,250
oCG.arc(250,250,180,oMinsValue,oMinsValue,false);
oCG.lineWidth=5;
oCG.closePath();
oCG.stroke();
//秒针的做法
oCG.beginPath();
oCG.moveTo(250,250);//移画布中心到250,250
oCG.arc(250,250,180,oSecsValue,oSecsValue,false);
oCG.lineWidth=3;
oCG.closePath();
oCG.stroke();
}
window.onload=function(){
setInterval(function(){
oCG.clearRect(0,0,oC.offsetWidth,oC.offsetHeight);
time();
},1000)
}
clearRect(0,0,oC.offsetWidth,oC.offsetHeight),这句话的意思就是每走1秒,清除上一秒画布里面的所有东西。必须要有这句话。
canvas做的时钟
<div id="box">
<ul id="list">
<!--<li></li>-->
<!--<li></li>-->
<!--<li></li>-->
<!--<li></li>-->
<!--<li></li>-->
<!--<li></li>-->
<!--<li></li>-->
</ul>
<div id="hour"></div>
<div id="min"></div>
<div id="sec"></div>
<div id="point"></div>
</div>
css,注意的是li标签元素变换的起点 横坐标是中心,纵坐标是距离其父标签99px,表的指针旋转起来,元素变换的起点是,横坐div底部,纵坐标div中心
<style id="css">
#box{width:200px;height:200px; border:1px solid black;-webkit-border-radius: 50%;margin:200px auto;position: relative;}
*{margin:;padding:}
#box ul{margin:;padding:;height: 200px;position: relative;list-style: none;}
#box ul li{width: 2px;height: 7px;position: absolute;background-color: #000; left:99px; top:;-webkit-transform-origin:center 99px;}
/*#box ul li:nth-of-type(1){-webkit-transform:rotate(6deg)}*/
/*#box ul li:nth-of-type(2){-webkit-transform:rotate(12deg)}*/
/*#box ul li:nth-of-type(3){-webkit-transform:rotate(18deg)}*/
/*#box ul li:nth-of-type(4){-webkit-transform:rotate(24deg)}*/
/*#box ul li:nth-of-type(5){-webkit-transform:rotate(30deg)}*/
/*#box ul li:nth-of-type(6){-webkit-transform:rotate(36deg)}*/
/*#box ul li:nth-of-type(7){-webkit-transform:rotate(42deg)}*/
#box ul li:nth-of-type(5n+1){height: 15px} //保证第一个刻度的长度要长一点
#hour{width:6px;height: 45px; background-color:#000;position: absolute;left: 97px;top:55px;-webkit-transform-origin:bottom }
#min {width:4px;height: 65px; background-color:gray;position: absolute;left: 97px;top:35px;-webkit-transform-origin:bottom }
#sec {width:3px;height: 80px; background-color:red;position: absolute;left: 95px;top:20px;-webkit-transform-origin:bottom}
#point{width: 15px ;height:15px;background-color: black;border-radius: 50%;position: absolute;left: 95px;top: 95px}
</style>
css写好js其实还是很好写的
var oList=document.getElementById('list');
var aLi='';
var aCss='';
var oCss=document.getElementById('css');
var oHour=document.getElementById('hour');
var oMin=document.getElementById('min');
var oSec=document.getElementById('sec');
for(var i=0;i<60;i++){
aLi+='<li></li>';
aCss+='#box ul li:nth-of-type('+(i+1)+'){-webkit-transform:rotate('+6*i+'deg)}'
}
oList.innerHTML=aLi;
oCss.innerHTML+=aCss;
构建新的60li标签,让其插入到ul里面。新的60个li标签的css的样式插入到style中。
把时钟指针旋转的角度附给transform:rotate
function toTime(){
var iDate=new Date();
var iSec=iDate.getSeconds();
var iMin=iDate.getMinutes()+iSec/60;
var iHour=iDate.getHours()+iMin/60;
oSec.style.webkitTransform='rotate('+iSec*6+'deg)';
oMin.style.webkitTransform='rotate('+iMin*6+'deg)';
oHour.style.webkitTransform='rotate('+iHour*30+'deg)';
}
定时器走起来
toTime();
setInterval(toTime,1000);

css3做的时钟
总结:
canvas是我年前做的,css这个是我今天做的。刚好看见了,就准备发个博客对比一下两者的区别。最终发现,两者并没有太大区别,核心原理上的还是一样的。小伙伴们快看看吧。
分别用canvas和css3的transform做出钟表的效果的更多相关文章
- 实用CSS3的transform实现多种动画效果
查看效果:http://keleyi.com/a/bjad/b6x9q8gs.htm 以下是代码: <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4. ...
- HTML5之CSS3 3D transform 剖析式学习之一
最近坐地铁发现“亚洲动物基金”在地铁上做了很多公益广告,比较吸引人的是一个月熊的广告.做的很可爱.回去就搜了一下,发现这个网站是HTML5做的,非常炫. 所以想学习一下,方法就是传统的学习办法,模仿. ...
- CSS3属性transform详解之(旋转:rotate,缩放:scale,倾斜:skew,移动:translate)
CSS3属性transform详解之(旋转:rotate,缩放:scale,倾斜:skew,移动:translate) 在CSS3中,可以利用transform功能来实现文字或图像的旋转.缩放.倾 ...
- 用CSS3的transform来做一个立方体
有一次上数据结构课老师布置了一个用队列的思想通过js和Html来做一个“跳舞配对”的网页,当时那个跳舞的部分用了css3里面transform的相关属性做了个个让图片无限翻转的效果,可能正是由于这个效 ...
- 好吧,CSS3 3D transform变换,不过如此!
一.写在前面的秋裤 早在去年的去年,我就大肆介绍了2D transform相关内容.看过海贼王的都知道,带D的家伙都不是好惹的,2D我辈尚可以应付,3D的话,呵呵,估计我等早就在千里之外被其霸气震晕了 ...
- css3 变形(transform)、转换(transition)和动画(animation)
http://www.w3cplus.com/content/css3-transform/ 在CSS3中transform主要包括以下几种:旋转rotate.扭曲skew.缩放scale和移动tr ...
- CSS3 2D Transform
在 一个二维或三维空间,元素可以被扭曲.移位或旋转.只不过2D变形工作在X轴和Y轴,也就是大家常说的水平轴和垂直轴:而3D变形工作在X轴和Y轴之外, 还有一个Z轴.这些3D变换不仅可以定义元素的长度和 ...
- CSS3 3D Transform
CSS3 3D Transform 原文:http://www.w3cplus.com/css3/css3-3d-transform.html 三维变换使用基于二维变换的相同属性,如果您熟悉二维变换, ...
- css3之transform的应用
一.利用transform实现图片额外显示 效果图如下 初始状态:
随机推荐
- day12 异常 模块 单例
1.异常 处理 在程序执行过程中 ,发生,影响程序的正常运行 在python中 异常就是一个错误 try .... except....捕获异常 try 用来检测t ...
- webpack系列之loader的基本使用
可以访问 这里 查看更多关于大数据平台建设的原创文章. webpack系列之loader及简单的使用 一. loader有什么用 webpack本身只能打包Javascript文件,对于其他资源例如 ...
- vue项目打包配置多个测试环境与生产环境,用npm命令打出不同的资源包。
1.找到package.json文件,找到script节点.再新增一个新的脚本命令 test 2.修改prod.env.js配置文件,npm_lifecycle_event代表返回当前执行的脚本名称, ...
- Golang omitempty 的用法
原文链接:https://blog.csdn.net/skh2015java/article/details/90720692omitempty作用是在json数据结构转换时,当该字段的值为该字段类型 ...
- linux tmpfs及消耗内存脚本
一.tmpfs介绍 tmpfs是一种虚拟内存文件系统,正如这个定义它最大的特点就是它的存储空间在VM里面VM是由linux内核里面的vm子系统管理的东西,现在大多数操作系统都采用了虚拟内存管理机制VM ...
- EventLoop-浏览器篇2
最近又碰到了event loop问题,之前研究的实在是浅显(https://www.cnblogs.com/zx0423/p/12641637.html)所以今天主要讲述promise的链式调用,as ...
- 类的加载,链接和初始化——1运行时常量池(来自于java虚拟机规范英文版本+本人的翻译和理解)
加载(loading):通过一个特定的名字,找到类或接口的二进制表示,并通过这个二进制表示创建一个类或接口的过程. 链接:是获取类或接口并把它结合到JVM的运行时状态中,以让类或接口可以被执行 初始化 ...
- 时间转换c#
简要 本篇文章主要介绍基于.net(c#)封装的时间帮助类.主要功能是将时间戳与DateTime类型相互转换. 1.其中包括将毫秒级时间戳(13位).秒级时间戳(10位)转换为DateTime. 2. ...
- 表格取消全选框,用文字表示--Echarts ElementUi
1.先看看实现的图 一. 添加添加复选框列 <el-table v-loading="zongShipLoading" tooltip-effect="dark&q ...
- Springboot-Mybatis-进阶
目录 数据库关系 ResultMap association collection 动态sql if where set choose foreach 缓存 一级缓存 二级缓存 开启二级缓存 配置 异 ...
