×

Canvas应用:实现最简单的挂钟效果

作者:cidy20172021.02.08来源:Web前端之家浏览:4729评论:0
关键词:jscanvas

Canvas应用:实现最简单的挂钟效果。废话不多说,直接上DEMO。

<html>
 <head>
 <meta charset="UTF-8">
 <title>Canvas应用:实现最简单的挂钟效果 | Web前端之家https://jiangweishan.com/</title>
 </head>
 <body>
 <canvas id = "canvas"></canvas>
 
 <script type="text/javascript" >
    var canvas,context;
    function draw(){//定义划时钟的方法
     var data = new Date();
     var hHoure = data.getHours();
     var mMin = data.getMinutes();
     var sSec = data.getSeconds();
     var hValue = (hHoure*30+mMin/2-90)*Math.PI/180; 
     var mValue = (mMin*6-90)*Math.PI/180;
     var sValue = (sSec*6 -90)*Math.PI/180;
     var x = 200,y = 200,r = 150;
     
     context.clearRect(0,0,canvas.width,canvas.height);
     context.moveTo(x,y);
     context.arc(x,y,r,0,6*Math.PI/180,false);
     //
     context.beginPath();
     context.lineWidth = 1;
     for(var i = 0;i<60;i++){
     context.moveTo(x,y);
     context.arc(x,y,r,6*i*Math.PI/180,6*(i+1)*Math.PI/180,false);
     }
     context.closePath();
     context.stroke();
     //
     context.beginPath();
     context.fillStyle = "white";
     context.moveTo(x,y);
     context.arc(x,y,r/1.1,-0,2*Math.PI,false);
     context.closePath();
     context.fill();
     // 
     context.beginPath();
     context.lineWidth = 3;
     for(var i = 0;i<12;i++){
     context.moveTo(x,y);
     context.arc(x,y,r,30*i*Math.PI/180,30*(i+1)*Math.PI,false);
     }
     context.closePath();
     context.stroke();
     //
     context.beginPath();
     context.fillStyle = "white";
     context.moveTo(x,y);
     context.arc(x,y,r/1.12,0,2*Math.PI,false);
     context.closePath();
     context.fill();
     
     context.beginPath();
     context.fillStyle = "black";
     context.moveTo(x,y);
     context.arc(x,y,r/30,0,2*Math.PI,false);
     context.fill(); 
     //
     context.beginPath();
     context.lineWidth = 5;
     context.moveTo(x,y);
     context.arc(x,y,r/2.5,hValue,hValue,false);
     context.stroke();
     //
     context.beginPath();
     context.lineWidth = 3;
     context.moveTo(x,y);
     context.arc(x,y,r/2,mValue,mValue,false);
     context.stroke(); 
     //
     context.beginPath();
     context.lineWidth = 2;
     context.moveTo(x,y);
     context.arc(x,y,r/1.6,sValue,sValue,false);
     context.stroke();
    }
    window.onload = function(){
     canvas = document.getElementById('canvas');
     context = canvas.getContext('2d');
     canvas.height = 500;
     canvas.width = 500;
     setInterval(draw,1000); 
     draw(); 
    }
 </script>
 </body>
</html>

试试吧!!!!

您的支持是我们创作的动力!
温馨提示:本文作者系 ,经Web前端之家编辑修改或补充,转载请注明出处和本文链接:
https://jiangweishan.com/article/js20210208a2.html

网友评论文明上网理性发言 已有0人参与

发表评论: