前言:從學(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)源于分享****