JS+Canvas绘制动态时钟效果
网络编程 2021-07-04 17:32www.168986.cn编程入门
这篇文章主要为大家详细介绍了JS+Canvas绘制动态时钟效果,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
本文实例为大家分享了Canvas绘制动态时钟效果展示的具体代码,供大家参考,具体内容如下
<!DOCTYPE html> <html> <head> <meta charset="utf-8" /> <title></title> <style> #mycanvas{ position: absolute; left:50%; margin-left:-250px; border:5px solid #fff; box-shadow: 0 0 10px rgba(0,0,0,0.2); background-color: rgb(58, 179, 255); } </style> </head> <body> <!-- canvashtml5新增的画布对象,可以在其中绘制任何的图形,以及线条效果,包括图片 注意canvas的尺寸应该通过元素的属性直接设置,而不是使用样式实现(失帧) --> <canvas id="mycanvas" width="500px" height="500px">您的浏览器太low了,请切换</canvas> <script> //获取画布对象 var mycanvas = document.getElementById('mycanvas'); //获取一个2d绘图环境(拿到一支画笔) var ctx = mycanvas.getContext('2d'); function draw(){ //获取系统时间 var nowTime = new Date(); var hours = nowTime.getHours();//获取时 var minutes = nowTime.getMinutes();//获取分 var seconds = nowTime.getSeconds();//获取秒 //防止小时超过12 hours = hours > 12 ? hours-12 : hours; //精准设置小时值 hours = hours + minutes/60; //清除画布(防止覆盖) ctx.clearRect(0,0,500,500); //初始化画笔的样式 ctx.lineWidth = 5; //设置线条的宽度 ctx.strokeStyle = '#fff'; //设置线条颜色 ctx.beginPath();//开始新的绘图路径 //设置一个圆形路径 ctx.arc(250,250,150,0,360,false); //绘制图形 ctx.stroke(); ctx.closePath();//结束当前绘图路径 //绘制刻度(时刻度) for(var i = 0;i < 12;i++){ ctx.beginPath(); ctx.lineWidth = 10; //保存当前绘图环境 ctx.save(); //重置绘制起始位置(将圆心位置重置为0,0) ctx.translate(250,250); //旋转画布到一定的弧度 弧度=角度PI/180 ctx.rotate(i 30 Math.PI / 180); //设置绘制线条的起始位置 ctx.moveTo(0,140); //设置线条的结束位置 ctx.lineTo(0,150); //绘制路径 ctx.stroke(); //还原初始的绘图环境 ctx.restore(); ctx.closePath(); } //绘制刻度(分刻度) for(var i = 0;i < 60;i++){ ctx.beginPath(); ctx.lineWidth = 3; //保存当前绘图环境 ctx.save(); //重置绘制起始位置(将圆心位置重置为0,0) ctx.translate(250,250); //旋转画布到一定的弧度 弧度=角度PI/180 ctx.rotate(i 6 Math.PI / 180); //设置绘制线条的起始位置 ctx.moveTo(0,142); //设置线条的结束位置 ctx.lineTo(0,146); //绘制路径 ctx.stroke(); //还原初始的绘图环境 ctx.restore(); ctx.closePath(); } /绘制时针/ ctx.beginPath(); ctx.lineWidth = 5; //保存当前绘图环境 ctx.save(); //重置绘制起始位置(将圆心位置重置为0,0) ctx.translate(250,250); //旋转画布到一定的弧度 弧度=角度PI/180 ctx.rotate(hours 30 Math.PI / 180); //设置绘制线条的起始位置 ctx.moveTo(0,10); //设置线条的结束位置 ctx.lineTo(0,-100); //绘制路径 ctx.stroke(); //还原初始的绘图环境 ctx.restore(); ctx.closePath(); /绘制分针/ ctx.beginPath(); ctx.lineWidth = 3; //保存当前绘图环境 ctx.save(); //重置绘制起始位置(将圆心位置重置为0,0) ctx.translate(250,250); //旋转画布到一定的弧度 弧度=角度PI/180 ctx.rotate(minutes 6 Math.PI / 180); //设置绘制线条的起始位置 ctx.moveTo(0,10); //设置线条的结束位置 ctx.lineTo(0,-120); //绘制路径 ctx.stroke(); //还原初始的绘图环境 ctx.restore(); ctx.closePath(); /绘制秒针/ ctx.beginPath(); ctx.lineWidth = 1; ctx.strokeStyle = '#f00'; //保存当前绘图环境 ctx.save(); //重置绘制起始位置(将圆心位置重置为0,0) ctx.translate(250,250); //旋转画布到一定的弧度 弧度=角度PI/180 ctx.rotate(seconds 6 Math.PI / 180); //设置绘制线条的起始位置 ctx.moveTo(0,10); //设置线条的结束位置 ctx.lineTo(0,-135); //绘制路径 ctx.stroke(); //还原初始的绘图环境 ctx.restore(); ctx.closePath(); } setInterval(draw,1000); </script> </body> </html>
更多JavaScript时钟特效点击查看
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持狼蚁SEO。
编程语言
- 如何快速学会编程 如何快速学会ug编程
- 免费学编程的app 推荐12个免费学编程的好网站
- 电脑怎么编程:电脑怎么编程网咯游戏菜单图标
- 如何写代码新手教学 如何写代码新手教学手机
- 基础编程入门教程视频 基础编程入门教程视频华
- 编程演示:编程演示浦丰投针过程
- 乐高编程加盟 乐高积木编程加盟
- 跟我学plc编程 plc编程自学入门视频教程
- ug编程成航林总 ug编程实战视频
- 孩子学编程的好处和坏处
- 初学者学编程该从哪里开始 新手学编程从哪里入
- 慢走丝编程 慢走丝编程难学吗
- 国内十强少儿编程机构 中国少儿编程机构十强有
- 成人计算机速成培训班 成人计算机速成培训班办
- 孩子学编程网上课程哪家好 儿童学编程比较好的
- 代码编程教学入门软件 代码编程教程