Android图形绘制

        前面学习已知,Android大部分组件都是View的子类,而如果要进行图形的绘制操作,则我们可以用一个类去继承View类,之后覆写View类中指定方法。

View中绘图方法

 protected void onDraw(Canvas canvas)

 protected void onDrawScrollBars(Canvas canvas)

绘图4个核心操作类

android.graphics.Canvas类:操作绘图,绘图平台,提供了一个画板功能

android.graphics.Paint类:相当于画笔类

android.graphics.Bitmap:图片管理类,操作图片资源

android.graphics.Matrix: 矩阵类

现在我们先画几个简单图形,了解一下这几个类的用法。

定义MyView类:

public class MyView extends View{

	public MyView(Context context, AttributeSet attrs) {
		super(context, attrs);
		// TODO Auto-generated constructor stub
	}
    protected void onDraw(Canvas canvas){
    	canvas.drawColor(Color.WHITE);//设置背景颜色
    	Paint paint=new Paint();
    	paint.setColor(Color.YELLOW);//设置笔尖为黄色
    	canvas.drawCircle(30,50,25,paint);//画圆
    	paint.setColor(Color.BLACK);
    	canvas.drawRect(80,20,160,80, paint);//定义矩形
    	Rect rect=new Rect();//定义矩形
    	rect.set(180, 20, 200, 80);//设置矩形大小
    	paint.setStyle(Style.STROKE);//空心显示
    	canvas.drawRect(rect,paint);
    	paint.setColor(Color.BLUE);
    	paint.setTextSize(20);
    	canvas.drawText("ee的画板", 10, 110, paint);//显示文字
    	paint.setColor(Color.RED);
    	canvas.drawLine(10, 120, 300, 120, paint);
    	RectF oval=new RectF();//定义参考矩形
    	oval.set(10.0f, 140.0f, 110.0f, 200.0f);
    	canvas.drawOval(oval, paint);//画椭圆
    	oval.set(150.0f, 140.0f, 110.0f, 200.0f);//定义大小
    	canvas.drawArc(oval, 150.0f, 140.0f, true, paint);//画弧
    	//绘图
    	Bitmap bitmap=BitmapFactory.decodeResource(getResources(), R.drawable.wall);
    	//消除锯齿
    	paint.setAntiAlias(true);
    	canvas.drawBitmap(bitmap, 200, 200,paint);
    	paint.setTextSize(20);
    	paint.setColor(Color.BLACK);
    	canvas.drawText("图片高度:"+bitmap.getHeight()+", 图片宽度:"+bitmap.getWidth(),
    			10, bitmap.getHeight()+20, paint);
    	
    	
    	
    	
    	
	
   }
	

}

 然后在布局文件添加我们自己定义的组件 MyView

 

 

<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:tools="http://schemas.android.com/tools"
    android:id="@+id/LinearLayout1"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:orientation="vertical"
    tools:context=".MyView" >
    <com.example.viewdraw.MyView 
        android:id="@+id/myview"
          android:layout_width="fill_parent"
    android:layout_height="fill_parent"
        
        
        
                            />

</LinearLayout>

接下来,Activity里面只需要显示即可,这里是不动的,系统生成默认。

实现效果如图:




 

 
 接下来,我们深入运用一下Bitmap

首先我们定义将图片拉伸。

加入以下几行代码:

/*
    	 * 将图片拉伸至手机屏幕大小
    	 */
    	DisplayMetrics dm=getResources().getDisplayMetrics();
    	int screenWidth=dm.widthPixels;
    	int screenHeight=dm.heightPixels;
    	bitmap=Bitmap.createScaledBitmap(bitmap, screenWidth, screenHeight, true);
    	canvas.drawBitmap(bitmap, 0, 0, paint);

 

 

 然后我们定义图片在指定区域显示,也就是定义一个矩形框

加上这个代码

canvas.drawBitmap(bitmap, null, new Rect(30,50,200,200), paint);

 

 

 

 

猜你喜欢

转载自429899791.iteye.com/blog/2214040