我是靠谱客的博主 俊逸咖啡豆,这篇文章主要介绍Android自定义橡皮擦效果,现在分享给大家,希望可以做个参考。

本文实例为大家分享了Android自定义橡皮擦效果,使用贝塞尔曲线处理曲线转折处

复制代码
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
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
public class picFingerToTest extends View { private Paint paint; private Bitmap decodeResourceSRC; private Bitmap createBitmapDST; // 手指路径,使用贝塞尔路线 private Path path; private float perX; private float perY; public picFingerToTest(Context context, AttributeSet attrs) { super(context, attrs); // 1、设置禁用硬件设置 setLayerType(View.LAYER_TYPE_SOFTWARE, null); // 2、设置手指画笔 paint = new Paint(); paint.setAntiAlias(true); paint.setColor(Color.RED); paint.setStyle(Paint.Style.STROKE); paint.setStrokeWidth(45); // 3、生成图像手指源目标 // 源 decodeResourceSRC = BitmapFactory.decodeResource(getResources(), R.drawable.welcome, null); // 目标 createBitmapDST = Bitmap.createBitmap(decodeResourceSRC.getWidth(), decodeResourceSRC.getHeight(), Config.ARGB_8888); path = new Path(); } @Override protected void onDraw(Canvas canvas) { super.onDraw(canvas); // 分层绘制 int saveLayer = canvas.saveLayer(0, 0, getWidth(), getHeight(), null,Canvas.ALL_SAVE_FLAG); // 把手指轨迹划到目标路径上 Canvas canvas2 = new Canvas(createBitmapDST); canvas2.drawPath(path, paint); // 把目标图像画到画布上 canvas.drawBitmap(createBitmapDST, 0, 0, paint); // 计算源图像区域 paint.setXfermode(new PorterDuffXfermode(Mode.SRC_OUT)); canvas.drawBitmap(decodeResourceSRC, 0, 0, paint); paint.setXfermode(null); canvas.restoreToCount(saveLayer); } //使用贝塞尔曲线,使折线过度圆滑 @Override public boolean onTouchEvent(MotionEvent event) { switch (event.getAction()) { // 记录手指触摸的初始化位置 case MotionEvent.ACTION_DOWN: path.moveTo(event.getX(), event.getY()); perX = event.getX(); perY = event.getY(); return true; case MotionEvent.ACTION_MOVE: float endX = (perX + event.getX()) / 2; float endY = (perY + event.getY()) / 2; path.quadTo(perX, perY, endX, endY); perX = event.getX(); perY = event.getY(); postInvalidate(); break; case MotionEvent.ACTION_UP: break; default: break; } return super.onTouchEvent(event); } }

小编再为大家补充一段代码:android橡皮擦擦图片功能

复制代码
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
public void onCreate() { //底边图片 ImageView ivTop = (ImageView) findViewByid(R.id.iv_top); Options opts = new Options(); //图片加载器,用于配置一些缩放比例,和像素单位 opts.inSampleSize = 2; //制定加载器把原图片的宽高缩放到2/1的效果加载 //获得外层图片,decodeResource方法默认获得的像素单位是RGB(red,green,blue),ARGB(alpha,red,green,blue) Bitmap topImage = BitmapFactory.decodeResources( getResource(),R.drawable.top, opts); //创建一张空白图片,并且把图片想读单位指定为:ARGB Bitmap blank = Bitmap.createBitmap(topImage.getWidth(), topImage.getHeight, Config.ARGB_4444); //把上边的topImage画到空白图片上 Canvas canvas = new Canvas(blank); //把topImage画到空白图片上但是像素单位变成ARGB() canvas.drawBitmap(topImage, 0, 0, null); ivTop.setImageBitmap(blank); } class MyOnTouchListoner implements OnTouchListener { @Override pulic boolean OnTouch(View v, MotionEvent event) { //是否是移动的事件 if (event.getAction() == MotionEvent.ACTION_MOVE) { //获得按下坐标 int x = (int) event.getX(); int y = (int) event.getY(); for (int i = x - 10; i < x + 10; i++) { for (int j = y - 10; j < y + 10; j++) { //防止超出边界 if (j >= 0 && blank.getHeight() && i >= 0 && i < blank.getWidth()) { blank.setPixel(i, j, Color.TRANSPARENT); } } } //修改后的图片设置给ImageView ivTop.setImageBitmap(blank); } return true; //true 消耗掉这次触摸事件.false 不消耗 } }

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持靠谱客。

最后

以上就是俊逸咖啡豆最近收集整理的关于Android自定义橡皮擦效果的全部内容,更多相关Android自定义橡皮擦效果内容请搜索靠谱客的其他文章。

本图文内容来源于网友提供,作为学习参考使用,或来自网络收集整理,版权属于原作者所有。
点赞(143)

评论列表共有 0 条评论

立即
投稿
返回
顶部