两种方式实际上在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();
}
acr(x,y,rad,起始弧度,终止弧度,旋转方向)   x,y是圆心坐标 , rad是半径,false就是顺时针(默认),true为逆时针,要注意的是每次画线的时候是移动画布中心到250,250,这个坐标可以自己设定。画线必须要在beginPath和closePath里面,且最后设定为fill还是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做的时钟

 
2、 css3中transform的时钟设计
  这种方法设计最重要的还是html中的布局。 
<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做出钟表的效果的更多相关文章

  1. 实用CSS3的transform实现多种动画效果

    查看效果:http://keleyi.com/a/bjad/b6x9q8gs.htm 以下是代码: <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4. ...

  2. HTML5之CSS3 3D transform 剖析式学习之一

    最近坐地铁发现“亚洲动物基金”在地铁上做了很多公益广告,比较吸引人的是一个月熊的广告.做的很可爱.回去就搜了一下,发现这个网站是HTML5做的,非常炫. 所以想学习一下,方法就是传统的学习办法,模仿. ...

  3. CSS3属性transform详解之(旋转:rotate,缩放:scale,倾斜:skew,移动:translate)

    CSS3属性transform详解之(旋转:rotate,缩放:scale,倾斜:skew,移动:translate)   在CSS3中,可以利用transform功能来实现文字或图像的旋转.缩放.倾 ...

  4. 用CSS3的transform来做一个立方体

    有一次上数据结构课老师布置了一个用队列的思想通过js和Html来做一个“跳舞配对”的网页,当时那个跳舞的部分用了css3里面transform的相关属性做了个个让图片无限翻转的效果,可能正是由于这个效 ...

  5. 好吧,CSS3 3D transform变换,不过如此!

    一.写在前面的秋裤 早在去年的去年,我就大肆介绍了2D transform相关内容.看过海贼王的都知道,带D的家伙都不是好惹的,2D我辈尚可以应付,3D的话,呵呵,估计我等早就在千里之外被其霸气震晕了 ...

  6. css3 变形(transform)、转换(transition)和动画(animation)

    http://www.w3cplus.com/content/css3-transform/  在CSS3中transform主要包括以下几种:旋转rotate.扭曲skew.缩放scale和移动tr ...

  7. CSS3 2D Transform

    在 一个二维或三维空间,元素可以被扭曲.移位或旋转.只不过2D变形工作在X轴和Y轴,也就是大家常说的水平轴和垂直轴:而3D变形工作在X轴和Y轴之外, 还有一个Z轴.这些3D变换不仅可以定义元素的长度和 ...

  8. CSS3 3D Transform

    CSS3 3D Transform 原文:http://www.w3cplus.com/css3/css3-3d-transform.html 三维变换使用基于二维变换的相同属性,如果您熟悉二维变换, ...

  9. css3之transform的应用

    一.利用transform实现图片额外显示 效果图如下 初始状态:

随机推荐

  1. unity探索者之socket传输protobuf字节流(四)

    版权声明:本文为原创文章,转载请声明http://www.cnblogs.com/unityExplorer/p/7027659.html 上篇已经把socket的传输说的差不多了,这篇主要是说说断线 ...

  2. 精讲响应式webclient第1篇-响应式非阻塞IO与基础用法

    笔者在之前已经写了一系列的关于RestTemplate的文章,如下: 精讲RestTemplate第1篇-在Spring或非Spring环境下如何使用 精讲RestTemplate第2篇-多种底层HT ...

  3. ucore学习

    1.启动操作系统的bootloader,用于了解操作系统启动前的状态和要做的准备工作,了解运行操作系统的硬件支持,操作系统如何加载到内存中,理解两类中断--"外设中断"," ...

  4. Goland远程连接Linux开发调试

    参考链接: https://blog.csdn.net/huwh_/article/details/77879152?utm_source=blogxgwz3 https://baijiahao.ba ...

  5. dcoker 小应用(一)

    docker 创建Ubuntu系统 1.创建Dockerfile #ubuntu:14.04 image FROM ubuntu:14.04 MAINTAINER XXX, xxx@xxx.com R ...

  6. Kernel methods on spike train space for neuroscience: a tutorial

    郑重声明:原文参见标题,如有侵权,请联系作者,将会撤销发布! 时序点过程:http://www.tensorinfinity.com/paper_154.html Abstract 在过去的十年中,人 ...

  7. CSS动画实例:圆的涟漪扩散

    设页面中有<div class="circle "></div>,定义.circle的样式规则绘制一个半径为75px,边框厚度为4px的圆,再定义关键帧,使 ...

  8. 洛谷 P3951 NOIP 2017 小凯的疑惑

    洛谷 P3951 NOIP 2017 小凯的疑惑 题目描述 小凯手中有两种面值的金币,两种面值均为正整数且彼此互素.每种金币小凯都有 无数个.在不找零的情况下,仅凭这两种金币,有些物品他是无法准确支付 ...

  9. drf中View和router的详解

    Rest Framework 视图和路由 因为涉及到视图层面了,而且下面的例子会反复用到request.data,所以我决定带大家稍微看下源码,感兴趣的可以自己深入了解 无论是View还是APIVie ...

  10. vue-x和axios的学习

    axios的使用 使用原因:因为vue本身就带有处理dom的功能,不希望再有其他操作dom的插件,所以用axios代替了jquery 功能:发送xhr请求 下载: $ npm install axio ...