Glide 图片加载库详细用法

Gilde 定义

Gilde 是google开源的图片加载库。

glide依赖

//glide

compile 'com.github.bumptech.glide:glide:4.0.0'

annotationProcessor 'com.github.bumptech.glide:compiler:4.0.0'

glide 基础用法

glide 用法传承目前流行的链式调用。

/**

* 基础用法.

*/

private void baseUsed(){

Glide.with(this)

.load(URL)

.into(mImageView);

}

glide 可以用RequestOptions配置各种参数:

private void gildeOptions(){

RequestOptions options = new RequestOptions();

options.centerCrop()

.placeholder(R.drawable.default_avatar)

.error(R.drawable.image_error)

.fallback(R.drawable.fallback_nodata);

Glide.with(this)

.load(URL)

.apply(options)

.into(mImageView);

}

其中Built in types:

CenterCrop:类似 ScaleType.CENTER_CROP

FitCenter: 类似 ScaleType.FIT_CENTER

CircleCrop: 圆形裁剪

placeholder: 占位即加载中的图片。

error: 错误图片.

fallback: 当url为null的时候,判断是否设置了fallback,是的话则显示fallback图片,否的话显示error图片,如果error还是没有设置则显示placeholder图片.

这几个图片显示规则:

glide.png

glide RequestBuilders还可以重用开始多个加载

private void multipleLoad(){

RequestOptions options = new RequestOptions();

options.centerCrop()

.placeholder(R.drawable.default_avatar)

.error(R.drawable.image_error)

.fallback(R.drawable.fallback_nodata);

RequestBuilder requestBuilder =

Glide.with(this)

.asDrawable().apply(options);

for(int i=0;i

ImageView view = (ImageView) mImageGroup.getChildAt(i);

requestBuilder.clone()

.load(urls[i])

.into(view);

}

}

AppGlideModule 用法

在glide4中引入 glideApp,通过annotation将option封装自动生成代码。

第一步必须自定义一个module 继承于AppGlideModule。

@GlideModule

public final class MyGlideModule extends AppGlideModule {

}

注意:AppGlideModule实现必须始终与@GlideModule注释一起出现.如果注释不存在,则该模块将不会被发现。重新编译,会自动生成代码,后面可用GlideApp.with() 代替Glide.with()

1、设置手机默认推荐缓存大小。MemorySizeCalculator类通过考虑设备给定的可用内存和屏幕大小想出合理的默认大小.

/**

* MemorySizeCalculator类通过考虑设备给定的可用内存和屏幕大小想出合理的默认大小.

* 通过LruResourceCache进行缓存。

* @param context

* @param builder

*/

@Override

public void applyOptions(Context context, GlideBuilder builder) {

MemorySizeCalculator calculator = new MemorySizeCalculator.Builder(context)

.setMemoryCacheScreens(2)

.build();

builder.setMemoryCache(new LruResourceCache(calculator.getMemoryCacheSize()));

}

2、自定义内存缓存大小

/**

* 自定义缓存大小.

* @param context

* @param builder

*/

@Override

public void applyOptions(Context context, GlideBuilder builder) {

int memoryCacheSizeBytes = 1024 * 1024 * 20; // 20mb

builder.setMemoryCache(new LruResourceCache(memoryCacheSizeBytes));

}

3、Disk Cache.自定义内置磁盘缓存大小

/**

* Disk Cache.自定义内置磁盘缓存大小.

* @param context

* @param builder

*/

@Override

public void applyOptions(Context context, GlideBuilder builder) {

int diskCacheSizeBytes = 1024 * 1024 * 100; // 100 MB

builder.setDiskCache(new InternalCacheDiskCacheFactory(context, diskCacheSizeBytes));

}

4、Disk Cache.自定义内置磁盘缓存大小并指定路径.

/**

* Disk Cache.自定义内置磁盘缓存大小并指定路径.

* @param context

* @param builder

*/

@Override

public void applyOptions(Context context, GlideBuilder builder) {

int diskCacheSizeBytes = 1024 * 1024 * 100; // 100 MB

builder.setDiskCache(

new InternalCacheDiskCacheFactory(context, "cacheFolderName", diskCacheSizeBytes));

}

5、Disk Cache.自定义外置磁盘缓存大小并指定路径.

/**

* Disk Cache.自定义外置磁盘缓存大小并指定路径.

* @param context

* @param builder

*/

@Override

public void applyOptions(Context context, GlideBuilder builder) {

int diskCacheSizeBytes = 1024 * 1024 * 100; // 100 MB

builder.setDiskCache(

new ExternalCacheDiskCacheFactory(context, "cacheFolderName", diskCacheSizeBytes));

}

isManifestParsingEnabled 设置清单解析,设置为false,避免添加相同的modules两次

@Override

public boolean isManifestParsingEnabled() {

return false;

}

GlideApp用法

基本用法

private void gildeAppUsed(){

GlideApp.with(this)

.load(URL1)

.placeholder(R.drawable.default_avatar)

.error(R.drawable.image_error)

.fallback(R.drawable.fallback_nodata)

.into(mImageView);

}

设置完全缓存

/**

* 缓存.

*/

private void diskCacheStrategyAll(){

GlideApp.with(this)

.asBitmap()

.load(URL)

.placeholder(R.drawable.default_avatar)

.error(R.drawable.image_error)

.fallback(R.drawable.fallback_nodata)

.diskCacheStrategy(DiskCacheStrategy.ALL)

.into(mImageView);

}

DiskCacheStrategy.NONE 不做磁盘缓存

DiskCacheStrategy.SOURCE 只缓存图像原图

DiskCacheStrategy.RESULT 只缓存加载后的图像,即处理后最终显示时的图像

DiskCacheStrategy.ALL 缓存所有版本的图像(默认行为)

只从缓存中读取,如果缓存没有,则失败.

private void retrieveFromCache(){

GlideApp.with(this)

.asBitmap()

.load(URL)

.placeholder(R.drawable.default_avatar)

.error(R.drawable.image_error)

.fallback(R.drawable.fallback_nodata)

.onlyRetrieveFromCache(true)

.into(mImageView);

}

跳过缓存. 每次都从服务端获取最新.

/**

* 跳过缓存. 每次都从服务端获取最新.

* diskCacheStrategy: 磁盘缓存

* skipMemoryCache:内存缓存

*/

private void skipCache(){

GlideApp.with(this)

.asBitmap()

.load(URL)

.diskCacheStrategy(DiskCacheStrategy.NONE)

.skipMemoryCache(true)

.into(mImageView);

}

清除缓存

/**

* 清除内存缓存.

*/

private void clearMemoryCache(){

// This method must be called on the main thread.

Glide.get(this).clearMemory();

}

/**

* 清除磁盘缓存.

*/

private void clearDiskCache(){

new AsyncTask(){

@Override

protected Void doInBackground(Void... params) {

// This method must be called on a background thread.

Glide.get(getApplicationContext()).clearDiskCache();

return null;

}

};

}

其他

自定义圆角Transform

public class CircleTransform extends BitmapTransformation {

public CircleTransform(Context context){

super(context);

}

@Override

protected Bitmap transform(@NonNull BitmapPool pool, @NonNull Bitmap toTransform, int outWidth, int outHeight) {

return circleCrop(pool,toTransform);

}

@Override

public void updateDiskCacheKey(MessageDigest messageDigest) {

}

private static Bitmap circleCrop(BitmapPool pool, Bitmap source) {

if (source == null) return null;

int size = Math.min(source.getWidth(), source.getHeight());

int x = (source.getWidth() - size) / 2;

int y = (source.getHeight() - size) / 2;

Bitmap squared = Bitmap.createBitmap(source, x, y, size, size);

Bitmap result = pool.get(size, size, Bitmap.Config.ARGB_8888);

if (result == null) {

result = Bitmap.createBitmap(size, size, Bitmap.Config.ARGB_8888);

}

Canvas canvas = new Canvas(result);

Paint paint = new Paint();

//画布中背景图片与绘制图片交集部分

paint.setShader(new BitmapShader(squared, BitmapShader.TileMode.CLAMP, BitmapShader.TileMode.CLAMP));

paint.setAntiAlias(true);

float r = size / 2f;

canvas.drawCircle(r, r, r, paint);

return result;

}

}

调用:

/**

* 自定义圆形裁剪.

*/

private void customerOptions(){

RequestOptions options = new RequestOptions();

options.centerCrop()

.placeholder(R.drawable.default_avatar)

.error(R.drawable.image_error)

.fallback(R.drawable.fallback_nodata)

.transform(new CircleTransform(this));

Glide.with(this)

.load(URL)

.apply(options)

.into(mImageView);

}

作者:johnnycmj

链接:http://www.jianshu.com/p/34cac7ec531e

來源:简书

著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 194,491评论 5 459
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 81,856评论 2 371
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 141,745评论 0 319
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 52,196评论 1 263
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 61,073评论 4 355
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 46,112评论 1 272
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 36,531评论 3 381
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 35,215评论 0 253
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 39,485评论 1 290
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 34,578评论 2 309
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 36,356评论 1 326
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 32,215评论 3 312
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 37,583评论 3 299
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 28,898评论 0 17
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 30,174评论 1 250
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 41,497评论 2 341
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 40,697评论 2 335

推荐阅读更多精彩内容