Android自定义View——可设置形状(圆形、圆角矩形、椭圆)的ImageView,抗锯齿

本文介绍如何在Android中创建自定义的ImageView,支持显示为圆形、圆角矩形或椭圆形,并解决图片边缘锯齿问题。通过使用BitmapShader作为画笔的渲染器,避免了canvas.clipPath()导致的锯齿现象,提供了一种高效且灵活的解决方案。
摘要由CSDN通过智能技术生成
(如果对自定义View不太熟悉,可以查看上篇文章《 Android自定义View——基础知识篇》)

有时显示的图片(如用户头像)是圆形或者圆角矩形的,如果我们把每一种形状的图片都裁剪成一个图片文件,这样既麻烦也浪费空间,所以最好的办法是通过代码来设置图片的显示形状。显示图片用到的是ImageView,最简单的设置图片形状的方法就是在draw()里面通过canvas.clipPath()把画布裁剪成相应形状,但这种方法有个很大的缺点,就是边缘锯齿明显。

这里我通过BitmapShader来绘制图片,可以很好地解决锯齿的问题,将画笔的渲染器设置成BitmapShader,则通过画笔绘制的图案则以图片为背景。关键步骤为:

// 获取图片
Bitmap bitmap = Util.getBitmapFromDrawable(getDrawable());
// 设置图片渲染器
mBitmapShader = new BitmapShader(bitmap, Shader.TileMode.CLAMP, Shader.TileMode.CLAMP);
// 把渲染器放入画笔中
mBitmapPaint.setShader(mBitmapShader);
// 在画布上画圆,即可绘制出圆形图片
canvas.drawCircle(cx, cy, radius, mBitmapPaint);

效果如下:



关键代码:
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值