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