在这之前

你需要了解一下方法的使用:

beginPath()

closePath()

moveTo()

lineTo()

fill()

stroke()

fillRect()

clearRect()

这些我在前面的文章介绍过,可以看:

画个圆

arc()方法

arc(x, y, radius, startAngle, endAngle, anticlockwise)

= > 画一个以(x,y)为圆心的以radius为半径的圆弧(圆),从startAngle开始到endAngle结束,按照anticlockwise给定的方向(默认为顺时针)来生成。

该方法有五个参数:x,y为绘制圆弧所在圆上的圆心坐标。radius为半径。startAngle以及endAngle参数用弧度定义了开始以及结束的弧度。这些都是以x轴为基准。参数anticlockwise 为一个布尔值。为true时,是逆时针方向,否则顺时针方向。

注意:arc()函数中的角度单位是弧度,不是度数。角度与弧度的js表达式:radians=(Math.PI/180)*degrees。

//画一个带边框的实心圆

var canvas = document.getElementById("canvas");

var ctx = canvas.getContext("2d");

canvas.width = 600;

canvas.height = 600;

ctx.beginPath();

var x = 200, // x 坐标值

y = 200, // y 坐标值

radius = 50, //半径

startAngle = 0 ; //开始点

endAngle = Math.PI * 2; //结束点

anticlockwise = true; //逆时针

ctx.arc(x, y, radius, startAngle, endAngle, anticlockwise);

ctx.lineWidth = 10;

ctx.fillStyle = "#1208ff";

ctx.strokeStyle = "#333";

ctx.stroke();

ctx.fill();

实现的效果图如下:

准备工作

会画个圆之后呢,就要开始绘制我们的电子时钟。开始之前,我们需要理清思路。首先,我们要创建个二维数组放置我们从0-9的点阵图形,当元素的值为1的时候,就要将其绘制出来。以下是二维数组的片段:

[

[0,0,1,1,1,0,0],

[0,1,1,0,1,1,0],

[1,1,0,0,0,1,1],

[1,1,0,0,0,1,1],

[1,1,0,0,0,1,1],

[1,1,0,0,0,1,1],

[1,1,0,0,0,1,1],

[1,1,0,0,0,1,1],

[0,1,1,0,1,1,0],

[0,0,1,1,1,0,0]

]//0

我们要做的就是将 0 - 9 个数字用二维数组表示出来。

绘制电子时钟的数字

首先,我们要遍历我们的二维数组,如果元素的值为 1 ,则我们就将他绘制成圆形,那如何确定每个元素的圆心呢,看下面这张图:

接着我们写这样一个绘制数字的数字:

function drawNum(x, y, num, ctx){

for (var i = 0; i < digit[num].length; i++){

for(var j = 0; j < digit[num][i].length; j++){

if( digit[num][i][j] == 1){

ctx.beginPath();

ctx.fillStyle = "rgb(0, 102, 153)";

ctx.arc(x+(RADIUS+1)*2*j+(RADIUS+1), y+(RADIUS+1)*2*i+(RADIUS+1), RADIUS, 0, Math.PI*2);

ctx.fill();

ctx.closePath();

}

}

}

}

然后,调用该函数来绘制我们的数字:

var RADIUS = 4; // 圆的半径

drawNum(0, 0, 1, ctx);

绘制的效果如下:

绘制简单的电子时钟

我们需要定义一个函数draw()来绘制我们的电子时钟。

function draw(ctx){

var curDate = new Date();

var hour = curDate.getHours();

var minute = curDate.getMinutes();

var seconds = curDate.getSeconds();

drawNum(Margin_X, Margin_Y, parseInt(hour/10), ctx);

drawNum(Margin_X + (RADIUS+1)*15, Margin_Y, parseInt(hour%10), ctx);

drawNum(Margin_X + (RADIUS+1)*30, Margin_Y, 10, ctx);

drawNum(Margin_X + (RADIUS+1)*45, Margin_Y, parseInt(minute/10), ctx);

drawNum(Margin_X + (RADIUS+1)*60, Margin_Y, parseInt(minute%10), ctx);

drawNum(Margin_X + (RADIUS+1)*75, Margin_Y, 10, ctx);

drawNum(Margin_X + (RADIUS+1)*90, Margin_Y, parseInt(seconds/10), ctx);

drawNum(Margin_X + (RADIUS+1)*105, Margin_Y, parseInt(seconds%10), ctx);

}

为了让每个数字之间有些间隔,不重叠在一起,定义了两个变量 Margin_X和Margin_Y来控制它距画布左边和顶部的距离。初始值都是30;

var Margin_X = 30; // 离 canvas 原点的坐标值 x

var Margin_Y = 30; // 离 canvas 原点的坐标值 y

让电子时钟动起来

setInterval()方法

setInterval(function,time)

= > 该方法会循环执行一个函数,时间间隔为 time(ms)

我们利用 setInterval方法让我们的电子时钟动起来。

setInterval(function(){

draw(ctx);

}, 500);

相应的,我们需要在重复绘制前,清楚我们的画布,不然会导致数字重叠在一起。这里用到了clearRect()清楚我们的画布。

ctx.clearRect(0,0,1024,786);

附上完整的代码:

canvas

当前浏览器不支持canvas

//电子时钟

var RADIUS = 4; // 圆的半径

var Margin_X = 30; // 离 canvas 原点的坐标值 x

var Margin_Y = 30; // 离 canvas 原点的坐标值 y

window.onload = function(){

var canvas = document.getElementById("canvas");

var ctx = canvas.getContext("2d");

setInterval(function(){

draw(ctx);

}, 500);

}

function draw(ctx){

ctx.clearRect(0,0,1024,786);

var curDate = new Date();

var hour = curDate.getHours();

var minute = curDate.getMinutes();

var seconds = curDate.getSeconds();

drawNum(Margin_X, Margin_Y, parseInt(hour/10), ctx);

drawNum(Margin_X + (RADIUS+1)*15, Margin_Y, parseInt(hour%10), ctx);

drawNum(Margin_X + (RADIUS+1)*30, Margin_Y, 10, ctx);

drawNum(Margin_X + (RADIUS+1)*45, Margin_Y, parseInt(minute/10), ctx);

drawNum(Margin_X + (RADIUS+1)*60, Margin_Y, parseInt(minute%10), ctx);

drawNum(Margin_X + (RADIUS+1)*75, Margin_Y, 10, ctx);

drawNum(Margin_X + (RADIUS+1)*90, Margin_Y, parseInt(seconds/10), ctx);

drawNum(Margin_X + (RADIUS+1)*105, Margin_Y, parseInt(seconds%10), ctx);

}

function drawNum(x, y, num, ctx){

for (var i = 0; i < digit[num].length; i++){

for(var j = 0; j < digit[num][i].length; j++){

if( digit[num][i][j] == 1){

ctx.beginPath();

ctx.fillStyle = "rgb(0, 102, 153)";

ctx.arc(x+(RADIUS+1)*2*j+(RADIUS+1), y+(RADIUS+1)*2*i+(RADIUS+1), RADIUS, 0, Math.PI*2);

ctx.fill();

ctx.closePath();

}

}

}

}

digit.js

digit =

[

[

[0,0,1,1,1,0,0],

[0,1,1,0,1,1,0],

[1,1,0,0,0,1,1],

[1,1,0,0,0,1,1],

[1,1,0,0,0,1,1],

[1,1,0,0,0,1,1],

[1,1,0,0,0,1,1],

[1,1,0,0,0,1,1],

[0,1,1,0,1,1,0],

[0,0,1,1,1,0,0]

],//0

[

[0,0,0,1,1,0,0],

[0,1,1,1,1,0,0],

[0,0,0,1,1,0,0],

[0,0,0,1,1,0,0],

[0,0,0,1,1,0,0],

[0,0,0,1,1,0,0],

[0,0,0,1,1,0,0],

[0,0,0,1,1,0,0],

[0,0,0,1,1,0,0],

[1,1,1,1,1,1,1]

],//1

[

[0,1,1,1,1,1,0],

[1,1,0,0,0,1,1],

[0,0,0,0,0,1,1],

[0,0,0,0,1,1,0],

[0,0,0,1,1,0,0],

[0,0,1,1,0,0,0],

[0,1,1,0,0,0,0],

[1,1,0,0,0,0,0],

[1,1,0,0,0,1,1],

[1,1,1,1,1,1,1]

],//2

[

[1,1,1,1,1,1,1],

[0,0,0,0,0,1,1],

[0,0,0,0,1,1,0],

[0,0,0,1,1,0,0],

[0,0,1,1,1,0,0],

[0,0,0,0,1,1,0],

[0,0,0,0,0,1,1],

[0,0,0,0,0,1,1],

[1,1,0,0,0,1,1],

[0,1,1,1,1,1,0]

],//3

[

[0,0,0,0,1,1,0],

[0,0,0,1,1,1,0],

[0,0,1,1,1,1,0],

[0,1,1,0,1,1,0],

[1,1,0,0,1,1,0],

[1,1,1,1,1,1,1],

[0,0,0,0,1,1,0],

[0,0,0,0,1,1,0],

[0,0,0,0,1,1,0],

[0,0,0,1,1,1,1]

],//4

[

[1,1,1,1,1,1,1],

[1,1,0,0,0,0,0],

[1,1,0,0,0,0,0],

[1,1,1,1,1,1,0],

[0,0,0,0,0,1,1],

[0,0,0,0,0,1,1],

[0,0,0,0,0,1,1],

[0,0,0,0,0,1,1],

[1,1,0,0,0,1,1],

[0,1,1,1,1,1,0]

],//5

[

[0,0,0,0,1,1,0],

[0,0,1,1,0,0,0],

[0,1,1,0,0,0,0],

[1,1,0,0,0,0,0],

[1,1,0,1,1,1,0],

[1,1,0,0,0,1,1],

[1,1,0,0,0,1,1],

[1,1,0,0,0,1,1],

[1,1,0,0,0,1,1],

[0,1,1,1,1,1,0]

],//6

[

[1,1,1,1,1,1,1],

[1,1,0,0,0,1,1],

[0,0,0,0,1,1,0],

[0,0,0,0,1,1,0],

[0,0,0,1,1,0,0],

[0,0,0,1,1,0,0],

[0,0,1,1,0,0,0],

[0,0,1,1,0,0,0],

[0,0,1,1,0,0,0],

[0,0,1,1,0,0,0]

],//7

[

[0,1,1,1,1,1,0],

[1,1,0,0,0,1,1],

[1,1,0,0,0,1,1],

[1,1,0,0,0,1,1],

[0,1,1,1,1,1,0],

[1,1,0,0,0,1,1],

[1,1,0,0,0,1,1],

[1,1,0,0,0,1,1],

[1,1,0,0,0,1,1],

[0,1,1,1,1,1,0]

],//8

[

[0,1,1,1,1,1,0],

[1,1,0,0,0,1,1],

[1,1,0,0,0,1,1],

[1,1,0,0,0,1,1],

[0,1,1,1,0,1,1],

[0,0,0,0,0,1,1],

[0,0,0,0,0,1,1],

[0,0,0,0,1,1,0],

[0,0,0,1,1,0,0],

[0,1,1,0,0,0,0]

],//9

[

[0,0,0,0],

[0,0,0,0],

[0,1,1,0],

[0,1,1,0],

[0,0,0,0],

[0,0,0,0],

[0,1,1,0],

[0,1,1,0],

[0,0,0,0],

[0,0,0,0]

]//:

];

实现的效果图如下:

甚至我们还可以这样子:

用easyx画电子钟_Canvas入门-利用Canvas绘制好玩的电子时钟相关推荐

  1. Canvas入门-利用Canvas绘制好玩的电子时钟

    在这之前 你需要了解一下方法的使用: beginPath() closePath() moveTo() lineTo() fill() stroke() fillRect() clearRect() ...

  2. html5 canvas 椭圆,html5中怎么利用Canvas绘制椭圆

    html5中怎么利用Canvas绘制椭圆 发布时间:2021-07-08 16:32:10 来源:亿速云 阅读:58 作者:Leah html5中怎么利用Canvas绘制椭圆,针对这个问题,这篇文章详 ...

  3. 小程序利用canvas 绘制图案 (生成海报, 生成有特色的头像)

    小程序利用canvas 绘制图案 (生成海报, 生成有特色的头像) 微信小程序生成特色头像,海报等是比较常见的.下面我来介绍下实现该类小程序的过程. 首先选择前端来通过 canvas 绘制.这样比较节 ...

  4. html5绘制图形幸运大转盘,微信小程序利用canvas 绘制幸运大转盘功能

    小程序对 canvas api 跟h5的不太一致 ,所以这个搞的比较久,不多说,先贴代码 Page({ /** * 页面的初始数据 */ data: { awardsConfig: {}, resta ...

  5. canvas线条背景(抽象画布可视化,利用canvas绘制多条线条,再利用多条线条同时动态发生改变,形成一幅美妙的动态图,非常惊艳!)

    canvas线条背景(抽象画布可视化,利用canvas绘制多条线条,再利用多条线条同时动态发生改变,形成一幅美妙的动态图,非常惊艳!) 动态变化中的静态截图 <!doctype html> ...

  6. 利用canvas绘制电子证书

    利用canvas绘制电子证书 <canvas>标签是HTML中的一个图形容器,其实你也可以把它理解成为一个程序员的画图工具,它只要提供的是2D绘制功能.我们可以通过利用JavaScript ...

  7. vue.js 利用canvas绘制仪表盘圆环进度条-带动画

    vue.js 利用canvas绘制简易仪表盘进度条 html代码 因为动画效果比较消耗性能,所以进度条单独canvas绘制 <template><div class="ci ...

  8. 利用canvas绘制的拓扑动画效果

    展示效果网址 reloadimage(callback){let imgArrs = [];this.imgArray.forEach((img,index,arrs)=>{imgArrs[in ...

  9. 利用Canvas绘制雷达图

    雷达图(蜘蛛网图)是一种常见的数据分析图表,本文采用canvas来绘制雷达图,并最终封装成一个小组件.首先来看一下最终的效果图: 如何画正多边形 以正五边形雷达图为例(其他任意正多边形也一样),如下图 ...

最新文章

  1. 拼多多面试:如何用 Redis 统计独立用户访问量?
  2. 最小化安装linux CentOS-6.6后 部署fastdfs +下载地址 很干很干的干货
  3. Typora markdown公式换行等号对齐_【精品软件 第3期】 有颜有料的编辑器——Typora
  4. 探寻阿里云服务器迈入2.0时代的技术要点
  5. U-net结构及代码注释
  6. Shell脚本中循环语句for,while,until用法
  7. Mr.J-- jQuery学习笔记(三)--静态方法详解
  8. oppo手机android 版本号,ColorOS新系统定档!紧跟安卓发布,但版本号亮了
  9. Kotlin入门(30)多线程交互
  10. 使用range()以相反的顺序打印列表?
  11. python如何快速登记凭证_如何高效地翻凭证?
  12. struts2编辑框中自动填充已经有的列表对应的值
  13. Django REST框架--认证和权限
  14. phpcmsv9 更换域名出现页面无法访问后怎么办
  15. python3 -m pip install pymongo_Python3上Pymongo的SSL握手问题
  16. matlab音乐合成卡农,神马FL神马Cubase都弱爆了!【matlab】弹凑卡农
  17. Vue2积分商城PC端项目(六)
  18. SQL语句LIKE CONCAT模糊查询
  19. ResponseResult
  20. 【OSATE学习笔记】AADL 样例 ARP4761 介绍

热门文章

  1. Java笔记整理-02.Java基础语法
  2. oracle 分页写法
  3. Spring之注解方式实例化Java类
  4. 病毒的灵魂拷问(绝对原创)
  5. CocoaPods私有库搭建的记录
  6. <a>标签带参数跳转并在下一个页面接收
  7. ext前后台数据传输的标准化
  8. Linux基础命令---diffstat
  9. python pexpect
  10. percent之集合