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

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

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一区二区三区 | 亚洲 欧美 中文 日韩 视频 | 好爽好深好猛好舒服视频上 | 公园暴露娇妻小说 | chinesehdxxx吃奶水| 久久综合老色鬼网站 | 久久99国产综合精品AV蜜桃 | 久久久久综合 | 69人成网站色www | 亚洲国产日韩欧美一区二区三区 | 99精品在免费线视频 | 91精品91 | 操动漫美女视频 | 色综合网亚洲精品久久 | 青青在线视频免费 | 免费看日产一区二区三区 | 色悠久久久久综合欧美99 | 小柔的性放荡羞辱日记动漫 | 亚拍一区 | 91欧美国产 | 亚洲高清中文字幕精品不卡 | 大片毛片女女女女女女女 | 国产精品久久久久久网站 | 色伦网| 日韩欧美不卡视频 | 国产亚洲女在线精品 | 亚洲 综合 自拍 精品 在线 | 美国复古性经典xxxxx | 99久久精品免费精品国产 | 顶级欧美做受xxx000 | 青草青草视频 | 色婷婷婷丁香亚洲综合不卡 | 青苹果乐园影院免费观看完整版 | japanhd粗暴video| 精品人人做人人爽久久久 | 国产精品四虎在线观看免费 | 欧美区在线 | 欧美日韩精品免费一区二区三区 |