HTML5 Canvas 画钟表
画钟表是2D画图的老生常谈,我也不能免俗弄了一个。代码如下:
<!DOCTYPE html> <html lang="utf-8"> <meta http-equiv="Content-Type" content="text/html; charset=utf-8"/> <head> <title>钟表</title> </head> <body onload="draw()"> <canvas id="myCanvus" width="200px" height="200px" style="border:1px dashed black;"> 出现文字表示你的浏览器不支持HTML5 </canvas> </body> </html> <script type="text/javascript"> <!-- function draw(){ var canvas=document.getElementById('myCanvus'); canvas.width=200; canvas.height=200; context=canvas.getContext('2d'); context.translate(100,100); clock=new Clock(100); clock.init(); animate(); }; var context; var clock; function animate(){ context.clearRect(-100,-100,200,200);// 清屏 clock.paintBg(context); clock.paintScale(context); clock.paintNumbers(context); clock.paintPointers(context); if(true){ // 让浏览器自行决定帧速率 window.requestAnimationFrame(animate); } } // 钟表类 function Clock(radius){ this.radius=radius; this.img; this.init=function(){ this.img=new Image(); this.img.src="clock7.jpg"; } // 画背景 this.paintBg=function(ctx){ ctx.drawImage(this.img,66,50,880,880,-100,-100,200,200); }; // 画刻度 this.paintScale=function(ctx){ for(var i=0;i<60;i++){ var degree=i*6; var x=this.radius*Math.cos(getRad(degree)); var y=this.radius*Math.sin(getRad(degree)); ctx.strokeStyle = "black"; ctx.fillStyle="black"; ctx.beginPath(); if((i % 5)==0){ ctx.arc(x,y,1.5,0,Math.PI*2,false); }else{ //ctx.arc(x,y,0.5,0,Math.PI*2,false); } ctx.closePath(); ctx.fill(); } }; // 画数字 this.paintNumbers=function(ctx){ ctx.font="bold 16px 宋体"; ctx.fillStyle="Red"; ctx.fillText("XII",-12,-80); ctx.fillText("VI",-8,93); ctx.fillText("IX",-94,5); ctx.fillText("III",68,5); }; // 画指针 this.paintPointers=function(ctx){ var date = new Date(); var hour=date.getHours(); var minute=date.getMinutes(); var second=date.getSeconds(); ctx.font="bold 6px 宋体"; ctx.fillStyle="navy"; ctx.fillText(hour+":"+minute+":"+second,12,-50); var angleS=second*6; var angleM=minute*6; var angleH=hour*30+angleM/360*30; context.save(); context.rotate(getRad(-90)); var x,y; context.lineWidth=0.5; x=(this.radius-2)*Math.cos(getRad(angleS)); y=(this.radius-2)*Math.sin(getRad(angleS)); ctx.strokeStyle = "black"; ctx.beginPath(); ctx.moveTo(-x/3, -y/3); ctx.lineTo(x,y); ctx.stroke(); ctx.closePath(); context.lineWidth=1.5; x=(this.radius-8)*Math.cos(getRad(angleM)); y=(this.radius-8)*Math.sin(getRad(angleM)); ctx.strokeStyle = "yellow"; ctx.beginPath(); ctx.moveTo(0, 0); ctx.lineTo(x,y); ctx.stroke(); ctx.closePath(); context.lineWidth=2; x=(this.radius-25)*Math.cos(getRad(angleH)); y=(this.radius-25)*Math.sin(getRad(angleH)); ctx.strokeStyle = "maroon"; ctx.beginPath(); ctx.moveTo(0, 0); ctx.lineTo(x,y); ctx.stroke(); ctx.closePath(); context.restore(); ctx.fillStyle="black"; ctx.arc(0,0,2.5,0,Math.PI*2,false); ctx.fill(); }; } // 常规函数:角度得到弧度 function getRad(degree){ return degree/180*Math.PI; } // 常规函数:得到颜色 function getColor(index){ if(index==0){ return "green"; }else if(index==1){ return "silver"; }else if(index==2){ return "lime"; }else if(index==3){ return "gray"; }else if(index==4){ return "white"; }else if(index==5){ return "yellow"; }else if(index==6){ return "maroon"; }else if(index==7){ return "navy"; }else if(index==8){ return "red"; }else if(index==9){ return "blue"; }else if(index==10){ return "purple"; }else if(index==11){ return "teal"; }else if(index==12){ return "fuchsia"; }else if(index==13){ return "aqua"; }else if(index==14){ return "black"; } } //--> </script>
完整代码从这里下载:https://files.cnblogs.com/files/xiandedanteng/clock.rar
HTML5 Canvas 画钟表的更多相关文章
- HTML5 Canvas 画虚线组件
前段时间由于项目需要,用到了HTML5 Canvas画图,但是没有画虚线的方法,自己写了一个HTML5 画虚线的组件. dashedLine.js if (window.CanvasRendering ...
- CSS3进度条 和 HTML5 Canvas画圆环
看到一些高大上的进度条插件,然后想自己用CSS写.经过搜索资料之后,终于成功了.为了以后方便拿来用,或者复习.将代码贴出. HTML代码: 只需要两个div,外面的为一个有border的div id为 ...
- html5 canvas画饼
1. [图片] lxdpie.jpg 2. [文件] lqdpie.html ~ 801B 下载(7) <!DOCTYPE HTML PUBLIC "-//W3C//DTD ...
- html5 canvas画不出图像的原因
很久没写博客了,今年过年的时候,家里出了意外,现在心里依然很难受.6月份之前一直忙着写毕业论文,答辩完6月初回公司继续上班,今天刚好周末有空,就写下之前碰到一个问题. 做一个图像查看器(基于Chrom ...
- html5 canvas画流程图
<!DOCTYPE html> <html> <head> <meta charset="utf-8" /> <title&g ...
- HTML5 Canvas画数字时钟
先不说废话,没代码算个蛋. 一些地方注释都写得比较清楚,不过这只是部分,因为只有秒针,但是时针,分针的逻辑都是一致的. 代码中有些坐标不知道为什么较不准,看看就好
- html5 canvas画进度条
这个ie8的兼容是个问题,ie8 的innerHTML有问题啊,添加两个附件吧 <!DOCTYPE html> <html> <head> <meta cha ...
- html5 canvas 画hello ketty
<!DOCTYPE html> <html lang="zh-CN"> <head> <meta charset="utf-8& ...
- canvas 画钟表
<!DOCTYPE html><html> <head> <meta charset="UTF-8"> <title>& ...
随机推荐
- bzoj 4443 [Scoi2015]小凸玩矩阵 网络流,二分
[Scoi2015]小凸玩矩阵 Time Limit: 10 Sec Memory Limit: 128 MBSubmit: 1564 Solved: 734[Submit][Status][Di ...
- python和shell对比
python和shell都是我们经常使用的脚本语言,平时python主要用来写一些小型的任务,shell则在使用liunx系统部署任务的时候用的比较多,由于两者有一些相似之处,时间长了容易混掉,所以这 ...
- Windows.Forms Panel 动态加载用户控件 UserControl
创建好一个Windows Forms程序,在创建好的程序中Form1添加一个Panel控件 如图:
- poj 3744 Scout YYF 1 (概率DP+矩阵快速幂)
F - Scout YYF I Time Limit:1000MS Memory Limit:65536KB 64bit IO Format:%I64d & %I64u Sub ...
- Html5学习进阶三 Input 类型
HTML5 新的 Input 类型 HTML5 拥有多个新的表单输入类型.这些新特性提供了更好的输入控制和验证. 本章全面介绍这些新的输入类型: email url number range Date ...
- [摸鱼] 配置的vim的使用攻略!
vim使用攻略 <>=f 折叠与缩进 开:<>[^fuck]cc 关:<>cu 缩进一块使用V选中,按>> [Ctrl]V 以列为单位选 za,打开或关 ...
- Linux Mint---ATI显卡驱动安装篇
显卡驱动可谓是至关重要,当时折腾debian驱动的时候可是弄了好几天才搞定的,现在却非常容易就是装上, 详见这篇博客:http://www.yyearth.com/article/14-03/amd1 ...
- USACO silver P1
原题概述题意: 共有N个数,每个数的个数为ai,ai的总和为M,将每2个数进行配对,要求使配对之后2数的和的最大值最小,并输出最小值. 这不就是裸的贪心么..实在是水题啊, 不过如果假如有一个人要一个 ...
- 如何防止Android反编译
转自: http://my.eoe.cn/sandking/archive/19772.html http://www.cnblogs.com/zdz8207/archive/2012/01/28/d ...
- RMQ-ST算法
1068 : RMQ-ST算法 时间限制:10000ms 单点时限:1000ms 内存限制:256MB 描述 小Hi和小Ho在美国旅行了相当长的一段时间之后,终于准备要回国啦!而在回国之前,他们准备去 ...