android圆弧view,Android 圆角View

自定义视图实现圆角矩形背景及资源回收
该博客主要介绍了如何在自定义视图中实现带有圆角的矩形背景,并且详细讲解了onMeasure、onSizeChanged、onDraw等关键方法的使用。同时,文章探讨了资源回收的重要性,特别是在处理Bitmap时如何正确地进行回收,以避免内存泄漏。还提到了使用Xfermode来实现特定的绘图效果。

声明style

onMeasure

onSizeChanged

onDraw

资源回收

style

// 圆角半径

// 圆角颜色

onSizeChanged

mBoundedRectF.set(0,0, w, h); //矩形宽高

onDraw

canvas.saveLaver会返回给一个新的Layer, 基于几个透明的Bitmap绘制,当restoreToCount时会将Layer出栈并最终和栈顶结合在一起,此处不适用clipPath(锯齿问题),使用xfmode.

通过Path绘制带圆角的矩形.

通过XfMode的SRC_IN效果设置.

如果不是BitmapDrawable则绘制圆角矩形即可.

Drawable drawable = getDrawable();

if (drawable instanceof BitmapDrawable) {

Paint paint = ((BitmapDrawable)drawable).getPaint();

setLayerType(View.LAYER_TYPE_HARDWARE, paint);

Rect bitmapBounds = drawable.getBounds();

mDrawableRect.set(bitmapBounds);

int saveCount = canvas.saveLayer(mDrawableRect, null, Canvas.ALL_SAVE_FLAG);

getImageMatrix().mapRect(mDrawableRect);

paint.setAntiAlias(true);

paint.setColor(mHoverColor);

mPath.reset();

mPath.addRoundRect(mBoundedRectF, cornerRadius, cornerRadius, Path.Direction.CW);

canvas.drawPath(mPath, paint);

Xfermode oldMode = paint.getXfermode();

paint.setXfermode(mXfermode);

super.onDraw(canvas);

paint.setXfermode(oldMode);

canvas.restoreToCount(saveCount);

} else {

mPath.reset();

mPath.addRoundRect(mBoundedRectF, cornerRadius, cornerRadius, Path.Direction.CW);

mColorPaint.setColor(mHoverColor);

canvas.drawPath(mPath, mColorPaint);

}

资源回收

// 记录resID,回收资源

@Override

protected void onDetachedFromWindow() {

super.onDetachedFromWindow();

recycleBitmap();

once = false;

}

@Override

protected void onAttachedToWindow() {

super.onAttachedToWindow();

if (!once) {

setRoundCornerDrawable(resID);

}

}

private void recycleBitmap() {

Drawable drawable = getDrawable();

if (drawable instanceof BitmapDrawable) {

Bitmap bitmap = ((BitmapDrawable) drawable).getBitmap();

bitmap.recycle(); // c

System.gc(); // java

}

}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值