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