android Canvas 裁剪

本文介绍如何使用 Android 的 Canvas 进行图形裁剪,包括创建裁剪选区、利用 Op 参数控制裁剪效果等关键步骤。通过实例演示了如何实现圆形裁剪。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

今天由于要对图片进行裁剪,即裁剪图片的某一部分,或者说一个特定的闭合图形。

首先想到是canvas 的 slip方法,其提供了很多样式的裁剪,这里就不一一指出。

要弄清的是,这里canvas裁剪,是对bitmap的裁剪吗,我的回答 :NO 。

个人理解:canvas只是画布,其slip方法就像创建一个裁剪选区,只有该画布上的这个选区才能可见。就像你通过圆形的孔去看世界,那么世界也是圆的。

这样想来,想裁剪你要的图形就简单多了。

先看代码:

Bitmap bitmap = BitmapFactory.decodeResource(getResources(), R.drawable.round_back).copy(Config.ARGB_8888, true);
int width = bitmap.getWidth();
int height = bitmap.getHeight();
			
Bitmap newBitmap = Bitmap.createBitmap(width, height, Config.ARGB_8888);
			
Canvas canvas = new Canvas(newBitmap);
Path path = new Path();
path.addCircle(width/2, height/2, width/4, Path.Direction.CCW);
canvas.clipPath(path,Op.REPLACE);
Rect rect = new Rect(0,0,width/2,height/2) ;
canvas.drawBitmap(bitmap, 0, 0, new Paint());
ivTest.setImageBitmap(newBitmap);
这里先创建一张空白的newBitmap,然后对空白的newBitmap 进行裁剪,裁剪区域是一个circle。

然后将bitmap资源画上去,此时 只有在裁剪区域的图才能被画,于是乎得到的newBitmap 就是我们想要的图。

另外,裁剪选区的时候有一个Op参数,其参数含义可以查看 http://developer.android.com/reference/android/graphics/Region.Op.html,用于选择我们裁剪之后的可见部分。

完工。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值