服务器之家:专注于VPS、云服务器配置技术及软件下载分享
分类导航

PHP教程|ASP.NET教程|Java教程|ASP教程|编程技术|正则表达式|C/C++|IOS|C#|Swift|Android|VB|R语言|JavaScript|易语言|vb.net|

服务器之家 - 编程语言 - Android - Android自定义橡皮擦效果

Android自定义橡皮擦效果

2022-09-03 15:04676598624 Android

这篇文章主要为大家详细介绍了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 不消耗
  }
 
}

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

原文链接:https://blog.csdn.net/qq_26761229/article/details/54138111

延伸 · 阅读

精彩推荐