Số đồng hồ canvas
Phần III – Vẽ số đồng hồ
Đồng hồ cần số. Tạo hàm JavaScript để vẽ số đồng hồ:
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);
}
}
Hãy tự mình thử »Ví dụ giải thích
Đặt kích thước phông chữ (của đối tượng vẽ) thành 15% bán kính:
ctx.font = radius * 0.15 + "px arial";
Đặt căn chỉnh văn bản ở giữa và giữa vị trí in:
ctx.textBaseline = "middle";
ctx.textAlign = "center";
Tính toán vị trí in (cho 12 số) đến 85% bán kính, xoay (PI/6) cho mỗi số:
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);
}