最新文章专题视频专题问答1问答10问答100问答1000问答2000关键字专题1关键字专题50关键字专题500关键字专题1500TAG最新视频文章推荐1 推荐3 推荐5 推荐7 推荐9 推荐11 推荐13 推荐15 推荐17 推荐19 推荐21 推荐23 推荐25 推荐27 推荐29 推荐31 推荐33 推荐35 推荐37视频文章20视频文章30视频文章40视频文章50视频文章60 视频文章70视频文章80视频文章90视频文章100视频文章120视频文章140 视频2关键字专题关键字专题tag2tag3文章专题文章专题2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章专题3
当前位置: 首页 - 科技 - 知识百科 - 正文

JS+Canvas绘制时钟效果

来源:动视网 责编:小OO 时间:2020-11-27 20:25:31
文档

JS+Canvas绘制时钟效果

1.clock.html。<;,canvas.height/2);//初始化画布 context.save();context.clearRect(0,0,canvas.width,canvas.height);context.translate(canvas.width/2,0);context.lineTo(radius-10,0);} context.stroke();context.restore();context.save();//分钟刻度 context.lineWidth=2;context.beginPath();for(var i=0;i<;60;i++){ if(。i%5==0){ context.moveTo(radius-15,0,0。
推荐度:
导读1.clock.html。<;,canvas.height/2);//初始化画布 context.save();context.clearRect(0,0,canvas.width,canvas.height);context.translate(canvas.width/2,0);context.lineTo(radius-10,0);} context.stroke();context.restore();context.save();//分钟刻度 context.lineWidth=2;context.beginPath();for(var i=0;i<;60;i++){ if(。i%5==0){ context.moveTo(radius-15,0,0。


本文实例为大家分享了使用canvas绘制时钟的具体代码,供大家参考,具体内容如下

1. clock.html

<!doctype html>
<html>
 <head>
 <meta charset="UTF-8">
 <meta name="Description" content="">
 <title>canvas时钟</title>
 </head>
 <body>
 <canvas id="canvas" width="300" height="300"></canvas>
 <script>
 var canvas=document.getElementById("canvas");
 var context=canvas.getContext('2d');
 //draw();
 function draw(){
 //得到当前系统的时分秒
 var now=new Date();
 var sec=now.getSeconds();
 var min=now.getMinutes();
 var hour=now.getHours();
 hour>=12&&(hour=hour-12);
 
 
 var radius = Math.min(canvas.width/2,canvas.height/2);
 //初始化画布
 context.save();
 context.clearRect(0,0,canvas.width,canvas.height);
 context.translate(canvas.width/2,canvas.height/2); 
 context.rotate(-Math.PI/2);
 context.save();
 
 //表框
 
 
 //小时刻度
 context.strokeStyle="black";
 context.fillStyle="black";
 context.lineWidth=3;
 context.lineCap="round";
 context.beginPath();
 for(var i=0;i<12;i++){
 context.rotate(Math.PI/6);
 context.moveTo(radius-30,0);
 context.lineTo(radius-10,0);
 
 }
 context.stroke();
 context.restore();
 context.save();
 
 //分钟刻度
 context.lineWidth=2;
 context.beginPath();
 for(var i=0;i<60;i++){
 if(!i%5==0){
 context.moveTo(radius-15,0);
 context.lineTo(radius-10,0);
 }
 context.rotate(Math.PI/30);
 }
 context.stroke();
 context.restore();
 context.save();
 
 //画上时针
 
 context.rotate((Math.PI/6)*hour+(Math.PI/360)*min+(Math.PI/21600)*sec);
 context.lineWidth=6;
 context.beginPath();
 context.moveTo(-10,0);
 context.lineTo(radius*0.5,0);
 context.stroke();
 context.restore();
 context.save();
 
 context.rotate((Math.PI/30)*min+(Math.PI/1800)*sec);
 context.strokeStyle="#29A8DE";
 context.lineWidth=4;
 context.lineCap="butt";
 context.beginPath();
 context.moveTo(-20,0);
 context.lineTo(radius*0.7,0);
 context.stroke();
 context.restore();
 context.save();
 
 context.rotate(sec*Math.PI/30);
 context.strokeStyle="red";
 context.lineWidth=2;
 context.lineCap="butt";
 context.beginPath();
 context.moveTo(-30,0);
 context.lineTo(radius*0.9,0);
 context.stroke();
 context.restore();
 context.save();
 
 context.lineWidth=4;
 context.strokeStyle="gray";
 context.beginPath();
 context.arc(0,0,radius,0,Math.PI*2,true);
 context.stroke();
 context.restore();
 
 
 context.restore();
 }
 
 window.onload=function(){
 setInterval(draw,1000)
 }
 </script>
 </body>
</html>

2. JavaScript代码

<script>
 var canvas=document.getElementById("canvas");
 var context=canvas.getContext('2d');
 //draw();
 function draw(){
 //得到当前系统的时分秒
 var now=new Date();
 var sec=now.getSeconds();
 var min=now.getMinutes();
 var hour=now.getHours();
 hour>=12&&(hour=hour-12);
 
 
 var radius = Math.min(canvas.width/2,canvas.height/2);
 //初始化画布
 context.save();
 context.clearRect(0,0,canvas.width,canvas.height);
 context.translate(canvas.width/2,canvas.height/2); 
 context.rotate(-Math.PI/2);
 context.save();
 
 //表框
 
 
 //小时刻度
 context.strokeStyle="black";
 context.fillStyle="black";
 context.lineWidth=3;
 context.lineCap="round";
 context.beginPath();
 for(var i=0;i<12;i++){
 context.rotate(Math.PI/6);
 context.moveTo(radius-30,0);
 context.lineTo(radius-10,0);
 
 }
 context.stroke();
 context.restore();
 context.save();
 
 //分钟刻度
 context.lineWidth=2;
 context.beginPath();
 for(var i=0;i<60;i++){
 if(!i%5==0){
 context.moveTo(radius-15,0);
 context.lineTo(radius-10,0);
 }
 context.rotate(Math.PI/30);
 }
 context.stroke();
 context.restore();
 context.save();
 
 //画上时针
 
 context.rotate((Math.PI/6)*hour+(Math.PI/360)*min+(Math.PI/21600)*sec);
 context.lineWidth=6;
 context.beginPath();
 context.moveTo(-10,0);
 context.lineTo(radius*0.5,0);
 context.stroke();
 context.restore();
 context.save();
 
 context.rotate((Math.PI/30)*min+(Math.PI/1800)*sec);
 context.strokeStyle="#29A8DE";
 context.lineWidth=4;
 context.lineCap="butt";
 context.beginPath();
 context.moveTo(-20,0);
 context.lineTo(radius*0.7,0);
 context.stroke();
 context.restore();
 context.save();
 
 context.rotate(sec*Math.PI/30);
 context.strokeStyle="red";
 context.lineWidth=2;
 context.lineCap="butt";
 context.beginPath();
 context.moveTo(-30,0);
 context.lineTo(radius*0.9,0);
 context.stroke();
 context.restore();
 context.save();
 
 context.lineWidth=4;
 context.strokeStyle="gray";
 context.beginPath();
 context.arc(0,0,radius,0,Math.PI*2,true);
 context.stroke();
 context.restore();
 
 
 context.restore();
 }
 
 window.onload=function(){
 setInterval(draw,1000)
 }
 </script>

文档

JS+Canvas绘制时钟效果

1.clock.html。<;,canvas.height/2);//初始化画布 context.save();context.clearRect(0,0,canvas.width,canvas.height);context.translate(canvas.width/2,0);context.lineTo(radius-10,0);} context.stroke();context.restore();context.save();//分钟刻度 context.lineWidth=2;context.beginPath();for(var i=0;i<;60;i++){ if(。i%5==0){ context.moveTo(radius-15,0,0。
推荐度:
标签: js 时钟 绘制
  • 热门焦点

最新推荐

猜你喜欢

热门推荐

专题
Top