binbinyang-----Glide用在CircleImageView上显示默认图片的问题,以及Glide让imageview自动显示成圆形头像

时间:2021-08-05 09:24:11

 


最近在项目里.用Gilde加载图片,开始没太多问题出现,但是后面再测试的时候发现,.我的圆形控件用的-------CircleImageView,,圆形图片刚开始加载的时候,是出不来图片的,退到前一个页面,在进去,就会加载,后来到网上找了很多帖子.今天在这记录下.....如果你要做圆形头像显示,那么可以直接这么用

布局代码

 <com.meizu.views.CircleImageView
android:id="@+id/iv_mephoto"
android:layout_width="60dp"
android:layout_height="60dp"
android:layout_alignParentEnd="true"
android:layout_alignParentRight="true"
android:layout_centerVertical="true"
android:layout_marginRight="52dp"
android:onClick="changePicture"
/>
页面代码:

  Glide.with(MeInformationActivity.this)
.load(response.getImgUrl())
.centerCrop()
.diskCacheStrategy(DiskCacheStrategy.ALL)
.placeholder(R.mipmap.touxiang)
.error(R.mipmap.touxiang)
.crossFade()
.into(mPhoto);
如果这么写,就会出现一个情况..

binbinyang-----Glide用在CircleImageView上显示默认图片的问题,以及Glide让imageview自动显示成圆形头像


就会出现这种,上传后,不会被 挡住的问题

  .placeholder(R.mipmap.touxiang)
.error(R.mipmap.touxiang)



 解决方案:经过验证,可以完美实现

Glide.with(MeInformationActivity.this).load(response.getImgUrl()).asBitmap().centerCrop().into(new BitmapImageViewTarget(mPhoto) {
@Override
protected void setResource(Bitmap resource) {
RoundedBitmapDrawable circularBitmapDrawable =
RoundedBitmapDrawableFactory.create(getResources(), resource);
circularBitmapDrawable.setCircular(true);
mPhoto.setImageDrawable(circularBitmapDrawable);
}
});

把代码改成这个后,完美解决, 同时你的XML 可以不用是
CircleImageView

可以直接用imagview binbinyang-----Glide用在CircleImageView上显示默认图片的问题,以及Glide让imageview自动显示成圆形头像