Android畫板實現

dfd7 8年前發布 | 873 次閱讀 Java Android

public class ActionerView extends View {
    private Paint mPaint = new Paint();
    private Path mPath = new Path();//手指滑動路徑
    private Canvas mCanvas;//緩存畫布
    private Bitmap mBitmap;//緩存圖片
    private float pointX, pointY;//觸點坐標

public ActionerView(Context context, AttributeSet attrs) {
    super(context, attrs);
}


@Override
protected void onMeasure(int widthMeasureSpec, int heightMeasureSpec) {
    super.onMeasure(widthMeasureSpec, heightMeasureSpec);

    int width = getMeasuredWidth();
    int height = getMeasuredHeight();

    initPaint();//初始化畫筆

    mBitmap = Bitmap.createBitmap(width, height, Bitmap.Config.ARGB_8888);
    mCanvas = new Canvas(mBitmap);
}

@Override
public void draw(Canvas canvas) {
    super.draw(canvas);

    mCanvas.drawPath(mPath, mPaint);
    canvas.drawBitmap(mBitmap, 0, 0, null);

}

@Override
public boolean onTouchEvent(MotionEvent event) {
    pointX = event.getX();
    pointY = event.getY();
    switch (event.getAction()) {
        case MotionEvent.ACTION_DOWN:
            mPath.moveTo(pointX, pointY);//將路徑移動到點(pointX, pointY),不繪制
            break;
        case MotionEvent.ACTION_MOVE:
            mPath.lineTo(pointX, pointY);//繪制一條從上個觸點到點(pointX, pointY)的線條
            break;
    }
    invalidate();//重新繪圖
    return true;
}

private void initPaint() {//初始化畫筆
    mPaint.setDither(true);//圖片抖動處理
    mPaint.setAntiAlias(true);
    mPaint.setStrokeWidth(20);
    mPaint.setStyle(Paint.Style.STROKE);
    mPaint.setStrokeCap(Paint.Cap.ROUND);//設置筆頭為圓角
    mPaint.setStrokeJoin(Paint.Join.ROUND);
}

}

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60

橡皮擦效果圖

這里寫圖片描述 頁面代碼

public class ActionView extends View { private Paint mPaint = new Paint(); private Path mPath = new Path();//手指滑動路徑 private Canvas mCanvas;//緩存畫布 private Bitmap mBitmap;//緩存圖片 private float pointX, pointY;//觸點坐標

public ActionView(Context context, AttributeSet attrs) {
    super(context, attrs);
}

@Override
protected void onMeasure(int widthMeasureSpec, int heightMeasureSpec) {
    super.onMeasure(widthMeasureSpec, heightMeasureSpec);

    int width = getMeasuredWidth();
    int height = getMeasuredHeight();

    initPaint();//初始化畫筆

    mBitmap = Bitmap.createBitmap(width, height, Bitmap.Config.ARGB_8888); //初始化Bitmap
    mCanvas = new Canvas(mBitmap);
    mCanvas.drawColor(Color.parseColor("#c0c0c0"));//設置畫板背景

}

@Override
protected void onDraw(Canvas canvas) {
    super.onDraw(canvas);

    Bitmap mBackBitmap = BitmapFactory.decodeResource(getResources(), R.drawable.bg);
    canvas.drawBitmap(mBackBitmap, 0, 0, null);

    mPaint.setXfermode(new PorterDuffXfermode(PorterDuff.Mode.DST_OUT));
    mCanvas.drawPath(mPath, mPaint);

    canvas.drawBitmap(mBitmap, 0, 0, null);
}


@Override
public boolean onTouchEvent(MotionEvent event) {
    pointX = event.getX();
    pointY = event.getY();
    switch (event.getAction()) {
        case MotionEvent.ACTION_DOWN:
            mPath.moveTo(pointX, pointY);//將路徑移動到點(pointX, pointY),不繪制
            break;
        case MotionEvent.ACTION_MOVE:
            mPath.lineTo(pointX, pointY);//繪制一條從上個觸點到點(pointX, pointY)的線條
            break;
    }
    invalidate();//重新繪圖
    return true;
}

private void initPaint() {//初始化畫筆
    mPaint.setDither(true);//設定是否使用圖像抖動處理,會使繪制出來的圖片顏色更加平滑和飽滿,圖像更加清晰
    mPaint.setAntiAlias(true);//設置抗鋸齒
    mPaint.setStrokeWidth(30);
    mPaint.setColor(Color.RED);//設置畫筆顏色
    mPaint.setStyle(Paint.Style.STROKE);
    mPaint.setStrokeCap(Paint.Cap.ROUND);
    mPaint.setStrokeJoin(Paint.Join.ROUND);//圓角
    mPaint.setXfermode(new PorterDuffXfermode(PorterDuff.Mode.DST));
}

}</pre>

 本文由用戶 dfd7 自行上傳分享,僅供網友學習交流。所有權歸原作者,若您的權利被侵害,請聯系管理員。
 轉載本站原創文章,請注明出處,并保留原始鏈接、圖片水印。
 本站是一個以用戶分享為主的開源技術平臺,歡迎各類分享!