Canvas 時鐘數字
第三部分 - 繪制時鐘數字
時鐘需要數字。創建一個 JavaScript 函數來繪制時鐘數字:
JavaScript:
function drawClock() { drawFace(ctx, radius); drawNumbers(ctx, radius); } function drawNumbers(ctx, radius) { ctx.font = radius * 0.15 + "px arial"; ctx.textBaseline = "middle"; ctx.textAlign = "center"; for(let num = 1; num < 13; num++){ let ang = num * Math.PI / 6; ctx.rotate(ang); ctx.translate(0, -radius * 0.85); ctx.rotate(-ang); ctx.fillText(num.toString(), 0, 0); ctx.rotate(ang); ctx.translate(0, radius * 0.85); ctx.rotate(-ang); } }
代碼解釋
將(繪圖對象的)字體大小設置為半徑的 15%:
ctx.font = radius * 0.15 + "px arial";
將文本對齊方式設置為打印位置的中間和中心:
ctx.textBaseline = "middle"; ctx.textAlign = "center";
將打印位置(12 個數字)計算到半徑的 85%,并為每個數字旋轉 (PI/6):
for(num = 1; num < 13; num++) { ang = num * Math.PI / 6; ctx.rotate(ang); ctx.translate(0, -radius * 0.85); ctx.rotate(-ang); ctx.fillText(num.toString(), 0, 0); ctx.rotate(ang); ctx.translate(0, radius * 0.85); ctx.rotate(-ang); }