温馨提示×

温馨提示×

您好,登录后才能下订单哦!

密码登录×
登录注册×
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》

如何解决Android中Glide与CircleImageView加载圆形图片的问题

发布时间:2021-07-21 13:52:19 来源:亿速云 阅读:592 作者:小新 栏目:移动开发

这篇文章将为大家详细讲解有关如何解决Android中Glide与CircleImageView加载圆形图片的问题,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。

1. 不使用占位符

注释掉这两句代码即可。

.placeholder(R.drawable.normal_photo)
    .error(R.drawable.normal_photo)

Glide 加载时的代码:

Glide.with(mContext)
                .load(datas.getUser_img())
                .centerCrop()
                .into(ivAvator);

此时XML中的还是CircleImageView,代码如下:

<de.hdodenhof.circleimageview.CircleImageView
      android:id="@+id/iv_avator"
      android:layout_width="130px"
      android:layout_height="130px"
      android:src="@drawable/normal_photo" />

2. 不使用默认动画

添加一句代码即可:

.dontAnimate()//防止设置placeholder导致第一次不显示网络图片,只显示默认图片的问题

此时Glide加载时的完整代码:

Glide.with(mContext)
        .load(datas.getUser_img())
        .centerCrop()
        .dontAnimate()//防止设置placeholder导致第一次不显示网络图片,只显示默认图片的问题
        .error(R.drawable.normal_photo)
        .placeholder(R.drawable.normal_photo)
        .into(ivAvator);

此时XML中的依然是CircleImageView,这没什么好说的。代码如下:

<de.hdodenhof.circleimageview.CircleImageView
      android:id="@+id/iv_avator"
      android:layout_width="130px"
      android:layout_height="130px"
      android:src="@drawable/normal_photo" />

3. 使用glide本身的圆形加载方式

这里就直接看下Glide加载时的代码,注意:

此时的ivAvator可以使用普通的ImageView,不必再引入CircleImageView第三方框架。(当然你依然可以写成CircleImageView)

asBitmap() 这句不能少,否则下面的方法会报错。

Glide.with(mContext)
       .load(datas.getUser_img())
       .asBitmap() //这句不能少,否则下面的方法会报错
       .centerCrop()
       .into(new BitmapImageViewTarget(ivAvator) {
         @Override
         protected void setResource(Bitmap resource) {
           RoundedBitmapDrawable circularBitmapDrawable =
               RoundedBitmapDrawableFactory.create(getResources(), resource);
           circularBitmapDrawable.setCircular(true);
           ivAvator.setImageDrawable(circularBitmapDrawable);
         }
       });

此时xml中的代码修改成ImageView,代码如下:

<ImageView
      android:id="@+id/iv_avator"
      android:layout_width="130px"
      android:layout_height="130px"
      android:src="@drawable/normal_photo" />

4. 同样使用Glide本身的圆形加载方式

这种方式和上面的基本类似。首先GlideCircleTransform继承BitmapTransformation,代码如下:

//圆形图片
public class GlideCircleTransform extends BitmapTransformation {
  public GlideCircleTransform(Context context) {
    super(context);
  }

  @Override protected Bitmap transform(BitmapPool pool, Bitmap toTransform, int outWidth, int outHeight) {
    return circleCrop(pool, toTransform);
  }

  private static Bitmap circleCrop(BitmapPool pool, Bitmap source) {
    if (source == null) return null;

    int size = Math.min(source.getWidth(), source.getHeight());
    int x = (source.getWidth() - size) / 2;
    int y = (source.getHeight() - size) / 2;

    // TODO this could be acquired from the pool too
    Bitmap squared = Bitmap.createBitmap(source, x, y, size, size);

    Bitmap result = pool.get(size, size, Bitmap.Config.ARGB_8888);
    if (result == null) {
      result = Bitmap.createBitmap(size, size, Bitmap.Config.ARGB_8888);
    }

    Canvas canvas = new Canvas(result);
    Paint paint = new Paint();
    paint.setShader(new BitmapShader(squared, BitmapShader.TileMode.CLAMP, BitmapShader.TileMode.CLAMP));
    paint.setAntiAlias(true);
    float r = size / 2f;
    canvas.drawCircle(r, r, r, paint);
    return result;
  }

  @Override public String getId() {
    return getClass().getName();
  }
}

Glide加载时的代码如下:

Glide.with(mContext)
                .load(datas.getUser_img())
                .centerCrop()
                .error(R.drawable.normal_photo)
                .placeholder(R.drawable.normal_photo)
                .transform(new GlideCircleTransform(mContext))
                .into(ivAvator);

注意: 此时的ivAvator依然可以是ImageView(当然你依然可以写成CircleImageView) 。代码如下:

<ImageView
      android:id="@+id/iv_avator"
      android:layout_width="130px"
      android:layout_height="130px"
      android:src="@drawable/normal_photo" />

关于“如何解决Android中Glide与CircleImageView加载圆形图片的问题”这篇文章就分享到这里了,希望以上内容可以对大家有一定的帮助,使各位可以学到更多知识,如果觉得文章不错,请把它分享出去让更多的人看到。

向AI问一下细节

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

AI