如何通过Canvas+JS实现简易的时钟
发表于:2025-01-20 作者:千家信息网编辑
千家信息网最后更新 2025年01月20日,今天就跟大家聊聊有关如何通过Canvas+JS实现简易的时钟,可能很多人都不太了解,为了让大家更加了解,小编给大家总结了以下内容,希望大家根据这篇文章可以有所收获。之前学习了下html5中的canva
千家信息网最后更新 2025年01月20日如何通过Canvas+JS实现简易的时钟
今天就跟大家聊聊有关如何通过Canvas+JS实现简易的时钟,可能很多人都不太了解,为了让大家更加了解,小编给大家总结了以下内容,希望大家根据这篇文章可以有所收获。
之前学习了下html5中的canvas元素,为了练练手就实现了一个简易的时钟。时钟本身并不复杂,也没有使用图片进行美化,不过麻雀虽小五脏俱全,下面就与大家分享一下:
实现效果:
html代码:
Clock
JS代码:
var Canvas = {}; Canvas.cxt = document.getElementById('canvasId').getContext('2d'); Canvas.Point = function(x, y){ this.x = x; this.y = y; }; /*擦除canvas上的所有图形*/ Canvas.clearCxt = function(){ var me = this; var canvas = me.cxt.canvas; me.cxt.clearRect(0,0, canvas.offsetWidth, canvas.offsetHeight); }; /*时钟*/ Canvas.Clock = function(){ var me = Canvas, c = me.cxt, radius = 150, /*半径*/ scale = 20, /*刻度长度*/ minangle = (1/30)*Math.PI, /*一分钟的弧度*/ hourangle = (1/6)*Math.PI, /*一小时的弧度*/ hourHandLength = radius/2, /*时针长度*/ minHandLength = radius/3*2, /*分针长度*/ secHandLength = radius/10*9, /*秒针长度*/ center = new me.Point(c.canvas.width/2, c.canvas.height/2); /*圆心*/ /*绘制圆心(表盘中心)*/ function drawCenter(){ c.save(); c.translate(center.x, center.y); c.fillStyle = 'black'; c.beginPath(); c.arc(0, 0, radius/20, 0, 2*Math.PI); c.closePath(); c.fill(); c.stroke(); c.restore(); }; /*通过坐标变换绘制表盘*/ function drawBackGround(){ c.save(); c.translate(center.x, center.y); /*平移变换*/ /*绘制刻度*/ function drawScale(){ c.moveTo(radius - scale, 0); c.lineTo(radius, 0); }; c.beginPath(); c.arc(0, 0, radius, 0, 2*Math.PI, true); c.closePath(); for (var i = 1; i <= 12; i++) { drawScale(); c.rotate(hourangle); /*旋转变换*/ }; /*绘制时间(3,6,9,12)*/ c.font = " bold 30px impack" c.fillText("3", 110, 10); c.fillText("6", -7, 120); c.fillText("9", -120, 10); c.fillText("12", -16, -100); c.stroke(); c.restore(); }; /*绘制时针(h: 当前时(24小时制))*/ this.drawHourHand = function(h){ h = h === 0? 24: h; c.save(); c.translate(center.x, center.y); c.rotate(3/2*Math.PI); c.rotate(h*hourangle); c.beginPath(); c.moveTo(0, 0); c.lineTo(hourHandLength, 0); c.stroke(); c.restore(); }; /*绘制分针(m: 当前分)*/ this.drawMinHand = function(m){ m = m === 0? 60: m; c.save(); c.translate(center.x, center.y); c.rotate(3/2*Math.PI); c.rotate(m*minangle); c.beginPath(); c.moveTo(0, 0); c.lineTo(minHandLength, 0); c.stroke(); c.restore(); }; /*绘制秒针(s:当前秒)*/ this.drawSecHand = function(s){ s = s === 0? 60: s; c.save(); c.translate(center.x, center.y); c.rotate(3/2*Math.PI); c.rotate(s*minangle); c.beginPath(); c.moveTo(0, 0); c.lineTo(secHandLength, 0); c.stroke(); c.restore(); }; /*依据本机时间绘制时钟*/ this.drawClock = function(){ var me = this; function draw(){ var date = new Date(); Canvas.clearCxt(); drawBackGround(); drawCenter(); me.drawHourHand(date.getHours() + date.getMinutes()/60); me.drawMinHand(date.getMinutes() + date.getSeconds()/60); me.drawSecHand(date.getSeconds()); } draw(); setInterval(draw, 1000); }; }; var main = function(){ var clock = new Canvas.Clock(); clock.drawClock(); };
代码中涉及到了一些简单的canvas元素API 大家google一下即可,
看完上述内容,你们对如何通过Canvas+JS实现简易的时钟有进一步的了解吗?如果还想了解更多知识或者相关内容,请关注行业资讯频道,感谢大家的支持。
时钟
长度
简易
代码
内容
变换
元素
分针
刻度
圆心
小时
弧度
时针
时间
秒针
表盘
复杂
麻雀虽小
五脏俱全
五脏
数据库的安全要保护哪些东西
数据库安全各自的含义是什么
生产安全数据库录入
数据库的安全性及管理
数据库安全策略包含哪些
海淀数据库安全审计系统
建立农村房屋安全信息数据库
易用的数据库客户端支持安全管理
连接数据库失败ssl安全错误
数据库的锁怎样保障安全
湖北手机软件开发案例
软件开发运维成本占百分之
阿里云服务器信息安全
时序数据库啊
陕西新一代网络技术服务资费
app与网络安全
mc服务器可以是电脑吗
史密森数据库图片
数据库技术主要研究的哪方面
网络安全与执法专业怎么样
永达网络技术有限公司
应急管理网络安全方案
数据库多个文件组成优点
郑州小程序软件开发运营公司
小说系统软件开发
数据库技术在铁路上的应用
众畅软件开发有限公司
怀旧服怎么发数据库装备
数据库安全制度规范
风水软件开发工具
c语言软件开发工具
netty 服务器监控
电脑怎么一键清除数据库
计算机四级考试网络技术
赤子城网络技术好不好
我的世界服务器的榜单
数据库 属性大小写
mc服务器房子
统计学中数据库的概念
分布式数据库有什么构成