Numeri di orologio su tela
Parte III - Disegna i numeri dell'orologio
L'orologio ha bisogno di numeri. Crea una funzione JavaScript per disegnare i numeri dell'orologio:
JavaScript:
function drawClock() {
drawFace(ctx, radius);
drawNumbers(ctx, radius);
}
function drawNumbers(ctx, radius) {
var ang;
var num;
ctx.font = radius * 0.15 + "px arial";
ctx.textBaseline = "middle";
ctx.textAlign = "center";
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);
}
}
Esempio spiegato
Imposta la dimensione del carattere (dell'oggetto di disegno) al 15% del raggio:
ctx.font = radius * 0.15 + "px arial";
Imposta l'allineamento del testo al centro e al centro della posizione di stampa:
ctx.textBaseline = "middle";
ctx.textAlign = "center";
Calcola la posizione di stampa (per 12 numeri) all'85% del raggio, ruotato (PI/6) per ogni numero:
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);
}