使用Volley加載、緩存圖片(ImageLoader)

關(guān)鍵字:圖片緩存 LruCache ImageCache NetworkImageView ImageRequest ImageLoader

前言上篇筆記 記錄了Volley的簡單用法撞蚕,進(jìn)行簡單的GET非区、POST請求告喊。這篇文章將記錄Volley加載、緩存圖片的用法星著。

Volley還可以進(jìn)行圖片的加載和緩存,可以利用ImageRequest對象簡單粗悯、方便地進(jìn)行網(wǎng)絡(luò)圖片的獲取虚循。ImageLoader用于獲取或緩存圖片。NetworkImageView是Volley提供的一個自定義View样傍,可直接設(shè)置網(wǎng)絡(luò)圖片横缔。

1. 使用ImageRequest簡單地進(jìn)行網(wǎng)絡(luò)圖片的獲取

String url = "https://images.unsplash.com/photo-1445251836269-d158eaa028a6?fit=crop&fm=jpg&h=625&ixlib=rb-0.3.5&q=80&w=1375";
RequestQueue requestQueue = Volley.newRequestQueue(getApplicationContext());
//構(gòu)建ImageRequest 實(shí)例
ImageRequest request = new ImageRequest(url, new Response.Listener<Bitmap>() {    
      @Override    
      public void onResponse(Bitmap response) {  
          //給imageView設(shè)置圖片      
          myImageView.setImageBitmap(response);    
      }
}, 0, 0, ImageView.ScaleType.CENTER, Bitmap.Config.RGB_565, new Response.ErrorListener() {    
      @Override    
      public void onErrorResponse(VolleyError error) { 
          //設(shè)置一張錯誤的圖片,臨時用ic_launcher代替          
          myImageView.setImageResource(R.drawable.ic_launcher);    
      }
}); 

requestQueue.add(request);

注意:在構(gòu)建ImageRequest實(shí)例時衫哥,需要傳遞七個參數(shù)(六個參數(shù)的重載方法已過時茎刚,少一個ScaleType參數(shù))
這七個參數(shù)類型分別為:

  1. String : 要獲取的圖片地址
  2. Response.Listener<Bitmap> : 獲取圖片成功的回調(diào)
  3. intmaxWidth,獲取圖片的最大寬度撤逢,會自動進(jìn)行壓縮或拉伸膛锭,設(shè)置為0捌斧,即獲取原圖
  4. intmaxHeight,同上
  5. ScaleType :顯示的類型泉沾,居中捞蚂,平鋪等
  6. Config:圖片類型,如:Bitmap.Config.RGB_565
  7. Response.ErrorListener: 獲取圖片失敗的回調(diào)

2. 使用ImageLoader緩存網(wǎng)絡(luò)圖片

使用ImageLoader只需三步:

  1. 實(shí)例化ImageLoader
  2. 設(shè)置監(jiān)聽器
  3. 獲取圖片

代碼如下:
MainActivity.java文件:

RequestQueue requestQueue = Volley.newRequestQueue(getApplicationContext());
//1.實(shí)例化ImageLoader
ImageLoader loader = new ImageLoader(requestQueue, new BitmapCache());
//2.設(shè)置監(jiān)聽器
ImageLoader.ImageListener listener = 
         ImageLoader.getImageListener(myImageView, R.drawable.ic_launcher, R.drawable.ic_launcher);
//3.獲取圖片
loader.get(url, listener);

BitmapCache.java文件:

public class BitmapCache implements ImageLoader.ImageCache {    
   //LruCache對象    
   private LruCache<String, Bitmap> lruCache ;    
   //設(shè)置最大緩存為10Mb跷究,大于這個值會啟動自動回收    
   private int max = 10*1024*1024;    
   
   public BitmapCache(){       
      //初始化 LruCache
      lruCache = new LruCache<String, Bitmap>(max){            
      @Override            
      protected int sizeOf(String key, Bitmap value) {                
         return value.getRowBytes()*value.getHeight();            
      }        
     };    
   }   
   @Override    
   public Bitmap getBitmap(String url) {        
      return lruCache.get(url);    
   }    
   @Override    
   public void putBitmap(String url, Bitmap bitmap) {          
      lruCache.put(url, bitmap);    
   }
}

說明:

  1. ImageLoader構(gòu)造器需要兩個參數(shù)姓迅,requestQueue是熟悉的請求隊(duì)列,imageCache是圖片緩存對象俊马,需要自定義類實(shí)現(xiàn)imageCache對象丁存。使用LruCache來作為具體的圖片緩存對象。
  2. ImageLoader.getImageListener()需要三個參數(shù):ImageView實(shí)例柴我,默認(rèn)的圖片資源解寝,錯誤顯示的圖片資源
  3. ImageLoader調(diào)用get(ImageURL, listener)方法,獲取圖片

3. NetworkImageView的使用

layout_main.xml文件:

<?xml version="1.0" encoding="utf-8"?>
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"    
      android:layout_width="match_parent"    
      android:layout_height="match_parent"    
      android:padding="@dimen/activity_horizontal_margin"    >    
   <Button        
      android:id="@+id/button"        
      android:layout_width="wrap_content"        
      android:layout_height="wrap_content"        
      android:onClick="click"        
      android:text="獲取圖片"        
      android:layout_alignParentTop="true"        
      android:layout_centerHorizontal="true" />    
   <com.android.volley.toolbox.NetworkImageView        
      android:id="@+id/mNetworkImageView"        
      android:layout_width="wrap_content"        
      android:layout_height="wrap_content"        
      android:layout_centerVertical="true"        
      android:layout_centerHorizontal="true" />
</RelativeLayout>

BitmapCache.java文件:同“使用ImageLoader緩存網(wǎng)絡(luò)圖片”。

MainActivity.java文件:

RequestQueue requestQueue = Volley.newRequestQueue(getApplicationContext());
//實(shí)例化ImageLoader
ImageLoader loader = new ImageLoader(requestQueue, new BitmapCache());
//設(shè)置默認(rèn)圖片
mNetworkImageView.setDefaultImageResId(R.drawable.ic_launcher);
//設(shè)置錯誤圖片
mNetworkImageView.setErrorImageResId(R.drawable.ic_launcher);
//設(shè)置圖片url和ImageLoader
mNetworkImageView.setImageUrl(url,loader);
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末艘儒,一起剝皮案震驚了整個濱河市聋伦,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌界睁,老刑警劉巖觉增,帶你破解...
    沈念sama閱讀 216,997評論 6 502
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異翻斟,居然都是意外死亡逾礁,警方通過查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,603評論 3 392
  • 文/潘曉璐 我一進(jìn)店門访惜,熙熙樓的掌柜王于貴愁眉苦臉地迎上來嘹履,“玉大人,你說我怎么就攤上這事债热±担” “怎么了?”我有些...
    開封第一講書人閱讀 163,359評論 0 353
  • 文/不壞的土叔 我叫張陵阳柔,是天一觀的道長焰枢。 經(jīng)常有香客問我,道長舌剂,這世上最難降的妖魔是什么济锄? 我笑而不...
    開封第一講書人閱讀 58,309評論 1 292
  • 正文 為了忘掉前任,我火速辦了婚禮霍转,結(jié)果婚禮上荐绝,老公的妹妹穿的比我還像新娘。我一直安慰自己避消,他們只是感情好低滩,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,346評論 6 390
  • 文/花漫 我一把揭開白布召夹。 她就那樣靜靜地躺著,像睡著了一般恕沫。 火紅的嫁衣襯著肌膚如雪监憎。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 51,258評論 1 300
  • 那天婶溯,我揣著相機(jī)與錄音鲸阔,去河邊找鬼。 笑死迄委,一個胖子當(dāng)著我的面吹牛褐筛,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播叙身,決...
    沈念sama閱讀 40,122評論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼渔扎,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了信轿?” 一聲冷哼從身側(cè)響起晃痴,我...
    開封第一講書人閱讀 38,970評論 0 275
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎虏两,沒想到半個月后愧旦,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 45,403評論 1 313
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡定罢,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,596評論 3 334
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發(fā)現(xiàn)自己被綠了旁瘫。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片祖凫。...
    茶點(diǎn)故事閱讀 39,769評論 1 348
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖酬凳,靈堂內(nèi)的尸體忽然破棺而出惠况,到底是詐尸還是另有隱情,我是刑警寧澤宁仔,帶...
    沈念sama閱讀 35,464評論 5 344
  • 正文 年R本政府宣布稠屠,位于F島的核電站,受9級特大地震影響翎苫,放射性物質(zhì)發(fā)生泄漏权埠。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,075評論 3 327
  • 文/蒙蒙 一煎谍、第九天 我趴在偏房一處隱蔽的房頂上張望攘蔽。 院中可真熱鬧,春花似錦呐粘、人聲如沸满俗。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,705評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽唆垃。三九已至五芝,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間辕万,已是汗流浹背枢步。 一陣腳步聲響...
    開封第一講書人閱讀 32,848評論 1 269
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留蓄坏,地道東北人价捧。 一個月前我還...
    沈念sama閱讀 47,831評論 2 370
  • 正文 我出身青樓,卻偏偏與公主長得像涡戳,于是被迫代替她去往敵國和親结蟋。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,678評論 2 354

推薦閱讀更多精彩內(nèi)容