第一步:写一个工具类
public class BitmapUtils { public static Bitmap circleBitmap(Bitmap source) { //获取Bitmap的宽度 int width = source.getWidth(); //以Bitmap的宽度值作为新的bitmap的宽高值。 Bitmap bitmap = Bitmap.createBitmap(width, width, Bitmap.Config.ARGB_8888); //以此bitmap为基准,创建一个矩形画布 Canvas canvas = new Canvas(bitmap); Paint paint = new Paint(); paint.setAntiAlias(true); //在画布上画一个圆 canvas.drawCircle(width / 2, width / 2, width / 2, paint); //设置图片相交情况下的处理方式 //setXfermode:设置当绘制的图像出现相交情况时候的处理方式的,它包含的常用模式有: //PorterDuff.Mode.SRC_IN 取两层图像交集部分,只显示上层图像 //PorterDuff.Mode.DST_IN 取两层图像交集部分,只显示下层图像 paint.setXfermode(new PorterDuffXfermode(PorterDuff.Mode.SRC_IN)); //在画布上绘制bitmap canvas.drawBitmap(source, 0, 0, paint); return bitmap; } //实现图片的压缩处理 //设置宽高必须使用浮点型,否则导致压缩的比例:0 public static Bitmap zoom(Bitmap sorce, float width, float heigth) { Matrix matrix = new Matrix(); //图片压缩处理 matrix.postScale(width / sorce.getWidth(), heigth / sorce.getHeight()); Bitmap bitmap = Bitmap.createBitmap(sorce, 0, 0, sorce.getWidth(), sorce.getHeight(), matrix, false); return bitmap; } }第二步:利用Picasso插件显示图片
String url = "http://mm.chinasareview.com/wp-content/uploads/2017a/08/01/01.jpg"; Picasso.with(getContext()).load(url).transform(new Transformation() { @Override public Bitmap transform(Bitmap source) { //压缩处理 Bitmap bitmap = BitmapUtils.zoom(source, UIUtils.dp2px(62),UIUtils.dp2px(62)); //圆形处理 bitmap = BitmapUtils.circleBitmap(bitmap); source.recycle(); return bitmap; } @Override public String key() { return "";//需要保证返回值不能为null。否则报错 } }).into(ivMeIcon);
效果图: