天天看點

Android 平滑圖檔加載和緩存庫 Glide

轉載:http://www.codeceo.com/article/android-glide-usage.html

1.如果你剛好使用了這個圓形Imageview庫或者其他的一些自定義的圓形Imageview,而你又剛好設定了占位的話,那麼,你就會遇到第一個問題。如何解決呢?

方案一: 不設定占位;

方案二:使用Glide的Transformation API自定義圓形Bitmap的轉換。這裡是一個已有的例子;

方案三:使用下面的代碼加載圖檔:

Glide.with(mContext)
    .load(url) 
    .placeholder(R.drawable.loading_spinner)
    .into(new SimpleTarget<Bitmap>(width, height) {
        @Override 
        public void onResourceReady(Bitmap bitmap, GlideAnimation anim) {
            // setImageBitmap(bitmap) on CircleImageView 
        } 
    };
           

于第二個問題,請記住一句話:不要再非主線程裡面使用Glide加載圖檔,如果真的使用了,請把context參數換成getApplicationContext。更多的細節請參考這個issue。

3.為什麼不能設定Tag,是因為你使用的姿勢不對哦。如何為ImageView設定Tag呢?且聽我細細道來。

方案一:使用setTag(int,object)方法設定tag,具體用法如下:

Java代碼是醬紫的:

Glide.with(context).load(urls.get(i).getUrl()).fitCenter().into(imageViewHolder.image);
        imageViewHolder.image.setTag(R.id.image_tag, i);
        imageViewHolder.image.setOnClickListener(new View.OnClickListener() {
            @Override
                int position = (int) v.getTag(R.id.image_tag);
                Toast.makeText(context, urls.get(position).getWho(), Toast.LENGTH_SHORT).show();
            }
        });
           

同時在values檔案夾下建立ids.xml,添加

大功告成!

方案二:從Glide的3.6.0之後,新添加了全局設定的方法。具體方法如下:

先實作GlideMoudle接口,全局設定ViewTaget的tagId:

public class MyGlideMoudle implements GlideModule{
    @Override
    public void applyOptions(Context context, GlideBuilder builder) {
        ViewTarget.setTagId(R.id.glide_tag_id);
    }

    @Override
    public void registerComponents(Context context, Glide glide) {

    }
}
           

同樣,也需要在ids.xml下添加id

<item name="glide_tag_id" type="id"/>
           

最後在AndroidManifest.xml檔案裡面添加

<meta-data
    android:name="com.yourpackagename.MyGlideMoudle"
    android:value="GlideModule" />
           

又可以愉快的玩耍了,嘻嘻`(∩_∩)′。

方案三:寫一個繼承自ImageViewTaget的類,複寫它的

get/setRequest方法。
Glide.with(context).load(urls.get(i).getUrl()).fitCenter().into(new ImageViewTarget<GlideDrawable>(imageViewHolder.image) {
            @Override
            protected void setResource(GlideDrawable resource) {
                imageViewHolder.image.setImageDrawable(resource);
            }

            @Override
            public void setRequest(Request request) {
                imageViewHolder.image.setTag(i);
                imageViewHolder.image.setTag(R.id.glide_tag_id,request);
            }

            @Override
            public Request getRequest() {
                return (Request) imageViewHolder.image.getTag(R.id.glide_tag_id);
            }
        });

        imageViewHolder.image.setOnClickListener(new View.OnClickListener() {
            @Override
            public void onClick(View v) {
                int position = (int) v.getTag();
                Toast.makeText(context, urls.get(position).getWho(), Toast.LENGTH_SHORT).show();
            }
        });
           

一些使用技巧

1.Glide.with(context).resumeRequests()和 Glide.with(context).pauseRequests()

當清單在滑動的時候,調用pauseRequests()取消請求,滑動停止時,調用resumeRequests()恢複請求。這樣是不是會好些呢?

2.Glide.clear()

當你想清除掉所有的圖檔加載請求時,這個方法可以幫助到你。

3.ListPreloader

如果你想讓清單預加載的話,不妨試一下ListPreloader這個類。