Glide4 高效加载图片的配置详解
作者:康熙微博私访记
本篇文章主要介绍了Glide4 高效加载图片的配置详解,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧
本文介绍了Glide4 高效加载图片的配置详解,分享给大家,具体如下:
在build.gradle中添加glide依赖
// glide 依赖 compile 'com.github.bumptech.glide:glide:4.6.1' // glide 相关注解,生成GlideApp代码 annotationProcessor 'com.github.bumptech.glide:compiler:4.6.1' // Glide网络库配置成okhttp3 compile ('com.github.bumptech.glide:okhttp3-integration:4.6.1') { transitive = false }
Glide全局配置类
package com.leo.demo; import android.content.Context; import android.support.annotation.NonNull; import com.bumptech.glide.Glide; import com.bumptech.glide.GlideBuilder; import com.bumptech.glide.Registry; import com.bumptech.glide.annotation.GlideModule; import com.bumptech.glide.load.engine.DiskCacheStrategy; import com.bumptech.glide.load.engine.cache.ExternalCacheDiskCacheFactory; import com.bumptech.glide.module.AppGlideModule; import com.bumptech.glide.request.RequestOptions; /** * Created by kangyi on 2018/3/20. * * Glide全局配置,使用GlideModule注解执行自动代码生成,生成GlideApp,后续的Glide * 调用都需要替换为GlideApp.with(context).load(url).into(imageView) 的方式 * */ @GlideModule public class GlobalGlideConfig extends AppGlideModule { @Override public void registerComponents(@NonNull Context context, @NonNull Glide glide, @NonNull Registry registry) { super.registerComponents(context, glide, registry); } @Override public boolean isManifestParsingEnabled() { return false; } @Override public void applyOptions(@NonNull Context context, @NonNull GlideBuilder builder) { super.applyOptions(context, builder); /** * DiskCacheStrategy.NONE: 表示不缓存任何内容。 * DiskCacheStrategy.DATA: 表示只缓存原始图片。 * DiskCacheStrategy.RESOURCE: 表示只缓存转换过后的图片。 * DiskCacheStrategy.ALL : 表示既缓存原始图片,也缓存转换过后的图片。 * DiskCacheStrategy.AUTOMATIC: 表示让Glide根据图片资源智能地选择使用哪一种缓存策略(默认选项)。 */ builder.setDefaultRequestOptions(new RequestOptions().diskCacheStrategy(DiskCacheStrategy.RESOURCE)); /** * 优先外部存储作为磁盘缓存目录,防止内部存储文件过大 * 外部存储目录默认地址为:/sdcard/Android/data/com.sina.weibolite/cache/image_manager_disk_cache */ builder.setDiskCache(new ExternalCacheDiskCacheFactory(context)); } }
代码解析
磁盘缓存策略
缓存常量 | 说明 |
---|---|
DiskCacheStrategy.NONE | 表示不缓存任何内容。 |
DiskCacheStrategy.DAT | 表示只缓存原始图片。 |
DiskCacheStrategy.RESOURCE | 表示只缓存转换过后的图片。 |
DiskCacheStrategy.ALL | 表示既缓存原始图片,也缓存转换过后的图片。 |
DiskCacheStrategy.AUTOMATIC | 表示让Glide根据图片资源智能地选择使用哪一种缓存策略(默认选项)。 |
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持脚本之家。
您可能感兴趣的文章:
- 导入takephoto库编译失败与glide库冲突应排除依赖
- Glide4.6.1 GlideApp无法生成的问题的解决
- Android中Glide获取图片Path、Bitmap用法详解
- Android将Glide动态加载不同大小的图片切圆角与圆形的方法
- Android添加glide库报错Error: Failed to resolve: com.android.support:support-annotations:26.0.2的解决
- android中Glide实现加载图片保存至本地并加载回调监听
- 详解Android中Glide与CircleImageView加载圆形图片的问题
- Android基于Glide v4.x的图片加载进度监听
- Android利用Glide获取图片真正的宽高的实例
- Glide用法与技巧以及优秀库的推荐