一区二区三区在线-一区二区三区亚洲视频-一区二区三区亚洲-一区二区三区午夜-一区二区三区四区在线视频-一区二区三区四区在线免费观看

服務器之家:專注于服務器技術及軟件下載分享
分類導航

node.js|vue.js|jquery|angularjs|React|json|js教程|

服務器之家 - 編程語言 - JavaScript - javascript canvas封裝動態時鐘

javascript canvas封裝動態時鐘

2021-10-20 14:14藍色之戀love JavaScript

這篇文章主要為大家詳細介紹了javascript canvas封裝動態時鐘,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下

本文實例為大家分享了canvas封裝動態時鐘的具體代碼,供大家參考,具體內容如下

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
<!DOCTYPE html>
<html lang="en">
 
<head>
 <meta charset="UTF-8">
 <meta name="viewport" content="width=device-width, initial-scale=1.0">
 <title>canvas繪制動態時鐘</title>
 <style>
 #clock {
  display: block;
  margin: 30px auto;
 }
 </style>
</head>
 
<body>
 <canvas id="clock" width="200" height="200"></canvas>
 <script>
 
 function canvasClock(canvasClockObj) {
  return (function (canvasClockObj) {
  var ctx = canvasClockObj.dom.getContext('2d')
  let width = ctx.canvas.width
  let height = ctx.canvas.height
  let r = width > height ? height / 2 : width / 2
 
  // 繪制背景板
  function drawBackground() {
   // 繪制外圈圓環
   ctx.save() // 每次開始前都要保存當前畫布狀態,以免移動畫布影響后續繪制
   ctx.translate(r, r) // 設置起始點為圓心
   ctx.beginPath() // 每次開始繪制前必須開始一條路徑
   ctx.lineWidth = 10 // 設置繪線的寬度
   ctx.strokeStyle = canvasClockObj.outerRing
   ctx.arc(0, 0, r - ctx.lineWidth / 2, 0, 2 * Math.PI, false) // 畫一個整圓
   ctx.stroke() // 對圓進行描邊
   ctx.strokeStyle = '#000'
   // 繪制分鐘 和 小時
   var minuteNumbers = [1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15, 16, 17, 18, 19, 20, 21, 22, 23, 24, 25, 26, 27, 28, 29, 30, 31, 32, 33, 34, 35, 36, 37, 38, 39, 40, 41, 42, 43, 44, 45, 46, 47, 48, 49, 50, 51, 52, 53, 54, 55, 56, 57, 58, 59, 60]
   minuteNumbers.map(function (number, i) {
   var rad = 2 * Math.PI / 60 * i
   var x = Math.cos(rad) * (r - 17) // 獲取每分鐘的x軸坐標
   var y = Math.sin(rad) * (r - 17) // 獲取每分鐘的y軸坐標
   ctx.beginPath() // 每次開始繪制前必須開始一條路徑
   ctx.fillStyle = '#ccc'
   ctx.arc(x, y, 2, 0, 2 * Math.PI, false)
   ctx.fill()
   })
   var hourNumbers = [3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 1, 2]
   hourNumbers.map(function (number, i) {
   var rad = 2 * Math.PI / 12 * i
   var x = Math.cos(rad) * (r - 30)
   var y = Math.sin(rad) * (r - 30)
   var x1 = Math.cos(rad) * (r - 17)
   var y1 = Math.sin(rad) * (r - 17)
   ctx.beginPath() // 每次開始繪制前必須開始一條路徑
   ctx.fillStyle = canvasClockObj.hourColor ? canvasClockObj.hourColor :'#000' // 設置 小時的顏色
   ctx.textAlign = 'center' // 使文字左右居中
   ctx.textBaseline = 'middle' // 使文字上下居中
   ctx.font = 14 + 'px Arial'
   ctx.fillText(number, x, y)
   ctx.arc(x1, y1, 2, 0, 2 * Math.PI, false)
   ctx.fill()
   })
  }
  drawBackground()
 
  // 繪制圓心
  function drawDot() {
   ctx.beginPath()
   ctx.fillStyle = '#fff'
   ctx.lineWidth = 1
   ctx.arc(0, 0, 3, 2 * Math.PI, false)
   ctx.fill()
  }
  // 繪制時針
  function drawHour(hour, minute) {
   ctx.save()
   ctx.beginPath()
   var hrad = Math.PI / 12 * hour * 2
   var mrad = Math.PI / 12 / 60 * minute * 2
   ctx.rotate(hrad + mrad)
   ctx.lineWidth = 4
   ctx.moveTo(0, 10)
   ctx.lineTo(0, -r / 2.5)
   ctx.lineCap = 'round'
   ctx.stroke()
   ctx.restore()
  }
  // 繪制分針
  function drawMinute(minute, second) {
   ctx.save()
   ctx.beginPath()
   var mrad = Math.PI / 60 * minute * 2
   var srad = Math.PI / 60 / 60 * second * 2
   ctx.rotate(srad + mrad)
   ctx.lineWidth = 0.5
   ctx.lineJoin = 'round'
   ctx.fillStyle = '#000'
   ctx.moveTo(2, 10)
   ctx.lineTo(0, -r / 1.7)
   ctx.lineTo(-2, 10)
   ctx.lineTo(2, 10)
   ctx.lineCap = 'round'
   ctx.fill()
   ctx.restore()
  }
  // 繪制秒針
  function drawSecond(second) {
   ctx.save()
   ctx.beginPath()
   var srad = Math.PI / 30 * second
   ctx.rotate(srad)
   ctx.lineWidth = 0.5
   ctx.lineJoin = 'round'
   ctx.fillStyle = canvasClockObj.secondHand ? canvasClockObj.secondHand : '#f00'
   ctx.moveTo(2, 10)
   ctx.lineTo(0, -r / 1.2)
   ctx.lineTo(-2, 10)
   ctx.lineTo(2, 10)
   ctx.lineCap = 'round'
   ctx.fill()
   ctx.restore()
  }
  // 使指針動起來
  function draw() {
   ctx.translate(-r, -r)
   ctx.clearRect(0, 0, width, height)
   var now = new Date()
   var hour = now.getHours()
   var minute = now.getMinutes()
   var second = now.getSeconds()
   drawBackground()        //繪制圓盤背景
   drawHour(hour, minute);       //繪制時針
   drawMinute(minute,second);        //繪制分針
   drawSecond(second);        //繪制秒針
   drawDot();           //繪制原點
  }
  draw()
  setInterval(draw, 1000);
  })(canvasClockObj)
 }
 canvasClock({
  dom:document.getElementById('clock'), // 必填項: canvas節點
  // outerRing:'purple', // 外圈圓環顏色 默認值: #000
  // hourColor:'skyblue', // 小時的顏色 默認值 #000
  // secondHand:'yellow' // 秒針的顏色 默認值: #f00
 })
 </script>
</body>
 
</html>

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持服務器之家。

原文鏈接:https://blog.csdn.net/raingrains/article/details/108865461

延伸 · 閱讀

精彩推薦
主站蜘蛛池模板: 久久久久久久久女黄 | 男人天堂国产 | 国产麻豆成91 | 日本漫画大全之工之口 | 男人捅女人漫画 | 欧美一区二区三区高清不卡tv | 国产情侣自拍网 | 精品精品国产自在久久高清 | 舔大逼 | 久久精品成人免费网站 | 亚洲欧美专区精品伊人久久 | 暖暖 免费 高清 日本 在线 | 欧美xxx000喷水 | 海角社区在线视频 | 天堂中文在线免费观看 | 美女的隐私无遮挡撒尿 | 性欧美hd | 国产精品免费综合一区视频 | 久久热在线视频精品1 | 动漫美女胸被狂揉扒开吃奶动态图 | 精品国产福利在线观看一区 | 国产亚洲一欧美一区二区三区 | 午夜AV内射一区二区三区红桃视 | 网址在线观看你懂我意思吧免费的 | www.片| 国产精品最新资源网 | 91porn最新地址 | 亚洲国产成人资源在线桃色 | 狠狠干2017 | 色多多在线视频 | 欧美精品99久久久久久人 | 数学老师扒开腿让我爽快 | 久久国产精品永久免费网站 | 2019中文字幕在线视频 | 国产成人v爽在线免播放观看 | 啪哆哆| 91麻豆国产福利在线观看 | 国产精品亚洲片夜色在线 | 色777777女人色 | 日韩网新片免费 | 538精品视频|