Canvas绘制心电图——网格开关

紧接上一篇文档,我们继续来为绘制好的心电图添加功能。

首先添加功能,必须得有功能按钮,所以我们需要先修改HTML页面内容,增加及功能按钮

一、HTML页面

1 <button id="showGrid" onclick="showGrid()">网格(开)</button>
2 <button id="multiple" onclick="multiple()">增益(10)</button>
3 时间:<input type="range" id="timeRange" min="0" max="10" value="0" step="1" />

(整体的HTML大家可以查看我之前发的教程文档)

我们在原有的心电图DIV盒子外面插入这几个按钮,为了方便起见,我直接讲我们用到的几个更能全部插入HTML内,在之后的教程中将不会再有HTML的相关代码。

插入后刷新网页、得到结果:

二、网格开关JS代码

首先为了方便操作,改变一行代码位置

1 var c_canvas = document.getElementById("heartBeat");

将这句代码从方法函数内取出来,放在最外面,因为我们之后的函数可能会需要调用c_canvas变量。



接下来首先需要一段隐藏函数:

1 function hide() {
2   ctx.beginPath();
3   ctx.clearRect(0, 0, 1000, 1000);
4   ctx.stroke();
5 }

这一段函数实际上是将canvas的画布内容上的内容清空。



编写好这段内容之后,我们需要做的就是写一个判断条件,来完成对画布的隐藏和显示

首先需要定义一个全局变量:

1 var show = true; //定义网格显示隐藏变量

之后写判断语句:

 1 //网格显示隐藏功能
 2 function showGrid() {
 3   show = !show; //每次执行这个方法,show就会变一次
 4   if (show) {
 5     draw();//重画全部
 6     document.getElementById("showGrid").innerHTML = "网格(开)";
 7     //改变button按钮上的文字
 8   } else {
 9     hide();//清除画布
10     drawLine(c_canvas);//将心电图再画上去,网格不画
11     document.getElementById("showGrid").innerHTML = "网格(关)";
12     //改变button按钮上的文字
13   }
14 }

到这里全部的代码就完成了,至于之前的心电图是如何画成的,大家可以关注我之前的几篇文档。

当然隐藏网格的方式不止这一种,还可以通过多一个canvas标签利用css隐藏等方式实现。

具体如何实现,喜欢用什么样的方法实现,自己开心就好,这里只是我的一种实现方法。

之后的功能,大家可以关注我后续的文档。

原文地址:https://www.cnblogs.com/BLackPeace/p/10558721.html

时间: 2024-10-20 10:15:26

Canvas绘制心电图——网格开关的相关文章

Canvas绘制心电图并且添加部分功能

今天来用Canvas绘制一张心电图,并且具备一些简单的调节功能. 首先来看下效果: 增益功能:能够放大心电图的波动幅度,效果如下: 网格开关:可以开启/关闭网格显示: 改变时间轴: 测量横纵坐标(鼠标拖拽测量,鼠标按下数显测量线,并且鼠标旁浮动数据,鼠标释放数据消失.PS:鼠标截图无法显示): 因为功能较多,具体功能如何实现的,可以关注我接下来的几篇赋源代码的技术贴.我会将功能一一为大家解答. 原文地址:https://www.cnblogs.com/BLackPeace/p/10551571.

用canvas绘制折线图

1 <!DOCTYPE html> 2 <html lang="en"> 3 <head> 4 <meta charset="UTF-8"> 5 <title>用canvas绘制折线图</title> 6 </head> 7 <body> 8 <canvas id="cv"></canvas> 9 </body> 1

封装 用canvas绘制直线的函数--面向对象

1 <!DOCTYPE html> 2 <html lang="en"> 3 <head> 4 <meta charset="UTF-8"> 5 <title>用面向对象的思想 封装 在canvas绘制直线的函数</title> 6 </head> 7 <body> 8 <canvas id="cv"></canvas> 9 &

canvas绘制时钟

<!DOCTYPE html> <html> <head> <meta charset="UTF-8"> <title>canvas绘制钟表</title> <style type="text/css"> #canvas{ /*border: 2px solid red;*/ display: block; margin: 0 auto; } </style> </

html5 Canvas绘制图形入门详解

html5,这个应该就不需要多作介绍了,只要是开发人员应该都不会陌生.html5是「新兴」的网页技术标准,目前,除IE8及其以下版本的IE浏览器之外,几乎所有主流浏览器(FireFox.Chrome.Opera.Safari.IE9+)都已经开始支持html5了.除此之外,在移动浏览器市场上,众多的移动浏览器也纷纷展开关于「html5的支持能力以及性能表现」的军备竞赛.html作为革命性的网页技术标准,再加上众多浏览器厂商或组织的鼎力支持,可以想见,html5将会成为未来网页技术的领头羊. ht

用h5中的canvas 绘制八卦图

1 <!doctype html> 2 <html> 3 <head> 4 <meta charset="UTF-8"> 5 <title>canvas绘制八卦图</title> 6 </head> 7 8 <body> 9 <canvas id="canvas" width="600" height="500"><

使用Canvas绘制图形的基本教程

原文地址:http://www.cnblogs.com/picaso/archive/2012/11/26/2789077.html HTML5火的正热,最近有个想法也是要用到HTML的相关功能,所以也要好好学习一把. 好好看了一下Canvas的功能,感觉HTML5在客户端交互的功能性越来越强了,今天看了一下Canvas绘图,下边是几个实例,记下以备后用. 1.使用Canvas绘制直线: <!doctype html> <html> <head> <meta ch

Canvas绘制线条模糊的解决方案

前段时间,做一个跨平台app项目,需要绘制分时图和K线图.找了很多开源的js的图表库,包括echarts.highcharts等等,都不是很满意,原因有2: 1.太臃肿,我实际上只要一个分时和一个K线图表,最多搭配几个线形图 2.不满足需求.主要就是分时图,国内玩的js图表库,几乎都没有分时图.都是用1分钟线的收盘价线来做的,和中国股民的使用习惯完全不搭界. 多年前有人开源了一个js绘制股票图形的库,叫做html54stock,图像表现上很符合中国人的使用习惯,但是也有问题: 1.封装不好,很多

用canvas绘制的饼状图,6等分,颜色随机

都说程序员懒,生活还是不能懒的,比如洗头.洗脸,当然也包括是分享咯.下面分享一下我用H5的新标签canvas绘制的饼状图,颜色是随机生成的,动态生成6等分,我还做了随机生成数据的, 配上文字,每份所占的比例就显而意见.,这点用在分析数据还是挺好的.图片如下; canvas 是 HTML5 提供的一个用于展示绘图效果的标签. canvas 原意画布, 帆布. 在 HTML 页面中用于展示绘图效果. 最早 canvas 是苹果提出的一个方案, 今天已经在大多数浏览器中实现.. 基本使用语法: 使用