Universal-Image-Loader的简单介绍和使用

今天说的是Universal-Image-Loader的使用,它也是一个比较强大的开源的UI组件程序。它有如下几个特征

1.多线程下载图片,图片可以来源于网络,文件系统,项目文件夹assets中以及drawable中等

2.支持随意的配置ImageLoader,例如线程池,图片下载器,内存缓存策略,硬盘缓存策略,图片显示选项以及其他的一些配置

3.支持图片的内存缓存,文件系统缓存或者SD卡缓存

4.支持图片下载过程的监听

5.根据控件(ImageView)的大小对Bitmap进行裁剪,减少Bitmap占用过多的内存

6.较好的控制图片的加载过程,例如暂停图片加载,重新开始加载图片,一般使用在ListView,GridView中,滑动过程中暂停加载图片,停止滑动的时候去加载图片

7.提供在较慢的网络下对图片进行加载

我自己本身项目中也挺多时候用到这个框架。今天的话我就把我项目中对 它的使用简化一下,也是希望大家能看得明白。

首先要在项目中的build.gradle文件中加入一下代码:

然后配置ImageLoaderConfiguration的全局变量,也是在Application文件中配置,看下代码 MyApplication.java:

/**
 * Created by Administrator on 2016/9/24.
 */
public class MyApplication extends Application {
    
    @Override
    public void onCreate() {
        super.onCreate();
        //获得外部缓存空间
        long maxSize=Runtime.getRuntime().maxMemory();
        File dir = getExternalCacheDir();//获得外部缓存
        ImageLoaderConfiguration imageLoader = new ImageLoaderConfiguration.Builder(getApplicationContext())
                .memoryCacheExtraOptions(480, 800)// max width, max height,即保存的每个缓存文件的最大长宽
                /*设置缓存的详细信息,不配或按需选配*/
                .threadPoolSize(5)// 线程池内加载的数量
                .threadPriority(Thread.NORM_PRIORITY - 2)//线程优先级,1~10优先级逐渐升高,10代表图片立即显示
                .memoryCache(new UsingFreqLimitedMemoryCache((int) maxSize / 16))//内存缓存
                .memoryCacheSize((int) maxSize / 16)//开辟16分之一内存缓存空间
                .discCacheSize((int) maxSize / 16)//开辟16分之一磁盘缓存空间
                .discCacheFileNameGenerator(new HashCodeFileNameGenerator())// 保存的时候的URI名称用MD5加密
                .diskCache(new UnlimitedDiskCache(dir))//配置自定义缓存目录
                .build();//开始构建
        ImageLoader.getInstance().init(imageLoader);//初始化组件

    }
}

具体代码的话代码中都有添加注释,这里就不再啰嗦。ImageLoaderConfiguration通过new ImageLoaderConfiguration.Builder()得到,再通过各种方法设置我们缓存空间的大小和路径等等,最后通过build()开始构建。最后调用ImageLoader的getInstance的init()方法把全局配置作为参数实现初始化。

这样就算配置好简单的ImageLoaderConfiguration了。接下来我们还需要的是DisplayImageOption,简单来说就是我们所要展示的图片的各种配置的设置。

我把这个包装到工具类中,我们看下代码:

/**
 * Created by Administrator on 2016/9/24.
 *
 * 用于配置及显示图片加载后的图片工具类
 */
public class ImageLoaderUtils {

    public static DisplayImageOptions getDisplayImageOptions() {
        DisplayImageOptions options = new DisplayImageOptions.Builder()
                .cacheInMemory(true)//是否进行内存缓存
                .cacheOnDisk(true)//是否进行磁盘缓存
                .build();//构造生成DisplayImageOptions
        return options;
    }
}
看起来比较简单,当然它肯定不止这些方法,它还有showImagrOnFail(),displayer()方法等等等,前者表示图片加载出错时显示的图片,后者表示设置图片显示出来的特效,当然实际项目中对性能要求比较高,我一般没怎么用。通过一系列方法最后build()得到DisplayImageOption对象。到这里我们已经得到了两个必不可少的对象。现在我们看下代码怎么使用,首先是简单的布局文件,就是一个ImageView:

<?xml version="1.0" encoding="utf-8"?>
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:tools="http://schemas.android.com/tools"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:paddingBottom="@dimen/activity_vertical_margin"
    android:paddingLeft="@dimen/activity_horizontal_margin"
    android:paddingRight="@dimen/activity_horizontal_margin"
    android:paddingTop="@dimen/activity_vertical_margin"
    tools:context="com.example.administrator.universalimagerloadertest.MainActivity">

    <ImageView
        android:id="@+id/imageView"
        android:layout_width="match_parent"
        android:layout_height="match_parent"
        android:text="Hello World!" />
</RelativeLayout>
下面看下MainActivity.java中的代码:

public class MainActivity extends AppCompatActivity {

    private String mImgUrl = "http://c.hiphotos.baidu.com/image/pic/item/5bafa40f4bfbfbed91fbb0837ef0f736aec31faf.jpg";
    private ImageView mImageView;

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);
        mImageView = (ImageView) findViewById(R.id.imageView);

        DisplayImageOptions options = ImageLoaderUtils.getDisplayImageOptions();
        ImageLoader.getInstance().displayImage(mImgUrl,mImageView,options);
    }
}
我们需要看的是

ImageLoader.getInstance().displayImage(mImgUrl,mImageView,options);
这句,这只是其中的一种加载图片的方法,参数1代表的是图片的url地址,参数2代表的是展示图片的控件,参数3是我们设置的DisplayImageOptions。

还有一种常见的写法就是4个参数,前三个参数跟上面方法一样,第四个参数加了ImageLoadingListener的回调接口:

ImageLoader.getInstance().displayImage(mImgUrl, mImageView, options, new ImageLoadingListener() {
            @Override
            public void onLoadingStarted(String imageUri, View view) {
                //加载开始的回调
            }

            @Override
            public void onLoadingFailed(String imageUri, View view, FailReason failReason) {
                //加载出错的回调
            }

            @Override
            public void onLoadingComplete(String imageUri, View view, Bitmap loadedImage) {
                //加载完成的回调
            }

            @Override
            public void onLoadingCancelled(String imageUri, View view) {
                //加载取消时的回调
            }
        });

这样我们就可以在图片加载的各种过程中做一系列的操作。



好了。今天就到这里啦。

大家共勉!


  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值