Android車輪之圖片加載框架Android-Universal-Image-Loader

前言:從學(xué)習(xí)Android已經(jīng)有十周時(shí)間了,之前都在學(xué)習(xí)PHP腳本語(yǔ)言策泣,曾經(jīng)還用純php寫了一個(gè)小型論壇衙傀,雖然不難,即使你用的東西自己同樣封裝了萨咕,但是最終總是感覺(jué)不太舒服统抬,后來(lái)就用了國(guó)內(nèi)的ThinkPHP框架作為框架學(xué)習(xí),然而就慢慢體驗(yàn)到了使用框架的好處危队,比如優(yōu)化的程序較好聪建,更容易學(xué)習(xí)到框架里面不錯(cuò)的知識(shí)模塊......
其實(shí)Android也是一樣的,倘若你開(kāi)發(fā)一個(gè)項(xiàng)目的話交掏,一切都從零開(kāi)始妆偏,嘿嘿刃鳄,那你就可悲╮(╯▽╰)╭盅弛,對(duì)于開(kāi)源的東西,學(xué)會(huì)選擇輪子以及會(huì)用輪子對(duì)于開(kāi)發(fā)項(xiàng)目是非常重要的叔锐,接下來(lái)介紹的輪子就是Android-Universal-Image-Loader圖片加載框架挪鹏。


****Android-Universal-Image-Loader簡(jiǎn)介****
Android-Universal-Image-Loader是當(dāng)前非常流行的一款開(kāi)源圖片加載框架。


****Android-Universal-Image-Loader優(yōu)點(diǎn)****

  • 多線程下載圖片愉烙,圖片可以來(lái)源于網(wǎng)絡(luò)讨盒,文件系統(tǒng),項(xiàng)目文件夾assets中以及drawable中等
  • 支持隨意的配置ImageLoader步责,例如線程池返顺,圖片下載器,內(nèi)存緩存策略蔓肯,硬盤緩存策略遂鹊,圖片顯示選項(xiàng)以及其他的一些配置
  • 支持圖片的內(nèi)存緩存,文件系統(tǒng)緩存或者SD卡緩存
  • 支持圖片下載過(guò)程的監(jiān)聽(tīng)
  • 根據(jù)控件(ImageView)的大小對(duì)Bitmap進(jìn)行裁剪蔗包,減少Bitmap占用過(guò)多的內(nèi)存
  • 較好的控制圖片的加載過(guò)程秉扑,例如暫停圖片加載,重新開(kāi)始加載圖片调限,一般使用在ListView,GridView中舟陆,滑動(dòng)過(guò)程中暫停加載圖片,停止滑動(dòng)的時(shí)候去加載圖片
  • 提供在較慢的網(wǎng)絡(luò)下對(duì)圖片進(jìn)行加載

****Android-Universal-Image-Loader使用****
為了避免配置使用重復(fù)的代碼耻矮,自己編寫了點(diǎn)小封裝
Step-One:配置ImageLoaderConfiguration

package com.samego.alic.androidutils.common;
/**
 * Created by alic on 16-5-17.
 */
public class SameGoApplication extends Application {
    @Override
    public void onCreate() {
        super.onCreate();
        initImageLoaderConfiguration(getApplicationContext());
    }

    /**
     * 初始化ImageLoaderConfiguration配置
     *
     * @param context 上下文
     */
    public void initImageLoaderConfiguration(Context context) {
        //緩存文件目錄
        File cacheDir = StorageUtils.getCacheDirectory(context);
        //構(gòu)建配置
        ImageLoaderConfiguration config = new ImageLoaderConfiguration.Builder(context)
                //默認(rèn)屏幕的大小
                .memoryCacheExtraOptions(480, 800)
                        // 內(nèi)存緩存的設(shè)置選項(xiàng) (最大圖片寬度,最大圖片高度) 默認(rèn)當(dāng)前屏幕分辨率
                .diskCacheExtraOptions(480, 800, null)
                        // 設(shè)置自定義加載和顯示圖片的線程池
                .taskExecutor(DefaultConfigurationFactory.createExecutor(3, Thread.NORM_PRIORITY, QueueProcessingType.LIFO))
                        // 設(shè)置自定義加載和顯示內(nèi)存緩存或者硬盤緩存圖片的線程池
                .taskExecutorForCachedImages(DefaultConfigurationFactory.createExecutor(3, Thread.NORM_PRIORITY, QueueProcessingType.LIFO))
                        // 設(shè)置顯示圖片線程池大小秦躯,默認(rèn)為3
                        // 注:如果設(shè)置了taskExecutor或者taskExecutorForCachedImages 此設(shè)置無(wú)效
                .threadPoolSize(3)
                        // 設(shè)置圖片加載線程的優(yōu)先級(jí),默認(rèn)為Thread.NORM_PRIORITY-1
                        // 注:如果設(shè)置了taskExecutor或者taskExecutorForCachedImages 此設(shè)置無(wú)效
                .threadPriority(Thread.NORM_PRIORITY - 2) // default
                        // 設(shè)置圖片加載和顯示隊(duì)列處理的類型 默認(rèn)為QueueProcessingType.FIFO
                        // 注:如果設(shè)置了taskExecutor或者taskExecutorForCachedImages 此設(shè)置無(wú)效
                .tasksProcessingOrder(QueueProcessingType.FIFO) // default
                        // 設(shè)置拒絕緩存在內(nèi)存中一個(gè)圖片多個(gè)大小 默認(rèn)為允許,(同一個(gè)圖片URL)根據(jù)不同大小的imageView保存不同大小圖片
                .denyCacheImageMultipleSizesInMemory()
                        // 設(shè)置內(nèi)存緩存 默認(rèn)為一個(gè)當(dāng)前應(yīng)用可用內(nèi)存的1/8大小的LruMemoryCache
                .memoryCache(new LruMemoryCache(2 * 1024 * 1024))
                        // 設(shè)置內(nèi)存緩存的最大大小 默認(rèn)為一個(gè)當(dāng)前應(yīng)用可用內(nèi)存的1/8
                .memoryCacheSize(2 * 1024 * 1024)
                        // 設(shè)置內(nèi)存緩存最大大小占當(dāng)前應(yīng)用可用內(nèi)存的百分比 默認(rèn)為一個(gè)當(dāng)前應(yīng)用可用內(nèi)存的1/8
                .memoryCacheSizePercentage(13) // default
                        // 設(shè)置硬盤緩存
                .diskCache(new UnlimitedDiskCache(cacheDir)) //緩存路徑
                        // 設(shè)置硬盤緩存的最大大小
                .diskCacheSize(50 * 1024 * 1024)
                        // 設(shè)置硬盤緩存的文件的最多個(gè)數(shù)
                .diskCacheFileCount(100)
                        // 設(shè)置硬盤緩存文件名生成規(guī)范
                .diskCacheFileNameGenerator(new HashCodeFileNameGenerator()) // default
                        // 設(shè)置圖片下載器
                .imageDownloader(new BaseImageDownloader(context)) // default
                        // 設(shè)置圖片解碼器
                .imageDecoder(DefaultConfigurationFactory.createImageDecoder(false))
                        // 設(shè)置默認(rèn)的圖片顯示選項(xiàng)
                .defaultDisplayImageOptions(DisplayImageOptions.createSimple())
                        // 打印DebugLogs
                .writeDebugLogs()
                        //萬(wàn)事俱備 執(zhí)行構(gòu)造
                .build();
        //初始化配置文件
        ImageLoader.getInstance().init(config);
    }
}

Step-Two:配置DisplayImageOptions

package com.samego.alic.androidutils.common;
/**
 * 應(yīng)用輔助配置文件
 * Created by alic on 16-5-17.
 */
public class AppConfig {
    public static DisplayImageOptions imageOptions() {
        /**
         * DisplayImageOptions所有配置簡(jiǎn)介
         */
        DisplayImageOptions options = new DisplayImageOptions.Builder()
                // 設(shè)置圖片加載時(shí)的默認(rèn)圖片
                .showImageOnLoading(R.drawable.login_face)
                        // 設(shè)置圖片加載失敗的默認(rèn)圖片
                .showImageOnFail(R.drawable.login_face)
                        // 設(shè)置圖片URI為空時(shí)默認(rèn)圖片
                .showImageForEmptyUri(R.drawable.login_face)
                        // 設(shè)置是否將View在加載前復(fù)位
                .resetViewBeforeLoading(false)
                        // 設(shè)置延遲部分時(shí)間才開(kāi)始加載
                        // 默認(rèn)為0
                .delayBeforeLoading(100)
                        // 設(shè)置添加到內(nèi)存緩存
                        // 默認(rèn)為false
                .cacheInMemory(true)
                        // 設(shè)置規(guī)模類型的解碼圖像
                        // 默認(rèn)為ImageScaleType.IN_SAMPLE_POWER_OF_2
                .imageScaleType(ImageScaleType.IN_SAMPLE_POWER_OF_2)
                        // 設(shè)置位圖圖像解碼配置
                        // 默認(rèn)為Bitmap.Config.ARGB_8888
                .bitmapConfig(Bitmap.Config.ARGB_8888)
                        // 設(shè)置選項(xiàng)的圖像解碼
                .decodingOptions(new BitmapFactory.Options())
                        // 設(shè)置自定義顯示器
                        // 默認(rèn)為DefaultConfigurationFactory.createBitmapDisplayer()
                .displayer(new FadeInBitmapDisplayer(300))
                        // 設(shè)置自定義的handler
                        // 默認(rèn)為new Handler()
                .handler(new Handler())
                        // 建立
                .build();
        return options;
    }
}

Step-Three:然后可以使用啦

package com.samego.alic.androidutils.view;

public class MainActivity extends AppCompatActivity {
    private ImageView imageView;

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);

        initVIew();
    }

    public void initVIew() {
        imageView = (ImageView) findViewById(R.id.imageVIew);
        //看這里使用,很簡(jiǎn)單的一行代碼
        ImageLoader.getInstance().displayImage("http://home.sise.cn/img/LOGO.png",imageView, AppConfig.imageOptions());
    }
}

配置后具體使用的其它方法
Acceptable URIs examples

"http://site.com/image.png" // from Web
"file:///mnt/sdcard/image.png" // from SD card
"file:///mnt/sdcard/video.mp4" // from SD card (video thumbnail)
"content://media/external/images/media/13" // from content provider
"content://media/external/video/media/13" // from content provider (video thumbnail)
"assets://image.png" // from assets
"drawable://" + R.drawable.img // from drawables (non-9patch images)

Simple

ImageLoader imageLoader = ImageLoader.getInstance();

imageLoader.displayImage(imageUri, imageView);
//支持回調(diào)方法
imageLoader.loadImage(imageUri, new SimpleImageLoadingListener() {
    @Override
    public void onLoadingComplete(String imageUri, View view, Bitmap loadedImage) {
        //你要干嘛( ⊙o⊙ )哇
    }
});

// 異步加載得到Bitmap
Bitmap bmp = imageLoader.loadImageSync(imageUri);


// 加載圖片更是可以支持監(jiān)聽(tīng)
imageLoader.displayImage(imageUri, imageView, options, new ImageLoadingListener() {
    @Override
    public void onLoadingStarted(String imageUri, View view) {
        //你要干嘛( ⊙o⊙ )哇
    }
    @Override
    public void onLoadingFailed(String imageUri, View view, FailReason failReason) {
         //你要干嘛( ⊙o⊙ )哇
    }
    @Override
    public void onLoadingComplete(String imageUri, View view, Bitmap loadedImage) {
         //你要干嘛( ⊙o⊙ )哇
    }
    @Override
    public void onLoadingCancelled(String imageUri, View view) {
        //你要干嘛( ⊙o⊙ )哇
    }
}, new ImageLoadingProgressListener() {
    @Override
    public void onProgressUpdate(String imageUri, View view, int current, int total) {
         //你要干嘛( ⊙o⊙ )哇 更新UI進(jìn)度條羅
    }
});
// Load image, decode it to Bitmap and return Bitmap to callback看看簡(jiǎn)單的官方英文
ImageSize targetSize = new ImageSize(80, 50); // result Bitmap will be fit to this size
imageLoader.loadImage(imageUri, targetSize, options, new SimpleImageLoadingListener() {
    @Override
    public void onLoadingComplete(String imageUri, View view, Bitmap loadedImage) {
        // Do whatever you want with Bitmap
    }
});
// Load image, decode it to Bitmap and return Bitmap synchronously看看簡(jiǎn)單的官方英文
ImageSize targetSize = new ImageSize(80, 50); // result Bitmap will be fit to this size
Bitmap bmp = imageLoader.loadImageSync(imageUri, targetSize, options);

Github:Android-Universal-Image-Loader
對(duì)于開(kāi)發(fā)者來(lái)說(shuō)使用好的輪子的確是很重要的裆装,要是上面出現(xiàn)錯(cuò)誤的地方望指出并多多交流宦赠,要是有更好的簡(jiǎn)單封裝方式感謝留言分享陪毡!

****價(jià)值源于技術(shù),貢獻(xiàn)源于分享****

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末勾扭,一起剝皮案震驚了整個(gè)濱河市毡琉,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌妙色,老刑警劉巖桅滋,帶你破解...
    沈念sama閱讀 219,589評(píng)論 6 508
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場(chǎng)離奇詭異身辨,居然都是意外死亡丐谋,警方通過(guò)查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,615評(píng)論 3 396
  • 文/潘曉璐 我一進(jìn)店門煌珊,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái)号俐,“玉大人,你說(shuō)我怎么就攤上這事定庵±舳觯” “怎么了?”我有些...
    開(kāi)封第一講書(shū)人閱讀 165,933評(píng)論 0 356
  • 文/不壞的土叔 我叫張陵蔬浙,是天一觀的道長(zhǎng)猪落。 經(jīng)常有香客問(wèn)我,道長(zhǎng)畴博,這世上最難降的妖魔是什么笨忌? 我笑而不...
    開(kāi)封第一講書(shū)人閱讀 58,976評(píng)論 1 295
  • 正文 為了忘掉前任,我火速辦了婚禮俱病,結(jié)果婚禮上官疲,老公的妹妹穿的比我還像新娘。我一直安慰自己亮隙,他們只是感情好途凫,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,999評(píng)論 6 393
  • 文/花漫 我一把揭開(kāi)白布。 她就那樣靜靜地躺著咱揍,像睡著了一般颖榜。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上煤裙,一...
    開(kāi)封第一講書(shū)人閱讀 51,775評(píng)論 1 307
  • 那天掩完,我揣著相機(jī)與錄音,去河邊找鬼硼砰。 笑死且蓬,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的题翰。 我是一名探鬼主播恶阴,決...
    沈念sama閱讀 40,474評(píng)論 3 420
  • 文/蒼蘭香墨 我猛地睜開(kāi)眼诈胜,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼!你這毒婦竟也來(lái)了冯事?” 一聲冷哼從身側(cè)響起焦匈,我...
    開(kāi)封第一講書(shū)人閱讀 39,359評(píng)論 0 276
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤,失蹤者是張志新(化名)和其女友劉穎昵仅,沒(méi)想到半個(gè)月后缓熟,有當(dāng)?shù)厝嗽跇?shù)林里發(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 45,854評(píng)論 1 317
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡摔笤,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 38,007評(píng)論 3 338
  • 正文 我和宋清朗相戀三年够滑,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片吕世。...
    茶點(diǎn)故事閱讀 40,146評(píng)論 1 351
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡彰触,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出命辖,到底是詐尸還是另有隱情况毅,我是刑警寧澤,帶...
    沈念sama閱讀 35,826評(píng)論 5 346
  • 正文 年R本政府宣布吮龄,位于F島的核電站俭茧,受9級(jí)特大地震影響咆疗,放射性物質(zhì)發(fā)生泄漏漓帚。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,484評(píng)論 3 331
  • 文/蒙蒙 一午磁、第九天 我趴在偏房一處隱蔽的房頂上張望尝抖。 院中可真熱鬧,春花似錦迅皇、人聲如沸昧辽。這莊子的主人今日做“春日...
    開(kāi)封第一講書(shū)人閱讀 32,029評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)搅荞。三九已至,卻和暖如春框咙,著一層夾襖步出監(jiān)牢的瞬間咕痛,已是汗流浹背。 一陣腳步聲響...
    開(kāi)封第一講書(shū)人閱讀 33,153評(píng)論 1 272
  • 我被黑心中介騙來(lái)泰國(guó)打工喇嘱, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留茉贡,地道東北人。 一個(gè)月前我還...
    沈念sama閱讀 48,420評(píng)論 3 373
  • 正文 我出身青樓者铜,卻偏偏與公主長(zhǎng)得像腔丧,于是被迫代替她去往敵國(guó)和親放椰。 傳聞我的和親對(duì)象是個(gè)殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 45,107評(píng)論 2 356

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