这个时钟是将钟盘的圆心点移到了 canvas 画布中心点。以方便后面的方位计算
ctx.translate(width/2,height/2);
现定义一个圆盘来显出这个时钟的基本位置
我在这里面添加了线性渐变来改变颜色,如果感觉颜色太过绚丽可以注释掉不写。
var grd1 = ctx.createLinearGradient(0,r); var r3 = Math.floor(Math.random()*256); var g3 = Math.floor(Math.random()*256); var b3 = Math.floor(Math.random()*256); grd1.addColorStop(0," + b0 + ")"); grd1.addColorStop(1,"rgb(" + r3 + "," + g3 + "," + b3 + ")");
然后利用到了三角函数原理来计算出钟表中刻度的位置;
var x = Math.cos(Math.PI/6*i)*(r-30); var y = Math.sin(Math.PI/6*i)*(r-30);
然后通过计算来显示出时刻和刻度的分布位置
<span style="color: #0000ff;">for(<span style="color: #0000ff;">var j =0;j < 60;j ++<span style="color: #000000;">){
<span style="color: #0000ff;">var x = Math.cos(Math.PI/30j)(r-15);
<span style="color: #0000ff;">var y = Math.sin(Math.PI/30j)(r-15);
<span style="color: #000000;"> ctx.beginPath();
ctx.arc(x,y,2,<span style="color: #0000ff;">false<span style="color: #000000;">);
<span style="color: #0000ff;">var grd1 = ctx.createLinearGradient(0,r);
<span style="color: #0000ff;">var r3 = Math.floor(Math.random()256<span style="color: #000000;">);
<span style="color: #0000ff;">var g3 = Math.floor(Math.random()256<span style="color: #000000;">);
<span style="color: #0000ff;">var b3 = Math.floor(Math.random()*256<span style="color: #000000;">);
grd1.addColorStop(0," + b0 + ")"<span style="color: #000000;">);
grd1.addColorStop(1," + b3 + ")"<span style="color: #000000;">);
ctx.fillStyle =<span style="color: #000000;"> grd1;
ctx.fill();
}
ctx.closePath();
}
接下来就是时针、分针和秒针在这里值得一提的是,秒针在移动的时候是带着分针和时针一起转动的,所以在计算时针的转动角度时,要把分针的也计算在一起,不过分针的计算角度要更新下
var HOUR = Math.PI/6*hour; var MINU = Math.PI/6/60*minu;
同样的在计算分针时,要带上秒针
var MINU = Math.PI/30*minu; var SECON = Math.PI/1800*secon;
这样,我们在运行时,就可以看出,分针和时针都是不停的在运转的
<span style="color: #0000ff;">function<span style="color: #000000;"> timm(minu,secon){
ctx.save();
ctx.beginPath();
ctx.lineWidth = 3<span style="color: #000000;">;
<span style="color: #0000ff;">var MINU = Math.PI/30minu;
<span style="color: #0000ff;">var SECON = Math.PI/1800secon;
ctx.rotate(MINU+<span style="color: #000000;">SECON);
ctx.moveTo(0,-r+50<span style="color: #000000;">);
ctx.lineCap = "round"<span style="color: #000000;">;
<span style="color: #0000ff;">var grd4 = ctx.createLinearGradient(0,r);
<span style="color: #0000ff;">var r4 = Math.floor(Math.random()256<span style="color: #000000;">);
<span style="color: #0000ff;">var g4 = Math.floor(Math.random()256<span style="color: #000000;">);
<span style="color: #0000ff;">var b4 = Math.floor(Math.random()*256<span style="color: #000000;">);
grd4.addColorStop(0,"rgb(" + r4 + "," + g4 + "," + b4 + ")"<span style="color: #000000;">);
grd4.addColorStop(1," + b0 + ")"<span style="color: #000000;">);
ctx.strokeStyle =<span style="color: #000000;"> grd4;
ctx.stroke();
ctx.restore();
}
<span style="color: #008000;">//<span style="color: #008000;"> 秒钟
<span style="color: #0000ff;">function<span style="color: #000000;"> tims(secon){
ctx.save();
ctx.beginPath();
<span style="color: #0000ff;">var SECON = Math.PI/30*secon;
<span style="color: #000000;"> ctx.rotate(SECON);
ctx.fillStyle = "red"<span style="color: #000000;">
ctx.moveTo(-2,20<span style="color: #000000;">);
ctx.lineTo(2,20<span style="color: #000000;">);
ctx.lineTo(1,-r+20<span style="color: #000000;">);
ctx.lineTo(-1,-r+20<span style="color: #000000;">);
ctx.closePath();
ctx.fill();
ctx.restore();
}
在最后为了真实一点,在钟盘中心增加一个固定
最后在添加无限定时器运转
fun();
timh(hour,minu);
timm(minu,secon);
tims(secon);
ding();
ctx.restore();
}setInterval(cleann,</span>1000);</pre>