Canvas Clock Numbers
Part III - Draw Clock Numbers
時鐘需要數字。建立一個 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);
}