用 Excel 测试“绘制两点间连线”的算法
最近在研究和制作数字示波器,其中涉及一个小算法:需要将 ADC 采样的数值在 TFT LCD 屏幕上面显示并且用“线”连接起来。
ADC 按照时序对输入电压采样后,记录的是一个个的数值,如果显示的时候不用“线”连接它们,那么他们看上去就是这样的:

用直线连接以后,看上去就是这样了(垃圾 LM324 运放的模拟前端,方波波形变形严重到令人发指):

X 轴(时间轴)的放大比率确定以后,ADC 采样值的相邻 2 点在屏幕上的间距也就确定了,连线算法要做的事情,就是将位于这两点间的直线上的 LCD 小点一个个点亮。
说实话,不是做数字示波器,我还真不太会用得到这个算法。我也没有查资料,直接就想到了“2分法”+ 递归来处理:
- 将起点(X1,Y1)和终点的坐标(X2,Y2)传入处理函数(命名叫 Process 吧)
- Process 计算这两个点的 X 轴和 Y 轴间距 dX =(X2 - X1)和 dY = (Y2 – Y 1)
- 如果 dX、dY 都等于 0,那么说明起点和重点已经连上了,结束处理
- 否则,得到中点(nX,nY)=(X1 + dX,Y1 + dY)
- 把中点(nX,nY)点亮
- 将起点、中点作为新的参数调用 Process
- 将中点、终点作为新的参数调用 Process
- 搞定。
算法是有了,但是,要到数字示波器上面直接调试,还挺麻烦的,因为要对记录 ADC 采样值的数组、LCD 屏幕显存数组、LCD 驱动程序等等软硬件相关的部分同时修改,并且还要硬件上调试才能看到结果。昨天硬件又不在手边,也没法调试。所以,就想到了 Excel。Excel 那些格子(Cell)模拟 LCD 界面那是极方便的,以前干过很多次了。
- 首先,在 Excel 上面框出来一片格子(Cells)当作显示器屏幕(B2~V18,对应列 2~22,行 2~18)
- 然后,放入 2 个按钮。1 个用来绘制连线,1 个用来清除屏幕
- 接着,定义起点(绿色,5287963 :)和终点(红色)的颜色。用颜色标识会比较醒目一点儿
- 最后,把上面的算法写进按钮的 VBA 代码中即可
1: Sub cmdConnectPoints()
2: For c = 2 To 22
3: For r = 2 To 18
4: If Cells(r, c).Interior.Color = 5287936 Then
5: x1 = c
6: y1 = r
7: End If
8: If Cells(r, c).Interior.Color = RGB(255, 0, 0) Then
9: x2 = c
10: y2 = r
11: End If
12: Next
13: Next
14: Process x1, y1, x2, y2
15: End Sub
16:
17: Sub Process(x1, y1, x2, y2)
18: dx = Fix((x2 - x1) / 2)
19: dy = Fix((y2 - y1) / 2)
20: If dx = 0 And dy = 0 Then
21:
22: Else
23: nx = x1 + dx
24: If dx <= (x2 - nx) Then
25: ny = y1 + dy
26: Else
27: ny = y2 - dy
28: End If
29: Cells(ny, nx).Interior.Color = RGB(0, 0, 0)
30: Call Process(x1, y1, nx, ny)
31: Call Process(nx, ny, x2, y2)
32: End If
33: End Sub
34:
35: Sub cmdClear()
36: For c = 2 To 22
37: For r = 2 To 18
38: Cells(r, c).Interior.Color = RGB(255, 255, 255)
39: Next
40: Next
41: End Sub
上面的代码中,有一段按照中点的 X 坐标距离起点和终点的远近来改变中点 Y 坐标计算方法的代码。如果中点 X 距离起点更近,那么 nY = Y1 + dY;否则,nY = Y2 - dY。这样的微调是为了让两点间的连线看上去更加均直、美观。如果去掉,那么,绘制的连线会“扭”向起点那一边,不美观。
效果就是这样的:

还有使用起来非常爽的操作视频:
这次做的数字示波器比上一个版本复杂点儿,采样率更高、控制也会更精细。所以,制作过程中借用了上一个版本的成果(用工具来制作工具,与软件开发也是相通的道理):


用 Excel 测试“绘制两点间连线”的算法的更多相关文章
- 转:Math: Math.atan() 与 Math.atan2() 计算两点间连线的夹角
我们可以使用正切操作将角度转变为斜率,那么怎样利用斜率来转换为角度呢?可以利用斜率的反正切函数将他转换为相应的角度.as中有两个函数可以计算反正切,我们来看一下. 1.Math.atan() Math ...
- 任意两点间的最短路问题(Floyd-Warshall算法)
/* 任意两点间的最短路问题(Floyd-Warshall算法) */ import java.util.Scanner; public class Main { //图的顶点数,总边数 static ...
- 利用百度API(JavaScript 版)实现在地图上绘制任一多边形,并判断给定经纬度是否在多边形范围内。以及两点间的测距功能
权声明:本文为博主原创文章,未经博主允许不得转载. 利用百度API(JavaScript 版)实现在地图上绘制任一多边形,并判断给定经纬度是否在多边形范围内.以及两点间的测距功能. 绘制多边形(蓝色) ...
- 一个由正则表达式引发的血案 vs2017使用rdlc实现批量打印 vs2017使用rdlc [asp.net core 源码分析] 01 - Session SignalR sql for xml path用法 MemCahe C# 操作Excel图形——绘制、读取、隐藏、删除图形 IOC,DIP,DI,IoC容器
1. 血案由来 近期我在为Lazada卖家中心做一个自助注册的项目,其中的shop name校验规则较为复杂,要求:1. 英文字母大小写2. 数字3. 越南文4. 一些特殊字符,如“&”,“- ...
- 使用PostGIS完成两点间的河流轨迹及流经长度的计算
基础准备工作 1.PostGIS 的安装 在安装PostGIS前首先必须安装PostgreSQL,然后再安装好的Stack Builder中选择安装PostGIS组件.具体安装步骤可参照 PostGI ...
- iOS: 如何正确的绘制1像素的线
iOS 绘制1像素的线 一.Point Vs Pixel iOS中当我们使用Quartz,UIKit,CoreAnimation等框架时,所有的坐标系统采用Point来衡量.系统在实际渲染到设置时会帮 ...
- 图算法之Floyd-Warshall 算法-- 任意两点间最小距离
1.Floyd-Warshall 算法 给定一张图,在o(n3)时间内求出任意两点间的最小距离,并可以在求解过程中保存路径 2.Floyd-Warshall 算法概念 这是一个动态规划的算法. 将顶点 ...
- c++ 算法 栅格中两点之间连线
屏幕划线,通过平面坐标系实现,基本组成是一个一个的点,起点为A,终点为B 本文的算法,可以实现平面栅格中,指定的A,B两点之间进行连线(代码中仅打印了两点间需要画出的坐标点) #include < ...
- iOS 绘制1像素的线
一.Point Vs Pixel iOS中当我们使用Quartz,UIKit,CoreAnimation等框架时,所有的坐标系统采用Point来衡量.系统在实际渲染到设置时会帮助我们处理Point到P ...
随机推荐
- Xamarin.Android活动的生命周期
一.前言 用过Android手机的人一定会发现一种现象,当你把一个应用置于后台后,一段时间之后在打开就会发现应用重新打开了,但是之前的相关的数据却没有丢失.可以看出app的“生命”是掌握在系统手上的, ...
- 支付宝AR抢红包?前端轻松就破解~
近期阿里搞了各LBS+AR实景的红包玩法,小伙伴们在公司里都玩疯了~ 有时候为了抢一个红包,会跑到另一个地方去拍照,虽然略麻烦,但整体的互动还是很有意思的. 不过对于机智的前端童鞋来说,只需要简单的一 ...
- 使用ENode框架前您需要了解的东西(初稿)
选择ENode意味着什么可能很多人还不太清楚.我简单整理了一下: 意味着你选择了:你需要做DDD领域建模.选择了事件驱动的架构.选择了CQRS架构.选择了最终一致性.选择了事件溯源.选择了分布式.这些 ...
- 写自己的Socket框架(三)
在通信写完了以后,应用层接收到Socket抛上来的byte[],这个时候对于实际的写逻辑的开发者来说,这样的数据并不友好,我们就需要在应用层统一一个包的规则(应用层协议),处理完以后,然后再传给实际的 ...
- android内部培训视频_第四节(1)_异步网络操作
第四节(1):异步网络操作 一.结合asyncTask下载网络图片 1.定义下载类,继承自asyncTask,参数分别为:String(url地址),Integer(刻度,本例没有用到),BitMa ...
- python获取ip代理列表爬虫
最近练习写爬虫,本来爬几张mm图做测试,可是爬到几十张的时候就会返回403错误,这是被网站服务器发现了,把我给屏蔽了. 因此需要使用代理IP.为了方便以后使用,我打算先写一个自动爬取ip代理的爬虫,正 ...
- CocoaPods被卡住:Updating local specs repositories
使用CocoaPods被卡住:Updating local specs repositories 使用 pod install --verbose --no-repo-update
- 解析大型.NET ERP系统 界面与逻辑分离
Windows Forms程序实现界面与逻辑分离的关键是数据绑定技术(Data Binding),这与微软推出的ASP.NET MVC的原理相同,分离业务代码与界面层,提高系统的可维护性. 数据绑定 ...
- 锋利的jQuery--jQuery与DOM对象的互相转换,DOM的三种操作(读书笔记一)
1.jQuery对象就是通过jQuery包装DOM对象后产生的对象. 2.jQuery对象和DOM对象的相互转换. 良好的书写风格: var $input=$("input" ...
- ASP.NET MVC5+EF6+EasyUI 后台管理系统--系统模块部分图
系统日志,系统异常,组织架构等