Android自定义 View 练习 —— 心电图的绘制

先上个效果图(画块饼),让你有耐心看完下面内容。

这里写图片描述

网上已经有不少人,把类似的效果做出来了。我就把自己做出这个效果的思路写出来,希望对想对自定义 View 有更深理解的朋友有帮助。

先作一个草图,打开 Windows 自带的“画图”软件,OS X 系统的就找个类似的软件吧。先想好,再来画个草图。我画的草图如下:

这里写图片描述

看到这,可能有人有疑问了,写自定义 View 怎么不写代码啊,我是来看代码的,最好把完整代码贴出来,画这些图有 * 用啊。有的高手能够在脑海里把很复杂的自定义 View 想象出来。为了说服你最好画一画图,我在这里简单说几句,个人认为画图是个重要的步骤,能事半功倍。想法是代码的灵魂,先想好想法,再去写代码就容易了,类似于“胸中有文章,下笔如涌泉”。假如你是新手阶段,对着别人的代码敲可以有进步,但如果你一直都是对着别人的代码敲然后敲成一个项目的,你自己深想一下,有没有前途?画了图之后,你的思维就被解放了,不会深陷于文字之中,还可能激发出新的想法,你就会想办法实现它。如果你没尝试过的话,可以试一试,顶多就是半个小时的时间,如果你有特别深刻的体验,那恭喜你学会了一种新方式;如果没有,你只是进行了一次风险不大的尝试,人生的惊喜就在于新的尝试。

看着你画的草图,我们可以看到屏幕宽度是已知的,设置大格子的数目后,大格子的宽度也就确定了。这个时候有思绪了,需要横纵两个方向的格子数量。来设置两个全局变量:

这里写图片描述

horizontalBigGirdNum 为横向的线,即纵向大格子的数量。verticalBigGirdNum 为纵向的线,即横向大格子的数量。

在 XML 文件中使用:

这里写图片描述

在 xml 中宽 360 dp( match_parent ),高 270 dp,也就是 3 : 4 的关系。
horizontalBigGirdNum = 6,verticalBigGirdNum = 8,横向八个格子,纵向六个格子,这样划分比较科学。

正式开始写代码。首先初始化画笔。

这里写图片描述

在 onSizeChanged() 方法调用后,View 的宽高也就确定了。我们可以在这个方法里面来确定每个大格子的宽度。

这里写图片描述

在 onDraw() 方法中进行绘画。
将画网格写在一个方法中,并设置标志位,这样可以设置一个 public 方法来设置是否画网格。

这里写图片描述

画网格的方法:

这里写图片描述

到这里,网格就出来了。

接下来就是重点,画心电图了。
画草图。

这里写图片描述

分析:一条这样的线我们可以用 Path 类来画,画笔 Paint的类型记得设为 Paint.Style.STROKE(不然会很难看)。

这里写图片描述

没有数据是出不了效果的,我们来生成一些模拟的数据。

这里写图片描述

如果你需要将真实的心电图数据(比如说从传感器通过蓝牙传送过来的)放进来的话,只要设置一个 public 方法从外面传参数进来就好了。

到了这里,轨迹就能画出来了。但是,它不能像真实心电图那样将心电轨迹慢慢呈现出来,而是一下子就显示出来了。

我们可以加个延时,将心电图的点一个一个慢慢地连接起来。让我来做个比喻。我们都玩过贪吃蛇的游戏,每个蛇要吃的点就是数据源的坐标,没加延时情况下,贪吃蛇的速度很快,我们一眨眼的瞬间它就吃完了,我们就马上看到了整体曲线,而加了延时后,贪吃蛇的速度就慢了,它慢慢地经过点然后吃掉变长,我们也就看到了轨迹形成的过程。

代码实现如下:

这里写图片描述

增加延时,并且使上面的代码持续地执行。

这里写图片描述

项目代码:
完整代码
(用 AS 的话太大了,还是用 Eclipse 的项目吧)

到此,心电图就基本完成了。这只是一个简单的绘画,要想做的更好,还有许多事情要做,比如说封装入库等。如果你是一个想练习自定义 View 的初学者,我想这篇文章会对你有所启发。

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 205,033评论 6 478
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 87,725评论 2 381
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 151,473评论 0 338
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,846评论 1 277
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,848评论 5 368
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,691评论 1 282
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 38,053评论 3 399
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,700评论 0 258
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 42,856评论 1 300
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,676评论 2 323
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,787评论 1 333
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,430评论 4 321
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 39,034评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,990评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,218评论 1 260
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 45,174评论 2 352
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,526评论 2 343

推荐阅读更多精彩内容