为什么我和老四显示的不一样啊 js文件 html文件没有问题

来源:3-3 Canvas静态的时分秒

Freen247

2017-03-26 10:06

var dom=document.getElementById('clock');
var ctx=dom.getContext("2d");
var width = ctx.canvas.width;
var height = ctx.canvas.height;
var r=width / 2;


function drawBackground(){
    ctx.translate(r, r);
    ctx.beginPath();
    ctx.lineWidth= 10;
    ctx.arc(0,0,r-5,0,2*Math.PI,false)
    ctx.stroke();

    var hourNumbers= [3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 1, 2];
    ctx.font='18px Arial';
    ctx.textAlign='center';
    ctx.textBaseline='middle';
    hourNumbers.forEach(function(number, i)
        {
            var rad=2 * Math.PI / 12 * i;
            var x=Math.cos(rad) * ( r - 30 );
            var y=Math.sin(rad) * ( r - 30 );
            ctx.fillText(number,x,y);
        });

    for (var i=0;i<60;i++){
        var rad=2 * Math.PI / 60 * i;
        var x=Math.cos(rad) * ( r - 18);
        var y=Math.sin(rad) * ( r - 18);
        ctx.beginPath();
        if(i % 5 === 0){
            ctx.fillStyle='#000';
            ctx.arc(x,y,2,0,2*Math.PI,false);
        }else{
            ctx.fillStyle='#ccc';
            ctx.arc(x,y,2,0,2*Math.PI,false);
            
         }
        ctx.fill();
    }
}
function drawHour(hour,minute){
    ctx.save();
    ctx.beginPath();
    var rad=2 * Math.PI / 12 * hour;
    var mrad=2 * Math.PI / 12 /60* minute;
    ctx.rotate(rad+mrad);
    ctx.lineWidth=6;
    ctx.lineCap='round';
    ctx.moveTo(0,10);
    ctx.lineTo(0,-r/2);
    ctx.stroke();
    ctx.restore;
}
function drawMinute(minute){
    ctx.save();
    ctx.beginPath();
    var rad=2 * Math.PI / 60 * minute;
    ctx.rotate(rad);
    ctx.lineWidth=3;
    ctx.lineCap='round';
    ctx.moveTo(0,10);
    ctx.lineTo(0,-r + 35);
    ctx.stroke();
    ctx.restore;
}
function drawSecond(second){
    ctx.save();
    ctx.beginPath();
    var rad=2 * Math.PI / 60 * second;
    ctx.rotate(rad);
    ctx.moveTo(-2,20);
    ctx.lineTo(2,20);
    ctx.lineTo(1,-r+18);
    ctx.lineTo(-1,-r+18);
    ctx.fill();
    ctx.restore;
}
function drawPoint(){
    ctx.beginPath();
    ctx.fillStyle='#cc0';
    ctx.arc(0,0,3,0,2*Math.PI,false);
    ctx.fill();
}
drawBackground();
drawHour(4,30);
drawMinute(30);
drawSecond(15);
drawPoint();

写回答 关注

1回答

  • 慕粉4296081
    2017-03-26 13:18:13
    已采纳

    每个ctx.restore()语句一定要加后面的'()', 不然js不能识别它为canvas的方法

    试了下应该是这个问题

    Freen2...

    非常感谢!

    2017-03-26 16:02:58

    共 1 条回复 >

Canvas 绘制时钟

canvas画出漂亮的时钟,通过本教程能重新掌握一些几何知识

49750 学习 · 160 问题

查看课程

相似问题