js canvas 转动时钟实例

发布时间:2021-01-07 发布网站:前端之家 F2er.com
前端之家收集整理的这篇文章主要介绍了js canvas 转动时钟实例前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
源码:https://pan.baidu.com/s/1R12MwZYs0OJw3OWKsc8WNw

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

我的百度经验:https://jingyan.baidu.com/article/1974b28935a46bf4b1f774a8.html

js canvas 转动时钟实例

一、绘制圆盘

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

js canvas 转动时钟实例

二、绘制圆点

与绘制圆形是一样的,只不过采用了 fillStyle属性来填充颜色。

三、绘制刻度

钟面共有60个刻度 。

在画上绘制刻度,其时也就是求每个刻度的坐标点。

公式如下:

假设圆心:o (x0,y0)

半径:r

角度:angle (角度是相对于图中红点位置而言,逆时针为负数,顺时针为正)

计算公式:

p2 (x1,y1),其中angle = 30

x1 = x0 + r * cos(angle * PI / 180)

y1 = y0 + r * sin(angle * PI /180)

四、绘制指针

分针与秒针每次转动为6度,时针为30度。

 

秒针度数:当前秒数 * 6

分针度数: 当前分钟 * 6

时针的度数为: 当前时间 * 30  + 分针/ 2 。 (分针每次进一位时,时针增加 0.5度)

 

 

在转动指针时需要注意

1:旋转中心点为:原点(0,0) 可通过translate方法来映射原点位置。

2:存在多个旋转时,上一个会影响下一个。这时先采用save方法来保存坐标系状态,转动完后在用restore方法恢复回来。

五、实例调用

<!DOCTYPE html>
<html>

<head>
    <meta charset="utf8">
    <title>canvas时钟</title>
    <script src="Time.js"></script>
</head>

<body>

    <canvas id="text" height="500" width="500"></canvas>
    <script>
        let element = document.querySelector("#text");
        let canvas = new Panel(element);
        canvas.dot = new Config(8,'red');
        canvas.time();
    </script>
</body>

</html>

 

总结


以上是前端之家为你收集整理的js canvas 转动时钟实例全部内容,希望文章能够帮你解决js canvas 转动时钟实例所遇到的程序开发问题。

如果觉得前端之家网站内容还不错,欢迎将前端之家网站推荐给前端开发程序员好友。

本图文内容来源于网友网络收集整理提供,作为学习参考使用,版权属于原作者。