Android自定义控件之圆形自定义控件之圆形/圆角的实现代码圆角的实现代码
主要为大家详细介绍了Android自定义控件之圆形/圆角的实现代码,感兴趣的小伙伴们可以参考一下
一、问题在哪里?一、问题在哪里?
问题来源于app开发中一个很常见的场景——用户头像要展示成圆的:
二、怎么搞?二、怎么搞?
机智的我,第一想法就是,切一张中间圆形透明、四周与底色相同、尺寸与头像相同的蒙板图片,盖在头像上不就完事了嘛,
哈哈哈!
在背景纯色的前提下,这的确能简单解决问题,但是如果背景没有这么简单呢?
在这种不规则背景下,有两个问题:
1)、背景图常常是适应手机宽度缩放,而头像的尺寸又是固定宽高DP的,所以固定的蒙板图片是没法保证在不同机型上都和
背景图案吻合的。
2)、在这种非纯色背景下,哪天想调整一下头像位置就得重新换图片蒙板,实在是太难维护了……
所以呢,既然头像图片肯定是方的,那就就让ImageView圆起来吧。
三、开始干活三、开始干活
基本思路是,自定义一个ImageView,通过重写onDraw方法画出一个圆形的图片来:
public class ImageViewPlus extends ImageView{
private Paint mPaintBitmap = new Paint(Paint.ANTI_ALIAS_FLAG);
private Bitmap mRawBitmap;
private BitmapShader mShader;
private Matrix mMatrix = new Matrix();
public ImageViewPlus(Context context, AttributeSet attrs) {
super(context, attrs);
}
@Override
protected void onDraw(Canvas canvas) {
Bitmap rawBitmap = getBitmap(getDrawable());
if (rawBitmap != null){
int viewWidth = getWidth();
int viewHeight = getHeight();
int viewMinSize = Math.min(viewWidth, viewHeight);
float dstWidth = viewMinSize;
float dstHeight = viewMinSize;
if (mShader == null || !rawBitmap.equals(mRawBitmap)){
mRawBitmap = rawBitmap;