Android View与SurfaceView的手绘板制作

本文总结了使用自定义View和SurfaceView在Android平台上制作手绘板的经验。通过记录路径、处理触摸事件,实现了手绘功能。View适合被动更新,适合棋类应用,而SurfaceView适合主动更新,如连续变化的场景,能避免阻塞主线程。
摘要由CSDN通过智能技术生成

最近学习了如何使用View与SurfaceView制作简单的手绘板,在此做个小结。


自定义VIew实现手绘板:


首先是使用View来实现手绘板:

package com.app.superxlcr.mydrawboard.myView;

import android.content.Context;
import android.graphics.Bitmap;
import android.graphics.Canvas;
import android.graphics.Color;
import android.graphics.Paint;
import android.graphics.Path;
import android.graphics.PorterDuff;
import android.graphics.PorterDuffXfermode;
import android.view.MotionEvent;
import android.view.View;

/**
 * Created by Superxlcr
 * On 2016/3/18
 * 普通画板View
 */
public class NormalDrawBoardView extends View {

    // 点击的坐标
    private float lastX = 0, lastY = 0;
    private Path path;
    private Paint paint;
    // 使用内存中的图片作为缓冲区
    private Bitmap cacheBitmap;
    // 缓冲区上的Canvas对象
    private Canvas cacheCanvas;

    public NormalDrawBoardView(Context context, int width, int height) {
        super(context);
        // 创建确定大小的bitmap
        cacheBitmap = Bitmap.createBitmap(width, height, Bitmap.Config.ARGB_8888);
        // 初始化缓存画布,把bitmap内容画到缓存画布上
        cacheCanvas = new Canvas();
        cacheCanvas.setBitmap(cacheBitmap);
        path = new Path();
        // 初始化画笔
        // 防抖动
        paint = new Paint(Paint.DITHER_FLAG);
        paint.setColor(Color.BLACK);
        paint.setStyle(Paint.Style.STROKE);
        paint.setStrokeWidth(1);
        // 反锯齿
        paint.setAntiAlias(true);
        paint.setDither(true);
    }

    /**
     * 设置画笔的颜色
     * @param color,颜色的字符串
     */
    public void setPaintColor(String color) {
        switch (color) {
        case "red" :
            paint.setColor(Color.RED);
            break;
        case "green" :
            paint.setColor(Color.GREEN);
            break;
        case "blue" :
            paint.setColor(Color.BLUE);
            break;
        case "yellow" :
            paint.setColor(Color.YELLOW);
            break;
        default:
            paint.setColor(Color.BLACK);
            break;
        }
    }

    /**
     * 设置画笔粗细
     * @param width
     */
    public void setPaintWidth(int width) {
        paint.setStrokeWidth(width);
    }

    public void clearCanvas() {
        // 清除path轨迹
        path.reset();
        path.moveTo(lastX, lastY);
        // 清除cacheCanvas图像
        Paint paint 
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值