绘制图形(从零开始学Android)

来源:互联网 发布:mac怎么设置主页 编辑:程序博客网 时间:2024/05/22 18:38

使用view画图,有两个重要的组件需要介绍:
  (1)Paint 可以理解为画刷或者画笔,去主要用来设置绘图使用的颜色、填充方式、透明度、字体以及字体样式等。
  (2)Canvas 画布,在view上显示的图形都是由canvas来绘制的,可以绘制矩形、圆、椭圆、扇形……。

  Paint常见方法与属性:
  (1)Paint.Style.FILL 用颜色填充图形
  (2)Paint.Style.FILL_AND_STROKE 即绘制边框 同时也填充内部
  (3)Paint.Style.STROKE 绘制边框
  (4)paint.setAntiAlias(true)这个是用来设置抗锯齿效果的。

一、设计界面

  1、布局文件

  我们使用自定义GraphicsView类作为布局,继承自View。
  因此,不需要布局文件。

二、程序文件

  1、创建“src/com.genwoxue.graphics/GraphicsView.java”文件。
  然后输入以下代码:

[java] view plaincopy
  1. package com.genwoxue.graphics;  
  2.   
  3. import android.content.Context;    
  4. import android.graphics.Canvas;  
  5. import android.graphics.Paint;  
  6. import android.graphics.Color;  
  7. import android.view.View;  
  8.   
  9.   
  10. public class GraphicsView extends View{  
  11.       
  12.     //声明画笔  
  13.     Paint paint=null;  
  14.                   
  15.     public GraphicsView(Context context) {     
  16.         super(context);  
  17.           
  18.         /*---------------------------------------------- 
  19.          * 部分书籍中把Paint paint=new Paint();放在onDraw方法中,建议 
  20.          * 尽量不要把初始化画笔放在onDraw方法中,这是因为:onDraw经常会运行 
  21.          * 到的,不要在里面new对象,越少越好,不然很浪费内存 
  22.          *--------------------------------------------*/          
  23.         //获取画笔,初始化画笔  
  24.         paint=new Paint();  
  25.     }    
  26.       
  27.     @Override  
  28.     protected void onDraw(Canvas canvas){  
  29.         //设置画布背景为白色  
  30.         canvas.drawColor(Color.WHITE);  
  31.           
  32.         //设置画笔为红色  
  33.         paint.setColor(Color.RED);  
  34.         //使用当前画笔绘制一个左上角坐标为80,20,右下角坐标为360,180的矩形  
  35.         canvas.drawRect(80,20,360,180, paint);  
  36.           
  37.         //设置画笔为红色  
  38.         paint.setColor(Color.YELLOW);  
  39.         //使用当前画笔绘制一个圆心坐标为220,100,半径为60的圆  
  40.         canvas.drawCircle(220,18060, paint);  
  41.           
  42.     }  
  43.   
  44. }  

  2、打开“src/com.genwoxue.graphics/MainActivity.java”文件。
  然后输入以下代码:

[java] view plaincopy
  1. package com.genwoxue.graphics;  
  2.   
  3. import android.os.Bundle;  
  4. import android.app.Activity;  
  5.   
  6. public class MainActivity extends Activity {  
  7.   
  8.     @Override  
  9.     protected void onCreate(Bundle savedInstanceState) {  
  10.         super.onCreate(savedInstanceState);  
  11.           
  12.         //实例化GraphicsView  
  13.         GraphicsView graphicsView = new GraphicsView(this);   
  14.           
  15.         /* 在以前我们通过setContentView(R.layout.activity_main)显示布局文件 
  16.          * 本例中使用GraphicsView对象graphicsView代替以前布局文件 
  17.          */  
  18.         setContentView(graphicsView);  
  19.     }  
  20. }  


三、配置文件

  采用默认生成的“AndroidManifest.xml”文件即可,无需另行配置。

四、运行结果

  


0 0
原创粉丝点击