Android ImageLoader第三方框架解析

本文实例为大家分享了Android ImageLoader框架的使用方法,供大家参考,具体内容如下

1.准备工作

1)导入universal-image-loader-1.9.5.jar到项目中

2)创建MyApplication继承Application,在oncreate()中初始化ImageLoader

public class MyApplication extends Application {

 @Override
 public void onCreate() {
  super.onCreate();
  initImageLoader(this);
 }

 // 初始化imageloader
 private void initImageLoader(Context context) {
  // 初始化参数
  ImageLoaderConfiguration config = new ImageLoaderConfiguration.Builder(context)
    .threadPriority(Thread.NORM_PRIORITY - 2)    // 线程优先级
    .denyCacheImageMultipleSizesInMemory()     // 当同一个Uri获取不同大小的图片,缓存到内存时,只缓存一个。默认会缓存多个不同的大小的相同图片
    .discCacheFileNameGenerator(new Md5FileNameGenerator()) // 将保存的时候的URI名称用MD5
    .tasksProcessingOrder(QueueProcessingType.LIFO)   // 设置图片下载和显示的工作队列排序
    .writeDebugLogs()          // 打印debug log
    .build();

  // 全局初始化此配置
  ImageLoader.getInstance().init(config);
 }
}

2.ImageLoader_Listview中使用

5)初始化DisplayImageOptions
6)获取ImageLoader实例
7)显示加载的图片

public class ImageloaderListviewAdapter extends BaseAdapter {
 private Context mContext;
 private final ImageLoader imageLoader;
 private DisplayImageOptions options = new DisplayImageOptions.Builder()
   .showStubImage(R.drawable.atguigu_logo)   // 设置图片下载期间显示的图片
   .showImageForEmptyUri(R.drawable.atguigu_logo) // 设置图片Uri为空或是错误的时候显示的图片
   .showImageOnFail(R.drawable.atguigu_logo)  // 设置图片加载或解码过程中发生错误显示的图片
   .cacheInMemory(true)      // 设置下载的图片是否缓存在内存中
   .cacheOnDisk(true)       // 设置下载的图片是否缓存在SD卡中
   .displayer(new RoundedBitmapDisplayer(20)) // 设置成圆角图片
   .build();         // 创建配置过得DisplayImageOption对象;

 public ImageloaderListviewAdapter(Context context) {
  mContext = context;

  // 初始化imageloader
  imageLoader = ImageLoader.getInstance();
 }

 @Override
 public int getCount() {
  return Constants.IMAGES.length;
 }

 @Override
 public Object getItem(int position) {
  return Constants.IMAGES[position];
 }

 @Override
 public long getItemId(int position) {
  return position;
 }

 @Override
 public View getView(int position, View convertView, ViewGroup parent) {
  Viewholder holder;
  if(convertView == null) {
   convertView = View.inflate(mContext, R.layout.item_imageloader_listview, null);
   holder = new Viewholder(convertView);
   convertView.setTag(holder);
  }else {
   holder = (Viewholder) convertView.getTag();
  }
  holder.name.setText("item"+(position + 1));

  imageLoader.displayImage(Constants.IMAGES[position],holder.iv,options);

  return convertView;
 }

 class Viewholder{
  @Bind(R.id.iv_imageloader_listview)
  ImageView iv;

  @Bind(R.id.tv_imageloader_name)
  TextView name;

  public Viewholder(View view) {
   ButterKnife.bind(this,view);
  }
 }
}

3.ImageLoader_在ViewPager中使用

public class ImageloaderViewpagerAdapter extends PagerAdapter {

 private Context mContext;
 private final ImageLoader imageLoader;
 private DisplayImageOptions options = new DisplayImageOptions.Builder()
   .showImageForEmptyUri(R.drawable.atguigu_logo) // 设置图片Uri为空或是错误的时候显示的图片
   .showImageOnFail(R.drawable.atguigu_logo)  // 设置图片加载或解码过程中发生错误显示的图片
   .resetViewBeforeLoading(true)    // 设置图片在下载前是否重置,复位
   .cacheOnDisc(true)       // 设置下载的图片是否缓存在SD卡中
   .imageScaleType(ImageScaleType.EXACTLY)  // 设置图片以如何的编码方式显示
   .bitmapConfig(Bitmap.Config.RGB_565)  // 设置图片的解码类型
   .displayer(new FadeInBitmapDisplayer(300)) // 设置图片渐变显示
   .build();
 ;

 public ImageloaderViewpagerAdapter(Context context) {
  mContext = context;

  // 初始化Imageloader
  imageLoader = ImageLoader.getInstance();
 }

 @Override
 public Object instantiateItem(ViewGroup container, int position) {
  // 添加布局文件
  View view = View.inflate(mContext, R.layout.item_imageloader_viewpager, null);

  // 获取控件对象
  ImageView iv = (ImageView) view.findViewById(R.id.iv_imageloader_viewpager);

  // 显示图片
  imageLoader.displayImage(Constants.IMAGES[position], iv, options);

  ((ViewPager) container).addView(view, 0);

  return view;
 }

 @Override
 public void destroyItem(ViewGroup container, int position, Object object) {
  ((ViewPager) container).removeView((View) object);
 }

 @Override
 public int getCount() {
  return Constants.IMAGES.length;
 }

 @Override
 public boolean isViewFromObject(View view, Object object) {
  return view.equals(object);
 }
}

3.ImageLoader 内存溢出解决办法

1)减少线程池中线程的个数,在ImageLoaderConfiguration中的(.threadPoolSize)中配置,推荐配置1-5。
2)在DisplayImageOptions选项中配置bitmapConfig为Bitmap.Config.RGB_565,因为默认是ARGB_8888, 使用RGB_565会比使用ARGB_8888少消耗2倍的内存。
3)在ImageLoaderConfiguration中配置图片的内存缓存为memoryCache(new WeakMemoryCache()) 或者不使用内存缓存。
4)在DisplayImageOptions选项中设置.imageScaleType(ImageScaleType.IN_SAMPLE_INT)或者imageScaleType(ImageScaleType.EXACTLY)。

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持我们。

(0)

相关推荐

  • Android开发之ImageLoader本地缓存

    ImageLoader是一个图片缓存的开源库,提供了强大的图片缓存机制,很多开发者都在使用,今天给大家介绍Android开发之ImageLoader本地缓存,具体内容如下所示: 本地缓存在缓存文件时对文件名称的修改提供了两种方式,每一种方式对应了一个Java类 1) HashCodeFileNameGenerator ,该类负责获取文件名称的hashcode然后转换成字符串. 2) Md5FileNameGenerator ,该类把源文件的名称同过md5加密后保存. 两个类都继承了FileNam

  • Android Universal ImageLoader 缓存图片

    项目介绍: Android上最让人头疼的莫过于从网络获取图片.显示.回收,任何一个环节有问题都可能直接OOM,这个项目或许能帮到你.Universal Image Loader for Android的目的是为了实现异步的网络图片加载.缓存及显示,支持多线程异步加载.它最初来源于Fedor Vlasov的项目,且自此之后,经过大规模的重构和改进. 特性列举: 多线程下载图片,图片可以来源于网络,文件系统,项目文件夹assets中以及drawable中等 支持随意的配置ImageLoader,例如

  • Android ListView实现ImageLoader图片加载的方法

    本文实例讲述了Android ListView实现ImageLoader图片加载的方法.分享给大家供大家参考,具体如下: 最近一直忙着做项目,今天也是忙里偷闲,想写篇博客来巩固下之前在应用中所用的知识.之前我们可能会也会肯定遇到了图片的异步加载问题,然而我们也可能会遇到图片二次或多次加载,这是ListView的特性造成的,具体原因不在这里讨论,又或者是OOM等问题.今天要讲的是一个开源框架Imageloader,个人觉得非常的好用. 该框架在github的地址.https://github.co

  • Android开发之ImageLoader使用详解

    先给大家展示效果图,看看是大家想要的效果吗,如果还满意,请参考以下代码: 前言 UniversalImageLoader是用于加载图片的一个开源项目,在其项目介绍中是这么写的, •支持多线程图片加载 •提供丰富的细节配置,比如线程池大小,HTPP请求项,内存和磁盘缓存,图片显示时的参数配置等等: •提供双缓存 •支持加载过程的监听: •提供图片的个性化显示配置接口: •Widget支持(这个,个人觉得没必要写进来,不过尊重原文) 其他类似的项目也有很多,但这个作为github上著名的开源项目被广

  • Android Imageloader的配置的实现代码

    Android Imageloader的配置的实现代码   ImageLoader 优点 (1) 支持下载进度监听 (2) 可以在 View 滚动中暂停图片加载 通过 PauseOnScrollListener 接口可以在 View 滚动中暂停图片加载. (3) 默认实现多种内存缓存算法 这几个图片缓存都可以配置缓存算法,不过 ImageLoader 默认实现了较多缓存算法,如 Size 最大先删除.使用最少先删除.最近最少使用.先进先删除.时间最长先删除等. (4) 支持本地缓存文件名规则定义

  • 从源代码分析Android Universal ImageLoader的缓存处理机制

    通过本文带大家一起看过UIL这个国内外大牛都追捧的图片缓存类库的缓存处理机制.看了UIL中的缓存实现,才发现其实这个东西不难,没有太多的进程调度,没有各种内存读取控制机制.没有各种异常处理.反正UIL中不单代码写的简单,连处理都简单.但是这个类库这么好用,又有这么多人用,那么非常有必要看看他是怎么实现的.先了解UIL中缓存流程的原理图. 原理示意图 主体有三个,分别是UI,缓存模块和数据源(网络).它们之间的关系如下: ① UI:请求数据,使用唯一的Key值索引Memory Cache中的Bit

  • SimpleCommand框架ImageLoader API详解(三)

    ImageLoader API 详细介绍,具体内容如下 在ImageLoader中有以下几个不同的构造器: /** * 注意: 次构造器不支持下载进度提示功能 * @param context * @param withCache 是否支持缓存 * false--不带缓存 * true--支持缓存功能,默认缓存路径在外置存储缓冲目录中的picasso-big-cache文件夹中 */ public ImageLoader(Context context, boolean withCache) {

  • Android ImageLoader第三方框架解析

    本文实例为大家分享了Android ImageLoader框架的使用方法,供大家参考,具体内容如下 1.准备工作 1)导入universal-image-loader-1.9.5.jar到项目中 2)创建MyApplication继承Application,在oncreate()中初始化ImageLoader public class MyApplication extends Application { @Override public void onCreate() { super.onCr

  • Android 网络请求框架解析之okhttp与okio

    安卓网络请求 先看一下今天的大纲 导入okhttp和okio依赖 禁用掉明文流量请求的检查 添加访问权限 布局及代码实现 运行结果 下面是具体步骤 一.导入okhttp和okio的依赖 1.打开File-Project Structure-Dependencies, 2.选择自己的程序文件,点击加号,选择Library Dependency 3.搜索okhttp,选择Com.squareup.okhttp3,点击ok按钮,此时可能需要较长时间 4.okio同上 5.应用,确认 6.此时我们可以看

  • Android ARouter路由框架解析

    一.ARouter介绍及主要应用场景: 1.介绍: 是ARouter是阿里巴巴开源的Android平台中对页面.服务提供路由功能的中间件,提倡的是简单且够用. 2.原生的路由方案存在的问题 首先谈一谈原生的路由方案存在的问题以及为什么需要路由框架.我们所使用的原生路由方案一般是通过显式intent和隐式intent两种方式实现的,而在显式intent的情况下,因为会存在直接的类依赖的问题,导致耦合非常严重:而在隐式intent情况下,则会出现规则集中式管理,导致协作变得非常困难.而且一般而言配置

  • Android设计模式之单例模式解析

    在日常开发过程中时常需要用到设计模式,但是设计模式有23种,如何将这些设计模式了然于胸并且能在实际开发过程中应用得得心应手呢?和我一起跟着<Android源码设计模式解析与实战>一书边学边应用吧! 今天我们要讲的是单例模式 定义 确保某一个类只有一个实例,而且自行实例化并向整个系统提供这个实例 使用场景 确保某个类有且只有一个对象的场景,避免产生多个对象消耗过多的资源 某个类型的对象只应该有一个 使用例子 应用的Application 图片加载框架对象,比如我们的ImageLoader,常用的

  • 一文搞懂Codec2框架解析

    目录 1 前言–Codec2.0是什么 2 Codec2.0框架 3 流程解析 3.1 初始化流程 3.2 启动流程 3.3 Input Buffer的回调 3.4 Output Buffer的回调 4 总结 1 前言–Codec2.0是什么 在Android Q之前,Android的两套多媒体框架分别为MediaPlayer与MediaCodec,后者只负责解码与渲染工作,解封装工作由MediaExtractor代劳,MediaCodec经由ACodec层调用第三方编解码标准接口OpenMAX

  • Android基于Pull方式解析xml的方法详解

    本文实例讲述了Android基于Pull方式解析xml的方法.分享给大家供大家参考,具体如下: Pull解析和Sax解析很相似,都是轻量级的解析,在Android的内核中已经嵌入了Pull,所以我们不需要再添加第三方jar包来支持Pull. Pull解析和Sax解析不一样的地方有: (1)pull读取xml文件后触发相应的事件调用方法返回的是数字 (2)pull可以在程序中控制想解析到哪里就可以停止解析. 来看看实例: book.xml如下: <?xml version="1.0"

  • Android通用流行框架大全【整理】

    Android通用流行框架大全 1. 缓存 DiskLruCacheJava实现基于LRU的磁盘缓存 2.图片加载 Android Universal Image Loader一个强大的加载,缓存,展示图片的库Picasso一个强大的图片下载与缓存的库Fresco一个用于管理图像和他们使用的内存的库Glide一个图片加载和缓存的库 3. 图片处理 Picasso-transformations一个为Picasso提供多种图片变换的库Glide-transformations一个为Glide提供多

  • Android中XUtils3框架使用方法详解(一)

    xUtils简介 xUtils 包含了很多实用的android工具. xUtils 支持大文件上传,更全面的http请求协议支持(10种谓词),拥有更加灵活的ORM,更多的事件注解支持且不受混淆影响... xUitls 最低兼容android 2.2 (api level 8) 今天给大家带来XUtils3的基本介绍,本文章的案例都是基于XUtils3的API语法进行的演示.相信大家对这个框架也都了解过, 下面简单介绍下XUtils3的一些基本知识. XUtils3一共有4大功能:注解模块,网络

  • Android中Volley框架进行请求网络数据的使用

    问题的阐述:Android SDK中的HttpClient和HttpUrlConnection两种请求方式用来处理网络的复杂的操作,但当应用比较复杂的时候需要我们编写大量的代码处理很多东西:图像缓存,请求的调度等等: 解决:Volley就是为解决这些而生,它与2013年Google I/O大会上被提出:使得Android应用网络操作更方便更快捷:抽象了底层Http Client等实现的细节,让开发者更专注与产生RESTful Request.另外,Volley在不同的线程上异步执行所有请求而避免

  • Android 网络请求框架Volley实例详解

    Android 网络请求框架Volley实例详解 首先上效果图 Logcat日志信息on Reponse Volley特别适合数据量不大但是通信频繁的场景,像文件上传下载不适合! 首先第一步 用到的RequetQueue RequestQueue.Java RequestQueue请求队列首先得先说一下,ReuqestQueue是如何对请求进行管理的...RequestQueue是对所有的请求进行保存...然后通过自身的start()方法开启一个CacheDispatcher线程用于缓存调度,开

随机推荐