HTML5 Canvas 绘制二十四字真言钟表
代码:
<!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="400px" height="400px" style="border:1px dashed black;"> 出现文字表示你的浏览器不支持HTML5 </canvas> </body> </html> <script type="text/javascript"> <!-- function draw(){ var canvas=document.getElementById('myCanvus'); canvas.width=400; canvas.height=400; context=canvas.getContext('2d'); context.translate(200,200); clock=new Clock(200); clock.init(); animate(); }; var context; var clock; function animate(){ context.clearRect(-200,-200,400,400);// 清屏 clock.paintBg(context); clock.paintScale(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="bg.jpg"; } // 画背景 this.paintBg=function(ctx){ ctx.drawImage(this.img,0,0,400,400,-200,-200,400,400); }; // 画刻度 this.paintScale=function(ctx){ var arr=["富强","民主","文明","和谐","自由","平等","公正","法治","爱国","敬业","诚信","友善"]; var offset=16; ctx.save(); ctx.rotate(getRad(-94.5)); for(var i=0;i<60;i++){ var degree=i*6; var x=(this.radius-offset)*Math.cos(getRad(degree)); var y=(this.radius-offset)*Math.sin(getRad(degree)); if((i % 5)==0){ ctx.save(); var x1=(this.radius-20)*Math.cos(getRad(degree)); var y1=(this.radius-20)*Math.sin(getRad(degree)); ctx.translate(x1,y1); ctx.rotate(getRad(degree+96)); ctx.font="bold 16px 宋体"; ctx.fillStyle=getColor(i/5); ctx.fillText(arr[i/5],0,0); ctx.restore(); } } ctx.restore(); }; // 画指针 this.paintPointers=function(ctx){ var date = new Date(); var hour=date.getHours(); var minute=date.getMinutes(); var second=date.getSeconds(); ctx.font="bold 12px 宋体"; ctx.fillStyle="navy"; ctx.fillText(hour+":"+minute+":"+second,-20,-120); 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/clock20170926.rar
HTML5 Canvas 绘制二十四字真言钟表的更多相关文章
- html5 canvas绘制环形进度条,环形渐变色仪表图
html5 canvas绘制环形进度条,环形渐变色仪表图 在绘制圆环前,我们需要知道canvas arc() 方 ...
- 学习笔记:HTML5 Canvas绘制简单图形
HTML5 Canvas绘制简单图形 1.添加Canvas标签,添加id供js操作. <canvas id="mycanvas" height="700" ...
- 使用 HTML5 Canvas 绘制出惊艳的水滴效果
HTML5 在不久前正式成为推荐标准,标志着全新的 Web 时代已经来临.在众多 HTML5 特性中,Canvas 元素用于在网页上绘制图形,该元素标签强大之处在于可以直接在 HTML 上进行图形操作 ...
- 使用html5 canvas绘制图片
注意:本文属于<html5 Canvas绘制图形入门详解>系列文章中的一部分.如果你是html5初学者,仅仅阅读本文,可能无法较深入的理解canvas,甚至无法顺畅地通读本文.请点击上述链 ...
- 使用html5 canvas绘制圆形或弧线
注意:本文属于<html5 Canvas绘制图形入门详解>系列文章中的一部分.如果你是html5初学者,仅仅阅读本文,可能无法较深入的理解canvas,甚至无法顺畅地通读本文.请点击上述链 ...
- html5 Canvas绘制图形入门详解
html5,这个应该就不需要多作介绍了,只要是开发人员应该都不会陌生.html5是「新兴」的网页技术标准,目前,除IE8及其以下版本的IE浏览器之外,几乎所有主流浏览器(FireFox.Chrome. ...
- 解决html5 canvas 绘制字体、图片与图形模糊问题
html5 canvas 绘制字体.图片与图形模糊问题 发生情况 多出现在高dpi设备,这意味着每平方英寸有更多的像素,如手机,平板电脑.当然很多高端台式电脑也有高分辨率高dpi的显示器. canva ...
- 使用html5 Canvas绘制线条(直线、折线等)
使用html5 Canvas绘制直线所需的CanvasRenderingContext2D对象的主要属性和方法(有"()"者为方法)如下: 属性或方法 基本描述 strokeSty ...
- 怎样用JavaScript和HTML5 Canvas绘制图表
原文:https://code.tutsplus.com/zh-...原作:John Negoita翻译:Stypstive 在这篇教程中,我将展示用JavaScript和canvas作为手段,在饼状 ...
随机推荐
- 6.shell判断语句
[ condition ](注意condition前后要有空格),可以使用$?验证(0为true,>1为false) 两个整数的比较:=:字符串比较-lt:小于-gt:大于-le:小于等于-ge ...
- 无界面运行Jmeter压测脚本
今天在针对单一接口压测时出现了从未遇到的问题,设好并发量后用调度器控制脚本的开始和结束,但在脚本应该自动结束时间,脚本却停不下来,手动stop报告就会有error率,卡了我很久很久不能解决,网络上也基 ...
- 详解Python中的__new__、__init__、__call__三个特殊方法(zz)
__new__: 对象的创建,是一个静态方法,第一个参数是cls.(想想也是,不可能是self,对象还没创建,哪来的self)__init__ : 对象的初始化, 是一个实例方法,第一个参数是self ...
- 【hdoj_1051】WoodenSticks
题目:http://acm.hdu.edu.cn/showproblem.php?pid=1051 题意可以理解为:给定若干个二元数对,要将这些数对分为不同的组,同一组中的若干个二元数对可以排列成一个 ...
- linux--redis的安装和配置和开启多个端口
在workerman开发过程中需要安装redis来存储用户ip.端口等信息 首先UBUNTU中安装redis: apt-update //更新apt包源apt-get install redis-s ...
- MYSQL的内外连接
1.内联接(典型的联接运算,使用像 = 或 <> 之类的比较运算符).包括相等联接和自然联接. 内联接使用比较运算符根据每个表共有的列的值匹配两个表中的行.例如,检索 stude ...
- (转载)grep的使用
R的意思是递归的对目录下的所有文件(包括子目录)进行 grep. 比如 grep -R main src就会搜索src目录下所有文件中是否包含 main 这个字符串. 因此grep -R " ...
- HDU 5935 Car【贪心,枚举,精度】
Problem Description Ruins is driving a car to participating in a programming contest. As on a very t ...
- OJP1147括号匹配加强版(栈)与P1153乱头发节(单调栈)
惨兮兮的被刷掉2%的通过率后在经过思考和dalao的指点后终于A掉了这道题 强烈建议修改这题的样例,实在太迷惑人,各种错误算法都能过 比如说这是一份错误代码,看懂了也不要学思路,和正解不知道差到哪里去 ...
- 1087: Common Substrings (哈希)
1087: Common Substrings Time Limit:3000/1000 MS (Java/Others) Memory Limit:163840/131072 KB (Java/ ...