canvas绘制表盘时钟

发布时间 - 2026-01-10 22:44:54    点击率:

话不多说,请看代码:

<!DOCTYPE html>
<html lang="en">
<head>
 <meta charset="UTF-8">
 <title>canvas绘制表盘</title>
</head>
<body>
 <canvas id='box' width="500" height="500" >
 您的浏览器不支持canvas
 </canvas>
 <script>
 var box = document.getElementById('box');
 var cxt = box.getContext('2d');
 // 时钟动起来
 var timer = null;
 function clock(){
 var date = new Date();
 var h = date.getHours();
 h = h + h/60;
 h = h>12? h-12:h;
 var m = date.getMinutes();
 var s = date.getSeconds();
 // 清画布
 cxt.clearRect(0,0,500,500); 
 // 画表盘
 cxt.strokeStyle = '#f0f';
 cxt.lineWidth = 6;
 cxt.beginPath();
 cxt.arc(250,250,100,0,2*Math.PI);
 cxt.stroke();
 // 画时钟刻度
 for(var i=0; i<12; i++){
 cxt.save();
 cxt.translate(250,250);
 cxt.rotate(30*i*Math.PI/180);
 cxt.lineWidth = 3;
 cxt.beginPath();
 cxt.moveTo(0,-80);
 cxt.lineTo(0,-92);
 cxt.stroke();
 cxt.restore();
 }
 //画分钟刻度
 for(var i=0; i<60; i++){
 cxt.save();
 cxt.translate(250,250);
 cxt.rotate(6*i*Math.PI/180);
 cxt.lineWidth = 2;
 cxt.beginPath();
 cxt.moveTo(0,-86);
 cxt.lineTo(0,-92);
 cxt.stroke();
 cxt.restore();
 }
 // 画时针
 cxt.save();
 cxt.lineWidth = 5;
 cxt.translate(250,250);
 cxt.rotate(h*30*Math.PI/180);
 cxt.beginPath();
 cxt.moveTo(0,6);
 cxt.lineTo(0,-40);
 cxt.stroke();
 cxt.restore();
 // 画分针
 cxt.save();
 cxt.lineWidth = 3;
 cxt.translate(250,250);
 cxt.rotate(m*6*Math.PI/180);
 cxt.beginPath();
 cxt.moveTo(0,8);
 cxt.lineTo(0,-60);
 cxt.stroke();
 cxt.restore();
 // 画秒针
 cxt.save();
 cxt.lineWidth = 1;
 cxt.translate(250,250);
 cxt.rotate(s*6*Math.PI/180);
 cxt.beginPath();
 cxt.moveTo(0,10);
 cxt.lineTo(0,-75);
 cxt.stroke();
 cxt.restore();
 // 画中心的小圆固定三根针
 cxt.save();
 cxt.beginPath();
 cxt.fillStyle = '#0f0';
 cxt.lineWidth = 2;
 cxt.translate(250,250);
 cxt.arc(0,0,2,0,360,false);
 cxt.stroke();
 cxt.fill();
 cxt.restore();
 // 画秒针上的园
 cxt.save();
 cxt.fillStyle = '#f00';
 cxt.lineWidth = 2;
 cxt.translate(250,250);
 cxt.rotate(s*6*Math.PI/180);
 cxt.beginPath();
 cxt.arc(0,-60,2,0,360,false);
 cxt.stroke();
 cxt.fill();
 cxt.restore();
 }
 clock();
 timer = setInterval(clock,1000);
 </script>
</body>
</html>

以上就是本文的全部内容,希望本文的内容对大家的学习或者工作能带来一定的帮助,同时也希望多多支持!


# canvas  # 绘制  # 时钟  # html5 canvas js(数字时钟)实例代码  # JS+Canvas绘制时钟效果  # vue+canvas实现炫酷时钟效果的倒计时插件(已发布到npm的vue2插件  # 开箱即用)  # js Canvas实现圆形时钟教程  # javascript结合Canvas 实现简易的圆形时钟  # JS+Canvas绘制动态时钟效果  # js+html5实现canvas绘制网页时钟的方法  # JavaScript html5 canvas绘制时钟效果(二)  # JavaScript html5 canvas绘制时钟效果  # JavaScript canvas实现七彩时钟效果  # 小圆  # 您的  # 不支持  # 多说  # 画中  # 三根  # box  # document  # var  # width  # height  # script  # clock  # function  # Date 


相关栏目: 【 网站优化151355 】 【 网络推广146373 】 【 网络技术251813 】 【 AI营销90571


相关推荐: 如何快速上传自定义模板至建站之星?  东莞专业网站制作公司有哪些,东莞招聘网站哪个好?  夸克浏览器网页跳转延迟怎么办 夸克浏览器跳转优化  如何在香港服务器上快速搭建免备案网站?  教你用AI润色文章,让你的文字表达更专业  Win11怎样安装网易有道词典_Win11安装词典教程【步骤】  Laravel如何使用Blade组件和插槽?(Component代码示例)  Laravel如何从数据库删除数据_Laravel destroy和delete方法区别  Angular 表单中正确绑定输入值以确保提交与验证正常工作  手机钓鱼网站怎么制作视频,怎样拦截钓鱼网站。怎么办?  简历没回改:利用AI润色让你的文字更专业  高防服务器租用指南:配置选择与快速部署攻略  Laravel模型事件有哪些_Laravel Model Event生命周期详解  Win11关机界面怎么改_Win11自定义关机画面设置【工具】  Win11怎么设置虚拟桌面 Win11新建多桌面切换操作【技巧】  JavaScript如何实现继承_有哪些常用方法  Gemini手机端怎么发图片_Gemini手机端发图方法【步骤】  胶州企业网站制作公司,青岛石头网络科技有限公司怎么样?  如何在自有机房高效搭建专业网站?  Laravel任务队列怎么用_Laravel Queues异步处理任务提升应用性能  javascript中的try catch异常捕获机制用法分析  浅谈redis在项目中的应用  如何在 Pandas 中基于一列条件计算另一列的分组均值  ChatGPT 4.0官网入口地址 ChatGPT在线体验官网  Python正则表达式进阶教程_复杂匹配与分组替换解析  北京网站制作公司哪家好一点,北京租房网站有哪些?  如何快速查询网站的真实建站时间?  Laravel如何使用Guzzle调用外部接口_Laravel发起HTTP请求与JSON数据解析【详解】  BootStrap整体框架之基础布局组件  Android滚轮选择时间控件使用详解  如何快速生成凡客建站的专业级图册?  悟空浏览器如何设置小说背景色_悟空浏览器背景色设置【方法】  图片制作网站免费软件,有没有免费的网站或软件可以将图片批量转为A4大小的pdf?  Win11怎么开启自动HDR画质_Windows11显示设置HDR选项  电商网站制作价格怎么算,网上拍卖流程以及规则?  为什么php本地部署后css不生效_静态资源加载失败修复技巧【技巧】  Win11搜索栏无法输入_解决Win11开始菜单搜索没反应问题【技巧】  Laravel如何使用集合(Collections)进行数据处理_Laravel Collection常用方法与技巧  如何快速搭建高效WAP手机网站?  米侠浏览器网页背景异常怎么办 米侠显示修复  微信小程序 require机制详解及实例代码  Laravel如何发送邮件和通知_Laravel邮件与通知系统发送步骤  高端建站三要素:定制模板、企业官网与响应式设计优化  html5如何设置样式_HTML5样式设置方法与CSS应用技巧【教程】  如何快速搭建个人网站并优化SEO?  googleplay官方入口在哪里_Google Play官方商店快速入口指南  详解jQuery停止动画——stop()方法的使用  如何撰写建站申请书?关键要点有哪些?  如何在HTML表单中获取用户输入并结合JavaScript动态控制复利计算循环  Laravel Session怎么存储_Laravel Session驱动配置详解