JavaScript Canvas绘制圆形时钟效果
网络编程 2021-07-04 18:32www.168986.cn编程入门
这篇文章主要为大家详细介绍了JavaScript Canvas绘制圆形时钟效果的相关资料,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
本文实例为大家分享了Canvas时钟效果展示的具体代码,供大家参考,具体内容如下
<html lang="en"> <head> <meta charset="UTF-8"> <title></title> <style> canvas{ display: block; margin: 0 auto; background-color: #fdffad; border: 1px solid #000; } </style> <script type="text/javascript"> document.addEventListener('DOMContentLoaded',function(){ var oC=document.querySelector('canvas'); var gd=oC.getContext('2d'); var r=oC.width/2; function drawBackground() { gd.save(); //渐变 var ra = gd.createLinearGradient(600, 0, 400, 0); ra.addColorS(1, '#2dd9ff'); ra.addColorS(0, '#8c48dd'); //表盘 gd.translate(r, r); gd.beginPath(); gd.fillStyle = ra; gd.lineWidth = 10; gd.strokeStyle = '#211f4e'; gd.arc(0, 0, r-5, 0, Math.PI 2, false); gd.fill(); gd.stroke(); //数字 for (var i = 1; i < 13; i++) { var rad=i Math.PI 2 / 12; var x = Math.sin(rad)(r-70); var y= -Math.cos(rad)(r-70); gd.fillStyle = "red"; gd.font = "bold 80px Calibri"; gd.lineWidth = 1; gd.textAlign = 'center'; gd.textBaseline = 'middle'; gd.strokeText(i, x, y); } //点 for (var i = 0; i < 60; i++) { gd.beginPath(); var rad=i Math.PI 2 / 60; var x = Math.sin(rad)(r-30); var y= -Math.cos(rad)(r-30); if (i % 5 == 0) { gd.fillStyle = 'red'; } else { gd.fillStyle = '#c' } gd.lineWidth = 2; gd.arc(x, y, 6, 0, Math.PI 2, false); gd.fill(); gd.stroke(); gd.closePath(); } } //时针 function drawHour(h,m){ gd.save(); gd.beginPath(); var rad=2Math.PI/12h; var mrad=2Math.PI/12/60m; gd.rotate(rad+mrad); gd.lineWidth=20; gd.lineCap='round'; gd.moveTo(0,10); gd.lineTo(0,-r/3); gd.stroke(); gd.closePath(); gd.restore(); } //分针 function drawMinutes(m){ gd.save(); gd.beginPath(); var rad=2Math.PI/60m; gd.rotate(rad); gd.lineWidth=10; gd.lineCap='round'; gd.moveTo(0,10); gd.lineTo(0,-r/2); gd.stroke(); gd.closePath(); gd.restore(); } //秒针 function drawSeconds(s){ gd.save(); gd.beginPath(); var rad=2Math.PI/60s; gd.rotate(rad); gd.fillStyle='red'; gd.moveTo(-2,20); gd.lineTo(2,20); gd.lineTo(1,-r+100); gd.lineTo(-1,-r+100); gd.fill(); gd.closePath(); gd.restore(); } //圆点 function drawPoint(){ gd.beginPath(); gd.fillStyle='#fff'; gd.arc(0,0,5,Math.PI2,false); gd.fill(); } function drawClock(){ gd.clearRect(0,0,oC.width,oC.height); var oDate=new Date(); var h=oDate.getHours(); var m=oDate.getMinutes(); var s=oDate.getSeconds(); drawBackground(); drawHour(h,m); drawMinutes(m); drawSeconds(s); drawPoint(); gd.restore(); } drawClock(); setInterval(drawClock,1000); },false); </script> </head> <body> <canvas width="800" height="800"></canvas> </body> </html>
效果图
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持狼蚁SEO。
编程语言
- 如何快速学会编程 如何快速学会ug编程
- 免费学编程的app 推荐12个免费学编程的好网站
- 电脑怎么编程:电脑怎么编程网咯游戏菜单图标
- 如何写代码新手教学 如何写代码新手教学手机
- 基础编程入门教程视频 基础编程入门教程视频华
- 编程演示:编程演示浦丰投针过程
- 乐高编程加盟 乐高积木编程加盟
- 跟我学plc编程 plc编程自学入门视频教程
- ug编程成航林总 ug编程实战视频
- 孩子学编程的好处和坏处
- 初学者学编程该从哪里开始 新手学编程从哪里入
- 慢走丝编程 慢走丝编程难学吗
- 国内十强少儿编程机构 中国少儿编程机构十强有
- 成人计算机速成培训班 成人计算机速成培训班办
- 孩子学编程网上课程哪家好 儿童学编程比较好的
- 代码编程教学入门软件 代码编程教程