https://github.com/nostra13/Android-Universal-Image-Loader
ImageLoader作用
1.多线程下载图片,图片可以来源于网络,文件系统,项目文件夹assets中以及drawable中
2.支持图片的内存缓存,文件系统缓存或者SD卡缓存
3.支持图片下载过程的监听
4.根据控件(ImageView)的大小对Bitmap进行裁剪,减少Bitmap占用过多的内存
加载第三方库
Gradle代码
‘com.nostra13.universalimageloader:universal-image-loader:1.9.4’
权限
1 2
|
<uses-permission android:name="android.permission.INTERNET" /> <uses-permission android:name="android.permission.WRITE_EXTERNAL_STORAGE" />
|
ImageLoader加载的类型
1 2 3 4 5 6 7
|
"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 [用imageView.setImageResource(drawable)来代替]
|
ImageLoader的加载、显示配置:
加载Image时的配置(ImageLoaderConfiguration)
自定义配置 - 通过new ImageLoaderConfiguration.Builder().builder()方法进行实例化。
默认配置 - 通过ImageLoaderConfiguration 的createDefault进行实例化。
1 2 3 4 5 6 7 8 9
|
File diskCache = StorageUtils.getOwnCacheDirectory(context, "BNJ_IMAGE_CACHE/"); ImageLoaderConfiguration config = new ImageLoaderConfiguration.Builder(context) .diskCache(new UnlimitedDiscCache(diskCache)) // 设置缓存路径 .memoryCacheSize(2 * 1024) // 设置缓存的最大字节 .diskCacheFileNameGenerator(new Md5FileNameGenerator()) // 加密 .denyCacheImageMultipleSizesInMemory() // 禁止缓存显示不同大小的同一张图片 .memoryCacheExtraOptions(800, 760) // 保存每个缓存图片的最大长和宽 .diskCacheFileCount(100) //缓存的File数量 .build();
|
使用
通过ImageLoader的getInstance().init()方法传入上述options对象.
显示Image时的配置(DisplayImageOptions)
自定义配置 - 通过new DisplayImageOptions.Builder().builder()方法实例化对象
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18
|
DisplayImageOptions options = new DisplayImageOptions.Builder() .showImageOnLoading(R.drawable.ic_stub) // 设置加载时的图片 (使用loadImage方法加载时无效) .showImageForEmptyUri(R.drawable.ic_empty) // resource or drawable .showImageOnFail(R.drawable.ic_error) // 设置加载失败的图片 .cacheInMemory(true) //设置使用内存缓存 .cacheOnDisk(true) //使用文件缓存 .displayer(new RoundedBitmapDisplayer(20)) // 设置成圆角图片 .bitmapConfig(Bitmap.Config.RGB_565) //减少内存消耗 .delayBeforeLoading(100) //设置下载图片前的延时 .imageScaleType(ImageScaleType.EXACTLY_STRETCHED) .considerExifParams(false) //是否考虑JPEG图像EXIF参数(旋转,翻转) .build();
ImageSize size= new ImageSize(300,300);(大小可以通过创建ImageSize对象设置)
上述图片显示displayer //显示圆角 RoundedBitmapDisplayer //淡入显示 FadeInBitmapDisplayer
|
加载图片的方法
loadImage跟displayImage
A.ImageLoader.getInstance().loadImage(uri地址,图片大小,上述配置,监听器,进度监听器);
B.ImageLoader.getinstance().displayImage(uri地址,控件,上述配置,监听器,进度监听器);
区别
A方法可以设置图片大小,即自定义下载图片的大小
B方法会根据控件大小及ImageScaleType来裁剪图片
常用displayImage方法
监听器有两种
SimpleImageLoadingListener(简单的监听器)
ImageLoadingListener (该监听器能实现 加载图片取消时,失败时的方法)
ImageLoadingProgressListener
最后在监听器的onLoadingComplete方法里,设置图片显示即可
进阶
listView.setOnScrollListener(new PauseOnScrollListener(imageLoader, pauseOnScroll, pauseOnFling));
第一个参数是imageLoader,第二个参数是滑动时是否加载图片,第三个参数是猛的滑动时是否加载图片
OOM问题
如果使用了ImageLoader出现OutOfMemoryError的话,那么可以通过下列方法解决
关闭memory的cache。
减少线程池的大小
用Bitmap.Config.RGB565代替ARGB8888
使用.imageScaleType(ImageScaleType.EXACTLY 或ImageScaleType.IN_SAMPLE_INT)
使用.diskCacheExtraOption(480, 320, null)
获取缓存文件
1 2
|
DiskCache diskCache = ImageLoader.getInstance().getDiskCache(); File cacheFile = DiskCacheUtils.findInCache(imgpath, diskCache);
|
ImageView ScaleType

ImageLoader的使用及封装
使用
1.全局初始化ImageLoader,配置ImageLoader的参数(ImageLoaderConfiguration)
2.配置图片加载的参数(DisplayImageOptions)
3.创建ImageLoader的对象,调用displayImage方法
封装
1.利用单例模式创建ImageLoaderTool的对象
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16
|
public class ImageLoaderTool{
private static ImageLoader imageLoader;//用于全局初始化 private static ImageLoaderConfiguration configuration;//配置ImageLoader的参数
private static class Holder{ //单例模式 private static final ImageLoaderTool imageLoaderTool = new ImageLoaderTool(); }
public static ImageLoaderTool getInstance(){ if(configuration==null || imageLoader==null){ throw new RunTimeException ("Must be call the method InitImageLoader(Context context) in Application"); } return Holder.imageLoaderTool; } }
|
2.初始化ImageLoaderConfiguration
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18
|
public static void initImageLoader(Context context) { File diskCache = StorageUtils.getOwnCacheDirectory(context, "TJD_NBA/"); if (configuration == null) { configuration = new ImageLoaderConfiguration.Builder(context) .diskCache(new UnlimitedDiskCache(diskCache)) .diskCacheFileNameGenerator(new Md5FileNameGenerator()) //md5加密 .memoryCacheSize(1024 * 2)//缓存最大字节 .memoryCache(new LruMemoryCache(5 * 1024 * 1024))//解决缓存listview滑动后显示默认图 .memoryCacheExtraOptions(800, 760)// 保存每个缓存图片的最大长和宽 .diskCacheFileCount(100) //缓存的File数量 .build(); } if (imageLoader == null) { imageLoader = ImageLoader.getInstance(); imageLoader.init(configuration); } }
|
3.封装DisplayImage方法
1 2 3 4 5 6 7 8 9
|
/** * 加载drawable图片,不能加载系统的drawable 即android:drawable * * @param resid * @param imageView */ public void loadImageFromDrawable(int resid, ImageView imageView) { imageLoader.displayImage(DRAWABLE_PREFIX + resid, imageView); }
|
示例 - 封装ImageLoader
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86
|
/** * ImageLoader的封装。单例模式 * 1. "http://site.com/image.png" // from Web * 2. "file:///mnt/sdcard/image.png" // from SD card * 3. "file:///mnt/sdcard/video.mp4" // from SD card (video thumbnail) * 4. "content://media/external/images/media/13" // from content provider * 5. "content://media/external/video/media/13" // from content provider (video thumbnail) * 6. "assets://image.png" // from assets * 7. "drawable://" + R.drawable.img // from drawables (non-9patch images)[用imageView.setImageResource(drawable)来代替] */ public class ImageLoaderTool {
private static ImageLoader imageLoader; //用于全局初始化 private static ImageLoaderConfiguration configuration;//默认的ImageLoader配置 private final String DRAWABLE_PREFIX = "drawable://";//用于加载drawable图像
private static class Holder { private static final ImageLoaderTool loaderTool = new ImageLoaderTool(); }
public static ImageLoaderTool getInstance() { if (imageLoader == null || configuration == null) { throw new RuntimeException("Must be call the method InitImageLoader(Context context) in Application"); } return Holder.loaderTool; }
// // 初始化ImageLoader // // @param context 在APP中 // public static void initImageLoader(Context context) { File diskCache = StorageUtils.getOwnCacheDirectory(context, "TJD_NBA/"); if (configuration == null) { configuration = new ImageLoaderConfiguration.Builder(context) .diskCache(new UnlimitedDiskCache(diskCache)) .diskCacheFileNameGenerator(new Md5FileNameGenerator()) //md5加密 .memoryCacheSize(1024 * 2)//缓存最大字节 .memoryCache(new LruMemoryCache(5 * 1024 * 1024))//解决缓存listview滑动后显示默认图 .memoryCacheExtraOptions(800, 760)// 保存每个缓存图片的最大长和宽 .diskCacheFileCount(100) //缓存的File数量 .build(); } if (imageLoader == null) { imageLoader = ImageLoader.getInstance(); imageLoader.init(configuration); } }
// // 默认图片加载参数 // private static DisplayImageOptions defaultOptions = new DisplayImageOptions.Builder() .cacheOnDisk(true) .cacheInMemory(true) .bitmapConfig(Bitmap.Config.RGB_565) .imageScaleType(ImageScaleType.EXACTLY) .showImageOnFail(R.drawable.side_nav_bar) .showImageForEmptyUri(R.drawable.side_nav_bar) .showImageOnLoading(R.drawable.side_nav_bar) .delayBeforeLoading(1000) .considerExifParams(true) //是否考虑JPEG图像EXIF参数(旋转,翻转) .build();
// // 加载普通图片 // // @param url // @param imageView // public void loadImage(String url, ImageView imageView) { imageLoader.displayImage(url, imageView, defaultOptions); }
// // 加载drawable图片,不能加载系统的drawable 即android:drawable // // @param resid // @param imageView // public void loadImageFromDrawable(int resid, ImageView imageView) { imageLoader.displayImage(DRAWABLE_PREFIX + resid, imageView); }
}
|
使用ImageLoader时加载相同URL的问题
//使用displayImage,而不使用loadImage,因为loadImage会导致当同时加载同一个url的时候出现task被取消的情况
//详情见https://github.com/nostra13/Android-Universal-Image-Loader/issues/804
1 2 3
|
// 解决方法 ImageSize size = new ImageSize(Functions.getScreenWidthPix(getActivity()), Functions.getScreenHeightPix(getActivity())); NonViewAware imageAware = new NonViewAware(size, ViewScaleType.CROP);
|
解决listvie宽度设置wwrap_content无效的方法
stackoverflow大佬
现象
listview宽度设置wrap_content无效
解决办法,添加FrameLayout跟LinearLayout设置weight
修改前代码

1 2 3 4 5 6 7 8 9 10 11 12
|
<ListView android:id="@+id/listView" android:layout_width="wrap_content" android:layout_height="wrap_content" android:layout_weight="0.3" android:background="黑色" android:divider="@null" android:gravity="center" android:horizontalSpacing="7dp" android:numColumns="4" android:paddingLeft="@dimen/common_layout_margin_15dp" android:paddingRight="@dimen/common_layout_margin_15dp"></ListView>
|
修改后代码

1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25
|
<LinearLayout android:layout_width="wrap_content" android:layout_height="wrap_content" android:orientation="horizontal">
<ListView android:id="@+id/listView" android:layout_width="0dp" android:layout_height="wrap_content" android:layout_weight="0.3" android:background="黑色" android:divider="@null" android:gravity="center" android:horizontalSpacing="7dp" android:numColumns="4" android:paddingLeft="@dimen/common_layout_margin_15dp" android:paddingRight="@dimen/common_layout_margin_15dp"></ListView>
<FrameLayout android:layout_width="0dp" android:layout_height="match_parent" android:layout_weight="0.7" android:background="蓝色" />
</LinearLayout>
|
https://tanjundang.github.io/2015/09/17/ImageLoaderTool/
- 转:iOS程序main函数之前发生了什么
原文地址:http://blog.sunnyxx.com/2014/08/30/objc-pre-main/ 我是前言 一个iOS app的main()函数位于main.m中,这是我们熟知的程序入口. ...
- 今日头条- iOS客户端 启动速度优化实践
版权声明 作者:今日头条iOS团队 原文:https://techblog.toutiao.com/2017/01/17/iosspeed/ 应用启动时间,直接影响用户对一款应用的判断和使用体验.头条 ...
- iOS程序main函数之前发生了什么
我是前言 一个iOS app的main()函数位于main.m中,这是我们熟知的程序入口.但对objc了解更多之后发现,程序在进入我们的main函数前已经执行了很多代码,比如熟知的+ load方法等. ...
- DNS域名解析中A、AAAA、CNAME、MX、NS、TXT、SRV、SOA、PTR各项记录的作用
名注册完成后首先需要做域名解析,域名解析就是把域名指向网站所在服务器的IP,让人们通过注册的域名可以访问到网站.IP地址是网络上标识服务器的数字地址,为了方便记忆,使用域名来代替IP地址.域名解析就是 ...
- Volley源码分析(2)----ImageLoader
一:imageLoader 先来看看如何使用imageloader: public void showImg(View view){ ImageView imageView = (ImageView) ...
- Volley(四)—— ImageLoader & NetworkImageView
Volley(四)—— ImageLoader & NetworkImageView ImageLoader是一个加载网络图片的封装类,其内部还是由ImageRequest来实现的.但因为源码 ...
- ImageLoader实现图片异步加载
ImageLoader是一个广泛使用的图片库,在向网络请求图片时,使用imageView和smartView常会产生outofmemory错误,这时ImageLoader可以起到很大的作用,主要有如下 ...
- ImageLoader(多线程网络图片加载)+本地缓存 for windowsphone 7
搞了好长一阵子wp,做点好事. C/S手机app中应用最多的是 获取网络图片,缓存到本地,展示图片 本次主要对其中的delay:LowProfileImageLoader进行修改,在获取图片的时候, ...
- mybatis中@Param的用法和作用
用注解来简化xml配置的时候,@Param注解的作用是给参数命名,参数命名后就能根据名字得到参数值,正确的将参数传入sql语句中 我们先来看Mapper接口中的@Select方法 package Ma ...
随机推荐
- ububtu16.04下安装protobuf
重新下载protobuf,我下载的时最新的protobuf-all-3.5.1.tar.gz protobuf网址:https://github.com/google/protobuf/relea ...
- MySQL存储引擎中的MyISAM和InnoDB
在使用MySQL的过程中对MyISAM和InnoDB这两个概念存在了些疑问,到底两者引擎有何分别一直是存在我心中的疑问.为了解开这个谜题,搜寻了网络,找到了如下信息: MyISAM是MySQL的默认数 ...
- Python:zip()函数
zip()函数的定义 从参数中的多个迭代器取元素组合成一个新的迭代器: 返回:返回一个zip对象,其内部元素为元组:可以转化为列表或元组: 传入参数:元组.列表.字典等迭代器. zip()函数的用法 ...
- Django - 学习目录
Django 基础 web应用/http协议/web框架 Django简介 Django - 路由层(URLconf) Django - 视图层 Django - 模板层 Django - 模型层 - ...
- Jmeter(十五)_上传与下载
今天重点说一下Jmeter的上传与下载 1:Jmeter上传文件 首先确认你的文件名称,参数名称,MIME类型,这些可以从接口文档里面获取,或者直接在页面抓包然后从请求头里面查看.注意,此处我的文件路 ...
- Library Publication 时遇到 "more than one library with package name" 错误的解决方法
Library Publication 是 Gradle 在0.9.0 时增加的一个新特性,它的作用是让Lib也能发布不同的版本 在这之前,Lib只能发布release版本,你的项目中依赖的所有Lib ...
- requests库的get请求,带有cookies
(一)如何带cookies请求 方法一:headers中带cookies #coding:utf-8 import requests import re # 构建url url = 'http://w ...
- OA系统部署短信过程
安装dotNetFx40_Client_setup.exe插件 安装mysql_installer_community_V5.6.21.1_setup.1415604646.msi数据库 根据数据库版 ...
- 011-jdk1.8版本新特性三-Date API
1.7.Date API Java 8 在包java.time下包含了一组全新的时间日期API.新的日期API和开源的Joda-Time库差不多,但又不完全一样,下面的例子展示了这组新API里最重要的 ...
- npm设置淘宝镜像
npm config set registry https://registry.npm.taobao.org --global npm config set disturl https://npm. ...