Android 平滑圖片載入和快取庫 Glide 使用詳解
在圖片載入庫爛大街的今天,選擇一個適合自己使用的圖片載入庫已經成為了每一個Android開發者的必經之路。現在市面上知名的圖片載入庫有UIL,Picasso,Volley ImageLoader,Fresco以及我們今天的主角Glide。它們各有千秋,不能評定誰一定比誰好,只能說哪一個更適合你。
我的理解
下面我來談一下個人對這些圖片載入庫的理解,如有錯誤,還望指教。
Universal Image Loader:一個強大的圖片載入庫,包含各種各樣的配置,最老牌,使用也最廣泛。
Picasso: Square出品,必屬精品。和OKHttp搭配起來更配呦!
Volley ImageLoader:Google官方出品,可惜不能載入本地圖片~
Fresco:Facebook出的,天生驕傲!不是一般的強大。
Glide:Google推薦的圖片載入庫,專注於流暢的滾動。
更多詳情請看stackoverflow上這個問題。
初試Glide
下面進入今天的主題,相信之前很多同學都看到過這篇介紹Glide的文章,中文版在這裡。文中從各個方面介紹和比較了Glide與Picasso,總體來說二者極為相似,有著近乎相同的API的使用風格。但Glide在快取策略和載入GIF方面略勝一籌。最後作者也極力推薦了這個庫。
而且據說在Google新出的Photos應用中,到處可見Glide的蹤跡。看到這裡,你是不是已經迫不及待的想試一試這個庫呢?就在你下定決心嘗試一記的時候,你又聽說Yelp app(據說是美國的大眾點評)也在使用這個吊炸天的庫。你的心中激動萬分,發四一定要使用這個庫。說幹就幹,開啟Android Studio,在builde.gradle裡面新增上
compile 'com.github.bumptech.glide:glide:3.6.1'
然後全域性搜尋圖片載入的地方,全部換成了下面的程式碼:
Glide.with(mContext) .load(url) .placeholder(R.drawable.loading_spinner) .crossFade() .into(myImageView);
在經過漫長的編譯過程之後,再次開啟APP,看到有著漸現效果的圖片呈現在你的面前,你不禁叫道:“wocao,真TM帥!為什麼我以前沒有發現呢?”。
不過在你使用了幾天之後你會發現一些問題:
為什麼 有的圖片第一次載入的時候只顯示佔點陣圖,第二次才顯示正常的圖片呢?
為什麼 我總會得到類似You cannot start a load for a destroyed activity這樣的異常呢?
為什麼 我不能給載入的圖片setTag()呢?
為什麼?為什麼?這麼NB的庫竟然會有這麼多的問題。沒錯,這就是我今天要講的重點。怎麼避免上面的問題發生。
一些解決方案
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 } };
2.至於第二個問題,請記住一句話:不要再非主執行緒裡面使用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,新增
<item name="image_tag" type="id"/>
大功告成!
方案二:從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這個類。
一些基於Glide的優秀庫
一個基於Glide的transformation庫,擁有裁剪,著色,模糊,濾鏡等多種轉換效果,讚的不行不行的~~
一個可以在Glide載入時很方便使用Palette的庫。
相關文章
- Android平滑圖片載入和快取庫 Glide 使用詳解Android快取IDE
- Glide 一個專注於平滑滾動的圖片載入和快取庫IDE快取
- Android圖片快取框架GlideAndroid快取框架IDE
- Glide 4.0.0 下之載入本地快取的圖片IDE快取
- android glide圖片載入框架AndroidIDE框架
- Android 圖片載入快取問題:為什麼你的Glide快取沒有起作用?Android快取IDE
- Android應用開發-圖片載入庫GlideAndroidIDE
- Android圖片載入框架Fresco使用詳解Android框架
- Android9.0使用Glide載入圖片問題AndroidIDE
- Android圖片載入的框架Fresco使用詳解Android框架
- Android 圖片載入庫Glide知其然知其所以然之載入AndroidIDE
- android ListView非同步載入圖片(雙快取)AndroidView非同步快取
- glide圖片載入原理IDE
- Android中圖片的三層快取詳解Android快取
- iOS Cell非同步圖片載入優化,快取機制詳解iOS非同步優化快取
- Android圖片快取之Glide進階Android快取IDE
- Android圖片快取之初識GlideAndroid快取IDE
- Flutter載入圖片與GlideFlutterIDE
- Android:這是一份全面 & 詳細的圖片載入庫Glide原始碼分析AndroidIDE原始碼
- Android圖片載入-Glide4.0框架封裝AndroidIDE框架封裝
- Android圖片載入庫Glide 知其然知其所以然 開篇AndroidIDE
- 開源框架——圖片載入和快取方案總結框架快取
- Android圖片快取之Bitmap詳解Android快取
- Glide載入gif圖片優化IDE優化
- 載入本地圖片模糊,Glide載入網路圖片卻很清晰地圖IDE
- 解耦圖片載入庫解耦
- js圖片預載入詳解JS
- Javascript圖片預載入詳解JavaScript
- 詳談高大上的圖片載入框架Glide -應用篇框架IDE
- 詳談高大上的圖片載入框架Glide -原始碼篇框架IDE原始碼
- Android使用LruCache、DiskLruCache實現圖片快取+圖片瀑布流Android快取
- Yelp app是如何使用Glide優化圖片載入的APPIDE優化
- Android 之 遠端圖片獲取和本地快取Android快取
- Google推薦的圖片載入庫Glide於Picasso比較GoIDE
- Android Bitmap快取池使用詳解Android快取
- 【構建Android快取模組】(三)Controller & 非同步圖片載入Android快取Controller非同步
- Android 圖片快取處理Android快取
- Glide 使用必須知道的基礎屬性——Google推薦的圖片載入庫IDEGo