Android教程網
  1. 首頁
  2. Android 技術
  3. Android 手機
  4. Android 系統教程
  5. Android 游戲
 Android教程網 >> Android技術 >> 關於Android編程 >> Android簡易實戰教程--第二十四話《畫畫板》

Android簡易實戰教程--第二十四話《畫畫板》

編輯:關於Android編程

今天完成一個畫畫板。

首先來個布局:

 



    
	

可見,要分紅綠色,而且還要保存最後畫的圖片。

 

看一下主活動代碼:

 

package com.itydl.paintban;

import java.io.File;
import java.io.FileNotFoundException;
import java.io.FileOutputStream;

import android.net.Uri;
import android.os.Bundle;
import android.os.Environment;
import android.app.Activity;
import android.content.Intent;
import android.graphics.Bitmap;
import android.graphics.Bitmap.CompressFormat;
import android.graphics.BitmapFactory;
import android.graphics.Canvas;
import android.graphics.Color;
import android.graphics.Matrix;
import android.graphics.Paint;
import android.view.Menu;
import android.view.MotionEvent;
import android.view.View;
import android.view.View.OnTouchListener;
import android.widget.ImageView;

public class MainActivity extends Activity {

	private ImageView iv;

	int startX;
	int startY;

	private Canvas canvas;

	private Paint paint;

	private Bitmap bmCopy;
	@Override
	protected void onCreate(Bundle savedInstanceState) {
		super.onCreate(savedInstanceState);
		setContentView(R.layout.activity_main);
		
		//加載畫畫板的背景圖
		Bitmap bmSrc = BitmapFactory.decodeResource(getResources(), R.drawable.bg);
		
		bmCopy = Bitmap.createBitmap(bmSrc.getWidth(), bmSrc.getHeight(), bmSrc.getConfig());
		paint = new Paint();
		canvas = new Canvas(bmCopy);
		//繪制
		canvas.drawBitmap(bmSrc, new Matrix(), paint);
		
		iv = (ImageView) findViewById(R.id.iv);
		iv.setImageBitmap(bmCopy);
		
		//設置觸摸偵聽
		iv.setOnTouchListener(new OnTouchListener() {
			
			//觸摸屏幕時,觸摸事件產生時,此方法調用
			@Override
			public boolean onTouch(View v, MotionEvent event) {
				int action = event.getAction();
				switch (action) {
				//用戶手指摸到屏幕
				case MotionEvent.ACTION_DOWN:
					startX = (int) event.getX();
					startY = (int) event.getY();
					break;
				//用戶手指正在滑動
				case MotionEvent.ACTION_MOVE:
					int x = (int) event.getX();
					int y = (int) event.getY();
					canvas.drawLine(startX, startY, x, y, paint);
					//每次繪制完畢之後,本次繪制的結束坐標變成下一次繪制的初始坐標
					startX = x;
					startY = y;
					iv.setImageBitmap(bmCopy);
					break;
				//用戶手指離開屏幕
				case MotionEvent.ACTION_UP:
					break;

				}
				//true:告訴系統,這個觸摸事件由我來處理
				//false:告訴系統,這個觸摸事件我不處理,這時系統會把觸摸事件傳遞給imageview的父節點
				return true;
			}
		});
			
		
	}

	public void red(View v){
		paint.setColor(Color.RED);
	}
	public void green(View v){
		paint.setColor(Color.GREEN);
	}
	public void brush(View v){
		paint.setStrokeWidth(7);
	}
	public void save(View v){
		File file = new File("sdcard/dazuo.png");
		FileOutputStream fos = null;
		try {
			fos = new FileOutputStream(file);
		} catch (FileNotFoundException e) {
			// TODO Auto-generated catch block
			e.printStackTrace();
		}
		bmCopy.compress(CompressFormat.PNG, 100, fos);
		
		//發送sd卡就緒廣播
		Intent intent = new Intent();
		intent.setAction(Intent.ACTION_MEDIA_MOUNTED);
		intent.setData(Uri.fromFile(Environment.getExternalStorageDirectory()));
		sendBroadcast(intent);
	}
}

運行看一下結果:

 

\

畫了個綠帽子,哈哈。

  1. 上一頁:
  2. 下一頁:
熱門文章
閱讀排行版
Copyright © Android教程網 All Rights Reserved