安卓canvas操作的总结

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

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

posted on 2014-07-03 10:55  jsRunner  阅读(1148)  评论(0编辑  收藏  举报

导航