博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
【译】UNIVERSAL IMAGE LOADER.PART 2---ImageLoaderConfiguration详解
阅读量:5817 次
发布时间:2019-06-18

本文共 3502 字,大约阅读时间需要 11 分钟。

ImageLoader类中包含了所有操作。他是一个单例,为了获取它的一个单一实例,你需要调用getInstance()方法。在使用ImageLoader来显示图片之前,你需要初始化它的配置-ImageLoaderConfiguration使用init(…)方法。然后,你就可以使用可以明确地根据需要使用不同形式的displayImage(…)。

总之,ImageLoader最简单的用法如下所示(使用默认配置):

ImageView imageView = ... // view, where the image will be displayedString imageUrl = ... // image URL (e.g. "http://site.com/image.png", "file:///mnt/sdcard/img/image.jpg")ImageLoader imageLoader = ImageLoader.getInstance();imageLoader.init(ImageLoaderConfiguration .createDefault(context));imageLoader.displayImage(imageUrl, imageView);

现在,让我们看看完整的用法。

就像你已经知道的,我们首先需要用configuration对象来初始化ImageLoader。因为ImageLoader是一个单例,所以它需要在App一启动的时候就初始化。我建议在一个重载了了的Application.onCreate()来做这件事。对于一个已经初始化的ImageLoader,重新初始化将不会对程序有任何影响。

接下来,我们创建一个configuration,他是一个ImageLoaderConfiguration类的对象,我们使用Builder来创建它。

File cacheDir = StorageUtils.getCacheDirectory(context,"UniversalImageLoader/Cache");ImageLoaderConfiguration config = newImageLoaderConfiguration .Builder(getApplicationContext()).maxImageWidthForMemoryCache(800).maxImageHeightForMemoryCache(480).httpConnectTimeout(5000).httpReadTimeout(20000).threadPoolSize(5).threadPriority(Thread.MIN_PRIORITY + 3).denyCacheImageMultipleSizesInMemory().memoryCache(new UsingFreqLimitedCache(2000000)) // You can pass your own memory cache implementation.discCache(new UnlimitedDiscCache(cacheDir)) // You can pass your own disc cache implementation.defaultDisplayImageOptions(DisplayImageOptions.createSimple()).build();

下面让我们来看看每一个选项。

• maxImageWidthForMemoryCache() 和maxImageHeightForMemoryCache()用于将图片将图片解析成Bitmap对象。为了不储存整个图片,根据ImageView参数的值(要加载图片的那个)减少图片的大小。maxWidth和maxHeight(第一阶段),layout_width layout_height(第二阶段)。如果不定义这些参数(值为fill_parent和wrap_content被视为不确定的大小),然后尺寸的设定就会根据maxImageWidthForMemoryCache()和maxImageHeightForMemoryCache()的设置而定。原始图像的大小最大会缩小到2倍(适合用fast decoding),直到宽度或高度变得小于指定值;

o默认值 - 设备的屏幕大小

• httpReadTimeout()设置图片从网络中加载的最大超时时间(以毫秒为单位)

o 默认值- 30秒

• threadPoolSize() 设置线程池的大小. 每一个图片加载和显示的任务都是在一个个单独的线程中进行的,这些线程在从图片网络中被下载的时候就会进入线程池。因此,池的大小决定能同时运行的线程数。一个大的线程池能显著地拖慢UI的响应速度,例如,列表的滚动就会变慢.

o 默认值- 5

• threadPriority()设置正在运行任务的所有线程在系统中的优先级(1到10);

o默认值- 4

• 调用denyCacheImageMultipleSizesInMemory()强制UIL在内存中不能存储内容相同但大小不同的图像。由于完整大小的图片会存储在磁盘缓存中,后面当图片加载进入内存,他们就会缩小到ImageView的大小(图片要显示的尺寸),然而在某些情况下,相同的图像第一次显示在一个小的View中,然后又需要在一个大的View中显示。同时,两个不同大小的相同内容的图片就会被将被存储在内存中。这是默认的操作。denyCacheImageMultipleSizesInMemory()指令确保删除前一个加载的图像缓存的内存的大小

• 使用memoryCache(),你可以指定内存缓存的实现。你可以使用现成的解决方案(他们都是实现limited  size-cache,如果超过缓存大小,就通过一定算法删除一个对象):

o FIFOLimitedCache (根据先进先出的原则上删除多余对象)

o LargestLimitedCache (空间占用最大的对象会被删除)
o UsingAgeLimitedCache (最早被添加的对象会被删除)
o UsingFreqLimitedCache (最少被用到的对象会被删除)
或者,你可以实现通过实现接口MemoryCacheAware <String,Bitmap>来实现自己的缓存;
o 默认值 - 使用2 MB的内存限制的UsingFreqLimitedCache
memoryCacheSize() 设置内存缓存的最大占用空间. 在这种情况下,默认的缓存策略是 - UsingFreqLimitedCache.
o 默认值 - 2 MB

• Using discCache(), 你可以定义自己的磁盘缓存. 也可以现成的解决方案 (文件跟特定的URL匹配,文件名为这些URL的哈希值):

o UnlimitedDiscCache (通常的策略, 缓存大小没有限制)

o FileCountLimitedDiscCache (限定大小的缓存)
o TotalSizeLimitedDiscCache (限定文件个数的缓存策略)
另外,你也可以通过实现DiscCacheAware接口定义自己的缓存
o 默认值 - UnlimitedDiscCache

• 使用defaultDisplayImageOptions(),你可以设置image显示选项,如果自定义选项没有传递给displayImage(),它将用于displayimage(…)方法的每一次调用。下面,我将详细讨论这些选项。

我们可以构建一个configuration对象或信任一个开发人员(比如我)然后使用默认的configuration:

 

ImageLoaderConfiguration config =ImageLoaderConfiguration.createDefault(context);

 

因此,configuration就创建好了。现在,ImageLoader可以通过它初始化了:

ImageLoader.getInstance().init(config);

就这样,ImageLoader已经可以使用了。在中我们还会讲到它。

 

 

原文链接

转载于:https://www.cnblogs.com/kissazi2/p/3903899.html

你可能感兴趣的文章
C++求值顺序
查看>>
postman学习网址
查看>>
注册表中路径的写法
查看>>
简单的 FFT 变形 - BZOJ 2194
查看>>
transient关键字的理解
查看>>
powershell 串口相关
查看>>
Django的admin使用
查看>>
mysql常用命令
查看>>
linux 管道
查看>>
b树的实现(c++)
查看>>
SQL Server 2005 中的分区表和索引
查看>>
黑马程序员—09-结构体
查看>>
修改input中的placeholder属性的颜色
查看>>
.net工作流引擎ccflow新增支持PostgreSQL数据库的功能的发布说明
查看>>
ActiveMQ_日志信息(五)
查看>>
linux下IPTABLES配置详解
查看>>
uva 128(简单题)
查看>>
第一个java程序
查看>>
HDU_2203_KMP入门
查看>>
LINQ to SQL语句非常详细(原文来自于网络)
查看>>