android自定义圆角矩形Imageview
来源:互联网 发布:淘宝网严重违规节点 编辑:程序博客网 时间:2024/04/30 18:31
安卓中的默认的imageview显示是矩形的,但往往我们需要做圆角矩形的图片显示,这样棱角不会太突出,之前我也没做过,目前也不是很理解其中缘由,就先做个笔记吧。
这做的也是非常简单,连自定义的属性都没有设置
首先自定义一个类继承Imageview
代码如下:
import android.widget.ImageView;import android.content.Context;import android.graphics.Bitmap;import android.graphics.Bitmap.Config;import android.graphics.Canvas;import android.graphics.Paint;import android.graphics.RectF;import android.graphics.PorterDuff.Mode;import android.graphics.PorterDuffXfermode;import android.graphics.Rect;import android.graphics.drawable.BitmapDrawable;import android.graphics.drawable.Drawable;import android.util.AttributeSet;/** * 自定义的圆角矩形ImageView,可以直接当组件在布局中使用。 * * Created by Sunny on 17/3/7. * * */public class XCRoundRectImageView extends ImageView{ private Paint paint; public XCRoundRectImageView(Context context) { this(context,null); } public XCRoundRectImageView(Context context, AttributeSet attrs) { this(context, attrs,0); } public XCRoundRectImageView(Context context, AttributeSet attrs, int defStyle) { super(context, attrs, defStyle); paint = new Paint(); } /** * 绘制圆角矩形图片 * @author caizhiming */ @Override protected void onDraw(Canvas canvas) { Drawable drawable = getDrawable(); if (null != drawable) { Bitmap bitmap = ((BitmapDrawable) drawable).getBitmap(); Bitmap b = getRoundBitmap(bitmap, 20); final Rect rectSrc = new Rect(0, 0, b.getWidth(), b.getHeight()); final Rect rectDest = new Rect(0,0,getWidth(),getHeight()); paint.reset(); canvas.drawBitmap(b, rectSrc, rectDest, paint); } else { super.onDraw(canvas); } } /** * 获取圆角矩形图片方法 * @param bitmap * @param roundPx,一般设置成14 * @return Bitmap * @author caizhiming */ private Bitmap getRoundBitmap(Bitmap bitmap, int roundPx) { Bitmap output = Bitmap.createBitmap(bitmap.getWidth(), bitmap.getHeight(), Config.ARGB_8888); Canvas canvas = new Canvas(output); final int color = 0xff424242; final Rect rect = new Rect(0, 0, bitmap.getWidth(), bitmap.getHeight()); final RectF rectF = new RectF(rect); paint.setAntiAlias(true); canvas.drawARGB(0, 0, 0, 0); paint.setColor(color); int x = bitmap.getWidth(); canvas.drawRoundRect(rectF, roundPx, roundPx, paint); paint.setXfermode(new PorterDuffXfermode(Mode.SRC_IN)); canvas.drawBitmap(bitmap, rect, rect, paint); return output; }}然后就可以在布局文件中使用了。
0 0
- Android自定义圆角矩形图片ImageView
- android自定义圆角矩形Imageview
- Android开发之自定义圆角矩形图片ImageView
- Android 圆角矩形ImageView
- 自定义ImageView实现圆角矩形
- 自定义圆角矩形或者圆形ImageView
- Android圆形ImageView和圆角矩形ImageView
- 圆角矩形ImageView
- 圆角矩形ImageView
- Android自定义ImageView实现图片圆形 ,椭圆和矩形圆角显示
- android 自定义View开发实战(四) 圆角矩形ImageView实现
- Android自定义圆角ImageView
- android 自定义圆角imageview
- Android 自定义圆角ImageView
- Android自定义圆角ImageView
- Android自定义圆角矩形
- Android自定义圆角矩形
- Android自定义View——可设置形状(圆形、圆角矩形、椭圆)的ImageView,抗锯齿
- PHP对redis操作详解
- 《将博客搬至CSDN》
- MySql优化的一般步骤:
- 分布式爬虫的设计与实现
- mysql导入数据load data infile用法整理
- android自定义圆角矩形Imageview
- HTTPS性能优化实践
- 如何利用Spring Cloud构建起自我修复型分布式系统
- BZOJ2190 SDOI2008 仪仗队
- linux添加开机自启动脚本示例详解
- 在shell脚本中调用另一个脚本的三种不同方法(fork, exec, source)
- Buffer Cache 原理
- 微信小程序小笔记
- 浅谈架构之路:前后端分离模式