概述
用于记录工具
/**
* 加载圆形图片
* @param context
* @param view
* @param url
*/
public static void setCirclePicture(Context context, ImageView view, String url) {
GlideApp.with(context)
.load(url)
.diskCacheStrategy(DiskCacheStrategy.RESOURCE)
.error(R.mipmap.head_deficon)
.placeholder(R.mipmap.head_deficon)
.transform(new CircleCrop())
.into(view);
}
/**
* 加载圆角图片
*
* @param context 上下文
* @param view 图片控件
* @param url 网络图片地址
* @param radius 圆角度数
* @param errorid 错误图片
*/
public static void setPicture(Context context, ImageView view, String url, int radius,
@DrawableRes int errorid) {
if (view == null) {
return;
}
RequestOptions options = bitmapTransform(new CenterCropRoundCornerTransform(radius));
GlideApp.with(context)
.load(url)
.apply(options)
.placeholder(R.drawable.loading)
.diskCacheStrategy(DiskCacheStrategy.AUTOMATIC)
.error(errorid)
.into(view);
}
关键类;
public class CenterCropRoundCornerTransform extends CenterCrop {
private static float radius = 0f;
public CenterCropRoundCornerTransform(int px) {
this.radius = px;
}
@Override
protected Bitmap transform(BitmapPool pool, Bitmap toTransform, int outWidth, int outHeight) {
Bitmap bitmap = TransformationUtils.centerCrop(pool, toTransform, outWidth, outHeight);
return roundCrop(pool, bitmap);
}
private static Bitmap roundCrop(BitmapPool pool, Bitmap source) {
if (source == null) return null;
Bitmap result = pool.get(source.getWidth(), source.getHeight(), Bitmap.Config.ARGB_4444);
if (result == null) {
result = Bitmap.createBitmap(source.getWidth(), source.getHeight(), Bitmap.Config.ARGB_4444);
}
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;
}
public String getId() {
return getClass().getName() + Math.round(radius);
}
@Override
public void updateDiskCacheKey(MessageDigest messageDigest) {
}
}
最后
以上就是温暖绿草为你收集整理的Glide4加载图片显示圆角和显示头像圆形图片的全部内容,希望文章能够帮你解决Glide4加载图片显示圆角和显示头像圆形图片所遇到的程序开发问题。
如果觉得靠谱客网站的内容还不错,欢迎将靠谱客网站推荐给程序员好友。
本图文内容来源于网友提供,作为学习参考使用,或来自网络收集整理,版权属于原作者所有。
发表评论 取消回复