캔버스 시계 숫자


파트 III - 시계 번호 그리기

시계에는 숫자가 필요합니다. 시계 번호를 그리는 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);
  }
}


예시 설명

(그리기 개체의) 글꼴 크기를 반경의 15%로 설정합니다.

ctx.font = radius * 0.15 + "px arial";

텍스트 정렬을 인쇄 위치의 중앙과 중앙으로 설정합니다.

ctx.textBaseline = "middle";
ctx.textAlign = "center";

각 숫자에 대해 회전된(PI/6) 반경의 85%까지 인쇄 위치(12개 숫자의 경우)를 계산합니다.

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);
}