2014.07.03 使用canvas绘图

需求:公司需要绘制波形图,类似数学上的正弦波,一条是参考值,一条是实际曲线

解决方法:采用canvas绘图。保存为图片,以供导出

这里提供一个学习的demo

为了方便调试,看到绘制的效果,因此用canvas 绘制一个视图,放入activity 中。

具体代码如下:

protected void onCreate(Bundle savedInstanceState) {
// TODO Auto-generated method stub
super.onCreate(savedInstanceState); setContentView(new CustomView1(this)); }

这里的Customview 是一个自定义的类,继承了view。

它的构造函数必须要传递当前的activity对象或其他容器

public CustomView1(Context context) {
super(context);

图片的绘制,具体的细节实现在 该类的ondraw中

@Override
protected void onDraw(Canvas canvas) {
//具体绘图代码

有了这些,就算准备好了绘图的大致框架。现在就开始来绘图吧

首先需要一个画笔,同时设置一些参数

paint = new Paint(); // 设置一个笔刷大小是3的黄色的画笔
paint.setColor(Color.BLUE);
// paint.setStrokeJoin(Paint.Join.ROUND); //图像结合的效果 例如平滑
paint.setStrokeCap(Paint.Cap.ROUND); //笔刷的样式 例如圆形 方形等
paint.setStrokeWidth(9);
// paint.setStyle(Paint.Style.STROKE); //设置为空心
paint.setStyle(Paint.Style.FILL); // 设置为实心

然后就是绘制图形,简单的图形,已经有现成的方法,譬如圆形,矩形等

// 绘制圆

            canvas.drawCircle(200, 200, 100, paint);

// 绘制弧线区域

            RectF rect = new RectF(0, 0, 100, 100);

            canvas.drawArc(rect, // 弧线所使用的矩形区域大小
0, // 开始角度
90, // 扫过的角度
true, // 是否使用中心
paint);
// 绘制没有中心的弧线
rect = new RectF(100, 0, 200, 100); canvas.drawArc(rect, // 弧线所使用的矩形区域大小
0, // 开始角度
90, // 扫过的角度
false, // 是否使用中心
paint); // 绘制色块。
// canvas.drawColor(Color.BLACK); // 绘制直线
canvas.drawLine(300, 300, 450, 450, paint); rect = new RectF(300, 0, 400, 300);
// 矩形区域内切椭圆
canvas.drawOval(rect, paint); /* 绘制文字 */
/*canvas.drawPosText("Android777", new float[] { 400,
10, // 第一个字母在坐标10,10
410,
20, // 第二个字母在坐标20,20
430,
30, // ....
440, 40, 450, 50, 460, 60, 470, 70, 480, 80, 490, 90, 500,
100 }, paint);
*/ /* 绘制文字 */
//canvas.drawText("吴文付", 500, 150, paint); /* 画矩形 */
//rect = new RectF(550, 250, 600, 350); // canvas.drawRect(rect, paint); //直角矩形 // 椭圆矩形
/*canvas.drawRoundRect(rect, 30, // x轴的半径
30, // y轴的半径
paint); Path path = new Path(); //定义一条路径
path.moveTo(0, 450); //移动到 坐标10,10
path.lineTo(50, 490);
path.lineTo(100,560);
path.lineTo(120, 580); canvas.drawPath(path, paint); path = new Path(); //定义一条路径
path.moveTo(100, 500); //移动到 坐标10,10
path.lineTo(50, 600);
path.lineTo(200,660);
path.lineTo(10, 670); // canvas.drawPath(path, paint);
canvas.drawTextOnPath("吴文付开发者博客", path, 10, 10, paint); drawSouth(canvas);

如果需要绘制比较复杂的图形,建议通过绘制点来实现或者 路径绘制来实现。

这前提就需要一个算法,提供点的集合。这里就不说了,具体情况具体应用。

一个技巧: 由于工作需要,绘制的线性图,需要填充,但是填充色 与线性图的线 要不同色。

方法是 : 改变画笔的 样式 和颜色,重复画。即可实现。

paint.setStyle(Paint.Style.STROKE);
paint.setStyle(Paint.Style.FILL);

演示的工程地址:http://download.csdn.net/detail/douniwan123654/7586469

安卓canvas操作的总结的更多相关文章

  1. canvas操作图片,进行面板画图,旋转等

    HTML5 <canvas> 标签用于绘制图像(通过脚本,通常是 JavaScript). 不过,<canvas> 元素本身并没有绘制能力(它仅仅是图形的容器) - 您必须使用 ...

  2. angular使用canvas操作时报错

    最近,用 angular 前端框架为应用登录新增图形验证码认证,由于没有现成的插件,于是便使用canvas+js操作,也是可以正常使用,但是在编译阶段却有个报错: ERROR in src/app/l ...

  3. 使用Canvas操作像素

    现代浏览器支持通过<video>元素播放视频.大多数浏览器也可以通过MediaDevices.getUserMedia() API访问摄像头.但即使这两件事结合起来,我们也无法直接访问和操 ...

  4. 安卓ListView操作的两种方法

    举例做一个微信的中间部分(好友消息等信息通知) 第一种:BaseAdapter() package com.example.wx; import java.util.ArrayList;import ...

  5. 安卓 canvas

    [转]http://blog.sina.com.cn/s/blog_61ef49250100qw9x.html(easy) [转]http://blog.csdn.net/rhljiayou/arti ...

  6. 微信小游戏canvas操作

    这几天在做项目的时候,想在游戏画面之前,在Canvas上面画上一张背景图,代码如下     let ctx = canvas.getContext('2d')    export default cl ...

  7. canvas 操作像素 窗帘效果

    代码实例: <!DOCTYPE html> <html> <head> <style> canvas{ background:#eee; } </ ...

  8. canvas 操作像素 反相

    代码实例: <!DOCTYPE html> <html> <head> <style> canvas{ background:#eee; } </ ...

  9. Winfrom 简单的安卓手机屏幕获取和安卓简单操作

    为啥我要做这个东西了,是因为经常要用投影演示app ,现在有很多这样的软件可以把手机界面投到电脑上 ,但都要安装,比如说360的手机助手,我又讨厌安装,于是就自己捣鼓了下 做了这个东西, 实现了以下简 ...

随机推荐

  1. Linux学习 -- Shell基础 -- 概述

    Shell是什么? 命令解释器 编程语言 Linux支持的Shell类型 cat /etc/shells 主要学习 bash 脚本执行方式 echo echo -e 单引号 -- 原始字符串  双引号 ...

  2. 2016中国大学生程序设计竞赛 - 网络选拔赛 1004 Danganronpa

    Problem Description Chisa Yukizome works as a teacher in the school. She prepares many gifts, which ...

  3. USACO Section 1.3 Combination Lock 解题报告

    题目 题目描述 农夫John的牛从农场逃脱出去了,所以他决定用一个密码锁来把农场的门锁起来,这个密码锁有三个表盘,每个表盘都是环形的,而且上面刻有1~N,现在John设了一个开锁密码,而且这个锁的设计 ...

  4. hibernate事务并发问题(脏读,不可重复读,幻读)

    脏读  dirty read:  读了别的事务没有提交的事务, 可能回滚, 数据可能不对. 不可重复读 non repeatable read: 同一个事务里前后读出来的数据不一样, 被另一个事务影响 ...

  5. hibernate中SQLQuery的addEntity()方法

    如果使用原生sql语句进行query查询时,hibernate是不会自动把结果包装成实体的.所以要手动调用addEntity(Class class)等一系列方法. 如session.createSQ ...

  6. 为图片存储而作——记一次UEditor源码的修改

    本文版权归博客园和作者吴双本人共同所有.  写在前面 这是一个数据爆发的网络时代,大家习惯于浏览图文直观带给我们的快速信息.大图片的存储和浏览经常会成为Web服务器的瓶颈.试想如果你的Web服务器依然 ...

  7. POJ 2991 Crane

    线段树+计算几何,区间更新,区间求和,向量旋转. /* *********************************************** Author :Zhou Zhentao Ema ...

  8. js优化原则

    首先,与其他语言不同,JS的效率很大程度是取决于JS engine的效率.除了引擎实现的优劣外,引擎自己也会为一些特殊的代码模式采取一些优化的策略.例如FF.Opera和Safari的JS引擎,都对字 ...

  9. Android 之 ServiceManager与服务管理

    ServiceMananger是android中比较重要的一个进程,它是在init进程启动之后启动,从名字上就可以看出来它是用来管理系统中的service.比如:InputMethodService. ...

  10. sql语句优化之not in

    多表关联想查a表中除去b表的可用not exists 效率比not in 更高 优化后的语句用时0.421秒 select john.*, (case when round((case john.su ...