多语言展示
当前在线:1354今日阅读:20今日分享:50

js 画布 Canvas 时钟实例

先绘制建静态时钟,然后通过时间间隔函数来实现动态效果.
工具/原料
1

源码:https://pan.baidu.com/s/1R12MwZYs0OJw3OWKsc8WNw

2

样本:http://js.zhuamimi.cn/shizhong/

方法/步骤
1

绘制圆盘arc 方法:来构造圆形,其中 起始角设置为 0,结束角设置为 2*Math.PI

2

绘制圆点与绘制圆形是一样的,只不过采用了 fillStyle属性来填充颜色,然后执行fill方法。

3

绘制刻度钟面共有60个刻度 。在圆上绘制刻度,其时也就是求每个刻度的坐标点。公式如下:假设圆心:o (x0,y0)半径:r角度:angle (角度是相对于图中红点位置而言,逆时针为负数,顺时针为正)计算公式:p2 (x1,y1), 其中angle = 30x1 = x0 + r * cos(angle * PI / 180)y1 = y0 + r * sin(angle * PI /180)

4

绘制指针分针与秒针每次转动为6度,时针为30度。 秒针度数:当前秒数 * 6分针度数: 当前分钟 * 6时针的度数为: 当前时间 * 30  + 分针/ 2 。 (分针每次进一位时,时针增加 0.5度)  在转动指针时需要注意1:旋转中心点为:原点(0,0) 可通过translate方法来映射原点位置。2:存在多个旋转时,上一个会影响下一个。这时先采用save方法来保存坐标系状态,转动完后在用restore方法恢复回来。

5

调用实例

推荐信息