ImageLoader应用

请求网络图片

必须继承Application 和一个依赖:
implementation ‘com.nostra13.universalimageloader:universal-image-loader:1.9.5’

得到ImageLoader instance = ImageLoader.getInstance();的方法

public class MyApp extends Application {

    //请求网络图片
    
    @Override
    public void onCreate() {
        super.onCreate();

        ImageLoaderConfiguration build = new ImageLoaderConfiguration.Builder(this).build();
        ImageLoader instance = ImageLoader.getInstance();
        instance.init(build);

    }
}

//高级应用

public class MyApp extends Application {
    File cacheFile= new File(Environment.getExternalStorageDirectory()+"/"+"imgages");

    @Override
    public void onCreate() {
        super.onCreate();
        //实例化
        ImageLoaderConfiguration build = new ImageLoaderConfiguration.Builder(this)
                .memoryCacheExtraOptions(480, 800) // default = device screen dimensions 内存缓存文件的最大长宽
                .diskCacheExtraOptions(480, 800, null)  // 本地缓存的详细信息(缓存的最大长宽),最好不要设置这个
                .tasksProcessingOrder(QueueProcessingType.FIFO) // default
                .denyCacheImageMultipleSizesInMemory()
                .memoryCache(new LruMemoryCache(2 * 1024 * 1024)) //可以通过自己的内存缓存实现
                .memoryCacheSize(2 * 1024 * 1024)  // 内存缓存的最大值
                .memoryCacheSizePercentage(13) // default
                .diskCacheSize(50 * 1024 * 1024) // 50 Mb sd卡(本地)缓存的最大值
                .diskCacheFileCount(100)  // 可以缓存的文件数量
                .diskCache(new UnlimitedDiskCache(cacheFile))//自定义缓存目录
                // default为使用HASHCODE对UIL进行加密命名, 还可以用MD5(new Md5FileNameGenerator())加密
                .diskCacheFileNameGenerator(new HashCodeFileNameGenerator())
                .defaultDisplayImageOptions(DisplayImageOptions.createSimple()) // default
                .writeDebugLogs() // 打印debug log
                .build();

        ImageLoader instance = ImageLoader.getInstance();

        instance.init(build);


    }
}

//配置类

public class MyAppUtil {

    public static DisplayImageOptions getDisplayImageOption() {
        DisplayImageOptions options = new DisplayImageOptions.Builder()
                .showImageOnLoading(R.drawable.aaatt) //设置图片在下载期间显示的图片
                .showImageForEmptyUri(R.drawable.ic0on)//设置图片Uri为空或是错误的时候显示的图片
                .showImageOnFail(R.drawable.iconj)  //设置图片加载/解码过程中错误时候显示的图片
                //.cacheInMemory(true)//设置下载的图片是否缓存在内存中
               // .cacheOnDisk(true)
                //.considerExifParams(true)  //是否考虑JPEG图像EXIF参数(旋转,翻转)
                //.imageScaleType(ImageScaleType.EXACTLY_STRETCHED)//设置图片以如何的编码方式显示
               // .bitmapConfig(Bitmap.Config.RGB_565)//设置图片的解码类型//
                .displayer(new RoundedBitmapDisplayer(20))//是否设置为圆角,弧度为多少
//                .displayer(new FadeInBitmapDisplayer(100))//是否图片加载好后渐入的动画时间
                .build();//构建完成
        return options;
    }


}

猜你喜欢

转载自blog.csdn.net/weixin_43812075/article/details/84645211