Glide 加载图片非常方便,但是有时候需要加载一些圆角图片,这就需要自定义一下BitmapTransformation ,然后在使用时引用就可以了:
package com.zhiyou.aifeng.mehooh.utils;
import android.content.Context;
import android.content.res.Resources;
import android.graphics.Bitmap;
import android.graphics.BitmapShader;
import android.graphics.Canvas;
import android.graphics.Paint;
import android.graphics.RectF;
import com.bumptech.glide.load.engine.bitmap_recycle.BitmapPool;
import com.bumptech.glide.load.resource.bitmap.BitmapTransformation;
/**
* com.zhiyou.aifeng.mehooh.utils
* love
* 11:52
**/
public class GlideRoundTransform extends BitmapTransformation {
private static float radius = 0f;
public GlideRoundTransform(Context context) {
this(context, 0);
}
public GlideRoundTransform(Context context, int dp) {
super(context);
this.radius = Resources.getSystem().getDisplayMetrics().density * dp;
}
@Override
protected Bitmap transform(BitmapPool pool, Bitmap toTransform, int outWidth, int outHeight) {
return roundCrop(pool, toTransform);
}
private static Bitmap roundCrop(BitmapPool pool, Bitmap source) {
if (source == null) {
return null;
}
Bitmap result = pool.get(source.getWidth(), source.getHeight(), Bitmap.Config.ARGB_8888);
if (result == null) {
result = Bitmap.createBitmap(source.getWidth(), source.getHeight(), Bitmap.Config.ARGB_8888);
}
Canvas canvas = new Canvas(result);
Paint paint = new Paint();
paint.setShader(new BitmapShader(source, BitmapShader.TileMode.CLAMP, BitmapShader.TileMode.CLAMP));
paint.setAntiAlias(true);
RectF rectF = new RectF(0f, 0f, source.getWidth(), source.getHeight());
canvas.drawRoundRect(rectF, radius, radius, paint);
return result;
}
@Override
public String getId() {
return getClass().getName() + Math.round(radius);
}
}
使用方法:
Glide.with(App.getContext()).load(bean.getHeadImage())
.dontAnimate()
.placeholder(R.drawable.default_image)
.error(R.drawable.default_image)
.transform(new CenterCrop(App.getContext()),new GlideRoundTransform(App.getContext(),10))
.into(headIv);
可以发现我将CenterCrop放到transform()里面了,这个是因为,如果放在外面的话,就只能实现一种效果,即如果是圆角在后面的话就只会实现圆角,而中间裁剪就会被覆盖掉,这样做就能避免ccenterCrop的效果被覆盖。