欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Android Imageloader的配置的實(shí)現(xiàn)代碼

 更新時(shí)間:2017年07月23日 11:13:09   作者:程序小渣渣  
這篇文章主要介紹了Android Imageloader的配置的實(shí)現(xiàn)代碼的相關(guān)資料,需要的朋友可以參考下

Android Imageloader的配置的實(shí)現(xiàn)代碼

  ImageLoader 優(yōu)點(diǎn)

(1) 支持下載進(jìn)度監(jiān)聽

(2) 可以在 View 滾動(dòng)中暫停圖片加載

通過 PauseOnScrollListener 接口可以在 View 滾動(dòng)中暫停圖片加載。

(3) 默認(rèn)實(shí)現(xiàn)多種內(nèi)存緩存算法 這幾個(gè)圖片緩存都可以配置緩存算法,不過 ImageLoader 默認(rèn)實(shí)現(xiàn)了較多緩存算法,如 Size

最大先刪除、使用最少先刪除、最近最少使用、先進(jìn)先刪除、時(shí)間最長(zhǎng)先刪除等。

(4) 支持本地緩存文件名規(guī)則定義     

實(shí)現(xiàn)代碼:


/** 
 * 初始化ImageLoader 
 */ 
public static void initImageLoader(Context context) { 
  File cacheDir = StorageUtils.getOwnCacheDirectory(context, 
      "bee_k77/Cache");// 獲取到緩存的目錄地址 
  Log.e("cacheDir", cacheDir.getPath()); 
  // 創(chuàng)建配置ImageLoader(所有的選項(xiàng)都是可選的,只使用那些你真的想定制),這個(gè)可以設(shè)定在APPLACATION里面,設(shè)置為全局的配置參數(shù) 
  ImageLoaderConfiguration config = new ImageLoaderConfiguration.Builder( 
      context) 
      // max width, max height,即保存的每個(gè)緩存文件的最大長(zhǎng)寬 
      .memoryCacheExtraOptions(480, 800) 
      // Can slow ImageLoader, use it carefully (Better don't use it)設(shè)置緩存的詳細(xì)信息,最好不要設(shè)置這個(gè) 
/        .discCacheExtraOptions(480, 800, CompressFormat.JPEG, 75, null)  
      // 線程池內(nèi)加載的數(shù)量 
      .threadPoolSize(3) 
      // 線程優(yōu)先級(jí) 
      .threadPriority(Thread.NORM_PRIORITY - 2) 
      /* 
       * When you display an image in a small ImageView 
       * and later you try to display this image (from identical URI) in a larger ImageView 
       * so decoded image of bigger size will be cached in memory as a previous decoded image of smaller size. 
       * So the default behavior is to allow to cache multiple sizes of one image in memory. 
       * You can deny it by calling this method: 
       * so when some image will be cached in memory then previous cached size of this image (if it exists) 
       *  will be removed from memory cache before. 
       */ 
/        .denyCacheImageMultipleSizesInMemory() 
       
      // You can pass your own memory cache implementation你可以通過自己的內(nèi)存緩存實(shí)現(xiàn) 
      // .memoryCache(new UsingFreqLimitedMemoryCache(2 * 1024 * 1024))  
      // .memoryCacheSize(2 * 1024 * 1024) 
      //硬盤緩存50MB 
      .diskCacheSize(50 * 1024 * 1024) 
       //將保存的時(shí)候的URI名稱用MD5 
      .diskCacheFileNameGenerator(new Md5FileNameGenerator()) 
      // 加密 
       .diskCacheFileNameGenerator(new HashCodeFileNameGenerator())//將保存的時(shí)候的URI名稱用HASHCODE加密 
      .tasksProcessingOrder(QueueProcessingType.LIFO) 
       .diskCacheFileCount(100) //緩存的File數(shù)量 
      .diskCache(new UnlimitedDiscCache(cacheDir))// 自定義緩存路徑 
      // .defaultDisplayImageOptions(DisplayImageOptions.createSimple()) 
      // .imageDownloader(new BaseImageDownloader(context, 5 * 1000, 
      // 30 * 1000)) // connectTimeout (5 s), readTimeout (30 s)超時(shí)時(shí)間 
      .writeDebugLogs() // Remove for release app 
      .build(); 
  // Initialize ImageLoader with configuration. 
  ImageLoader.getInstance().init(config);// 全局初始化此配置 
} 

Option類

package com.topnews.config; 
 
import android.graphics.Bitmap; 
 
import com.nostra13.universalimageloader.core.DisplayImageOptions; 
import com.nostra13.universalimageloader.core.assist.ImageScaleType; 
import com.nostra13.universalimageloader.core.display.FadeInBitmapDisplayer; 
import com.topnews.R; 
 
public class Options { 
  /** 
   * 新聞列表中用到的圖片加載配置 
   */ 
  public static DisplayImageOptions getListOptions() { 
    DisplayImageOptions options = new DisplayImageOptions.Builder() 
    // 設(shè)置圖片在下載期間顯示的圖片 
        .showImageOnLoading(R.drawable.ic_stub) 
        // 設(shè)置圖片Uri為空或是錯(cuò)誤的時(shí)候顯示的圖片 
        .showImageForEmptyUri(R.drawable.ic_stub) 
        // 設(shè)置圖片加載/解碼過程中錯(cuò)誤時(shí)候顯示的圖片 
        .showImageOnFail(R.drawable.ic_error) 
        // 設(shè)置下載的圖片是否緩存在內(nèi)存中 
        .cacheInMemory(false) 
        // 設(shè)置下載的圖片是否緩存在SD卡中 
        .cacheOnDisc(true) 
        // 保留Exif信息 
        .considerExifParams(true) 
        // 設(shè)置圖片以如何的編碼方式顯示 
        .imageScaleType(ImageScaleType.EXACTLY_STRETCHED) 
        // 設(shè)置圖片的解碼類型 
        .bitmapConfig(Bitmap.Config.RGB_565) 
        // .decodingOptions(android.graphics.BitmapFactory.Options 
        // decodingOptions)//設(shè)置圖片的解碼配置 
        .considerExifParams(true) 
        // 設(shè)置圖片下載前的延遲 
        .delayBeforeLoading(100)// int 
        // delayInMillis為你設(shè)置的延遲時(shí)間 
        // 設(shè)置圖片加入緩存前,對(duì)bitmap進(jìn)行設(shè)置 
        // .preProcessor(BitmapProcessor preProcessor) 
        .resetViewBeforeLoading(true)// 設(shè)置圖片在下載前是否重置,復(fù)位 
        // .displayer(new RoundedBitmapDisplayer(20))//是否設(shè)置為圓角,弧度為多少 
        .displayer(new FadeInBitmapDisplayer(100))// 淡入 
        .build(); 
    return options; 
  } 
} 

感謝閱讀,希望能幫助到大家,謝謝大家對(duì)本站的支持!

相關(guān)文章

最新評(píng)論