说到HTML5,我们就要首先知道Canvas标签,这个标签定义了一块画布,所有图形的画面都要在这块画布上呈

现出来。其实光有Canvas是做不了任何事的,学过Windows的人都知道,在Windows里面绘图要先得到一个设

备上下文DC,在Canvas里面绘图同样要得到一个渲染上下文,在HTML5中,我们的图形并不是直接画到屏幕上

的,而是先画到一个上下文上,然后再刷新到屏幕上的。在Canvas中,我们通过语句getContext('2d')方法

返回一个CanvasRenderingContext2D对象,即渲染上下文对象,然后通过调用它的方法来实现Canvas绘图。

Canvas实现模拟电子时钟,代码如下

clock.html

<!doctype html>
<html><head></head><body><!-- 定义canvas画布,包括宽度和高度,还有背景颜色 --><canvas id="clock" width="1350" height="620" style="background:black">你的浏览器不支持canvas标!</canvas><!-- 用src引用js源文件 --><script src="clock.js"></script></body>
</html>

clock.js

//获取上下文文档对象
var clock = document.getElementById('clock');
var cxt = clock.getContext('2d');//画指针
function drawPointer(width, color, value, angle, startx, starty, endx, endy){cxt.save();                 //先保存当前画布cxt.lineWidth = width;      //设置画笔的宽度cxt.strokeStyle = color;    //设置画笔的颜色cxt.translate(550, 310);    //重置异次元空间的原点坐标cxt.rotate(value * angle * Math.PI / 180);  //设置旋转的角度,参数是弧度cxt.beginPath();cxt.moveTo(startx, starty);cxt.lineTo(endx, endy);cxt.closePath();            //先闭合路径,再画线cxt.stroke();               //开始画线cxt.restore();              //将旋转后的线段返回给画布
}//画刻度
function drawScale(size, width, color, value, startx, starty, endx, endy){for(var i = 0; i < size; i++){drawPointer(width, color, value, i, startx, starty, endx, endy);}
}//为表盘的中心填充颜色
function drawFill(){cxt.save();cxt.beginPath();cxt.arc(550, 310, 7, 0, 360, false);cxt.closePath();cxt.fillStyle = "red";cxt.fill();cxt.restore();
}//画时钟
function drawClock(){cxt.clearRect(0, 0, 1350, 620);  //清空整个画布var now = new Date();            //获取系统时间,取出时,分,秒var sec = now.getSeconds();var min = now.getMinutes();var hour = now.getHours();min += sec / 60;hour += min / 60;if(hour > 12) hour -= 12;cxt.beginPath();cxt.lineWidth = 10;cxt.strokeStyle = "blue";cxt.arc(550, 310, 300, 0, 360, false);cxt.closePath();cxt.stroke();drawScale(12, 7, "pink", 30, 0, -280, 0, -260);      //画时刻度drawScale(60, 5, "pink", 6,  0, -280, 0, -270);      //画分刻度drawPointer(7, "purple", hour, 30, 0, 12, 0, -210);  //画时针drawPointer(5, "yellow", min, 6, 0, 15, 0, -240);    //画分针drawPointer(4, "red", sec, 6, 0, 17, 0, -250);       //画秒针//细化秒针,为秒针加箭头drawPointer(3, "red", sec, 6, -7, -235, 0, -255);drawPointer(3, "red", sec, 6, 7, -235, 0, -255);drawFill();
}drawClock();
setInterval(drawClock, 1000);   //setInterval()方法中表示每隔1000ms,就执行drawClock一次

运行结果:





第一个Canvas实例-钟表相关推荐

  1. 每天一个JavaScript实例-canvas绘图

    <!DOCTYPE html> <html> <head> <meta http-equiv="Content-Type" content ...

  2. python tkinter计算器实例_Python+tkinter使用80行代码实现一个计算器实例

    Python+tkinter使用80行代码实现一个计算器实例 本文主要探索的是使用Python+tkinter编程实现一个简单的计算器代码示例,具体如下. 闲话不说,直奔主题.建议大家跟着敲一遍代码, ...

  3. 开发一个Canvas小游戏 实现一个游戏“引擎”

    前言 这个游戏其实在三四年前就写了,中间还重构过好几次,之前都是用简单的面向对象和函数式编程来写,游戏中的元素关系到还是分的挺开,但是游戏的渲染,运算等逻辑分的不够清晰,整个逻辑基本都是自顶向下的流水 ...

  4. canvas制作钟表

    之前用html+css+JavaScript实现了一个简单钟表,但还是有一些问题,主要是一些css属性不同浏览器支持效果不一样,所以尝试用 canvas实现了一个简单的钟表,效果在下方,当然了,采用c ...

  5. 超多经典 canvas 实例,动态离子背景、移动炫彩小球、贪吃蛇、坦克大战、是男人就下100层、心形文字等等等...

    超多经典 canvas 实例 普及:<canvas> 元素用于在网页上绘制图形.这是一个图形容器,您可以控制其每一像素,必须使用脚本来绘制图形. 注意:IE 8 以及更早的版本不支持 &l ...

  6. PixiJS学习(1)创建一个canvas

    简介 PixiJs是一款轻量级的渲染引擎库 官网地址:https://www.pixijs.com/ github:https://github.com/pixijs/pixi.js <scri ...

  7. JUnit基础及第一个单元测试实例(JUnit3.8)

    JUnit基础及第一个单元测试实例(JUnit3.8) 单元测试 单元测试(unit testing) ,是指对软件中的最小可测试单元进行检查和验证. 单元测试不是为了证明您是对的,而是为了证明您没有 ...

  8. 每天一个JavaScript实例-apply和call的使用方法

    <!DOCTYPE html> <html> <head> <meta http-equiv="Content-Type" content ...

  9. 每天一个JavaScript实例-获取元素当前高度

    <!DOCTYPE html> <html> <head> <meta http-equiv="Content-Type" content ...

最新文章

  1. 关于 0xCCCCCCCC
  2. javaScript入门之常用事件
  3. agc018B Sports Festival
  4. 数据挖掘导论读书笔记2
  5. 浏览器是如何展示网页的
  6. mysql left join on_mysql,left join on
  7. C++——赫夫曼编码-译码器(Huffman Coding)
  8. Increasing Subsequence (hard version)
  9. 使用Spring的Hibernate构建Java Web应用程序
  10. dz去掉/forum.php_discuz如何去除url的forum.php
  11. Windows下Maven 环境配置
  12. Linux驱动实现灯循环闪烁,TQ2440上LED灯闪烁效果的驱动程序实现
  13. 《Greenplum5.0 最佳实践》 内存与资源队列 (四)
  14. 一次百万长连接压测 Nginx OOM 的问题排查分析
  15. 2021湖南高考成绩分段查询,2021年湖南高考成绩排名查询系统,湖南高考位次排名表...
  16. R语言--异常值检测
  17. 免费天气API,免费天气接口,天气预报
  18. Theme Studio(主题工作室)
  19. 3D建模和渲染吃CPU还是显卡?专业显卡和游戏显卡的区别
  20. V神北京演讲全文:Casper与分片技术的最新进展

热门文章

  1. 基于Xml 的IOC 容器-开始读取配置内容
  2. response对象简介
  3. Linux下清理内存和Cache方法 /proc/sys/vm/drop_caches
  4. ES6新特性之map和reduce方法的使用
  5. Zuul指定path+serviceid
  6. FastDFS配置手册trackerstorage
  7. 蓝字冲销是什么意思_60秒学个词:Elusive 是什么意思?(美音版)
  8. NIO--Selector
  9. _LVM——让Linux磁盘空间的弹性管理
  10. java调用rocketmq_java操作RocketMQ