分别用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实现图片额外显示 效果图如下 初始状态:
随机推荐
- CallStub相关
CallStub相关 调用入口 share/vm/runtime/stubRoutines.hpp // Calls to Java SimonNote: 函数指针结合typedef类型定义 type ...
- JDBC | 第一章: 快速开始使用JDBC连接Mysql数据库?
开始使用基于java的JDBC技术来连接mysql进行msyql数据库简单的CRUD操作 下载对应mysql驱动包 这里我创建maven项目基于maven下载 <!--mysql 驱动--> ...
- ES7异步函数解决进程等待相关业务问题
业务需求场景描述: 在接口只能单一检测的情况下,批量检测资源名称是否存在数据库,如果资源群中某一个资源已存在:给出交互让用户决定是否覆盖资源,最后形成不存在的资源和用户确定覆盖的资源群,进行提交. 业 ...
- springMVC入门(六)------json交互与RESTFul风格支持
简介 JSON(JavaScript Object Notation) 是一种轻量级的数据交换格式.由于其简单易用,目前常用来通过AJAX与后台进行交互.springMVC对于接收.发送JSON数据也 ...
- Selenium的WebDriver API元素定位中的XPath和CSS
元素的定位和操作是自动化测试的核心部分,其中操作又是建立在定位的基础上的. 浏览器的常规操作 import time from selenium import webdriver # 打开浏览器 dr ...
- asp.net报表结构学习记录
当一份web报表项目压缩包躺在我的文件夹里时,我是完全懵的.作为一个学习了一个月java的asp.net小白,以前从来没有接触过这方面,我完全不知道从何入手. 手里也有asp.net开发学习视频,但都 ...
- Python测试函数运行时间
import time import datetime # 测试函数运行时间 def cal_time(fn): """计算性能的修饰器""" ...
- Min Cost Climbing Stairs [746]
Min Cost Climbing Stairs [746] 题目描述 简单来说就是:要跳过当前楼梯需要花费当前楼梯所代表的价值cost[i], 花费cost[i]之后,可以选择跳一阶或者两阶楼梯,以 ...
- 那些jdk中坑你没商量的方法
前言:jdk作为我们每天必备的调用类库,里面大量提供了基础类供我们使用.可以说离开jdk,我们的java代码寸步难行,jdk带给我们的便利可谓是不胜枚举,但同时这些方法在使用起来也存在一些坑,如果不注 ...
- 大数据计算的基石——MapReduce
MapReduce Google File System提供了大数据存储的方案,这也为后来HDFS提供了理论依据,但是在大数据存储之上的大数据计算则不得不提到MapReduce. 虽然现在通过框架的不 ...
