如何解決Android中Glide與CircleImageView加載圓形圖片的問題

這篇文章將為大家詳細(xì)講解有關(guān)如何解決Android中Glide與CircleImageView加載圓形圖片的問題,小編覺得挺實(shí)用的,因此分享給大家做個參考,希望大家閱讀完這篇文章后可以有所收獲。

專注于為中小企業(yè)提供成都網(wǎng)站設(shè)計(jì)、做網(wǎng)站服務(wù),電腦端+手機(jī)端+微信端的三站合一,更高效的管理,為中小企業(yè)晉江免費(fèi)做網(wǎng)站提供優(yōu)質(zhì)的服務(wù)。我們立足成都,凝聚了一批互聯(lián)網(wǎng)行業(yè)人才,有力地推動了上1000+企業(yè)的穩(wěn)健成長,幫助中小企業(yè)通過網(wǎng)站建設(shè)實(shí)現(xiàn)規(guī)模擴(kuò)充和轉(zhuǎn)變。

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. 不使用默認(rèn)動畫

添加一句代碼即可:

.dontAnimate()//防止設(shè)置placeholder導(dǎo)致第一次不顯示網(wǎng)絡(luò)圖片,只顯示默認(rèn)圖片的問題

此時Glide加載時的完整代碼:

Glide.with(mContext)
        .load(datas.getUser_img())
        .centerCrop()
        .dontAnimate()//防止設(shè)置placeholder導(dǎo)致第一次不顯示網(wǎng)絡(luò)圖片,只顯示默認(rèn)圖片的問題
        .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第三方框架。(當(dāng)然你依然可以寫成CircleImageView)

asBitmap() 這句不能少,否則下面的方法會報(bào)錯。

Glide.with(mContext)
       .load(datas.getUser_img())
       .asBitmap() //這句不能少,否則下面的方法會報(bào)錯
       .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(當(dāng)然你依然可以寫成CircleImageView) 。代碼如下:

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

關(guān)于“如何解決Android中Glide與CircleImageView加載圓形圖片的問題”這篇文章就分享到這里了,希望以上內(nèi)容可以對大家有一定的幫助,使各位可以學(xué)到更多知識,如果覺得文章不錯,請把它分享出去讓更多的人看到。

本文標(biāo)題:如何解決Android中Glide與CircleImageView加載圓形圖片的問題
文章位置:http://muchs.cn/article38/pisgsp.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供品牌網(wǎng)站制作、網(wǎng)站策劃、網(wǎng)站設(shè)計(jì)、ChatGPT、App設(shè)計(jì)、動態(tài)網(wǎng)站

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會在第一時間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時需注明來源: 創(chuàng)新互聯(lián)

微信小程序開發(fā)