Generated API 模式的设计出于以下两个目的:
1.集成库可以为 Generated API 扩展自定义选项。
2.在 Application 模块中可将常用的选项组打包成一个选项在 Generated API 中使用
1、添加 Glide 注解处理器的依赖
2.在 Application 模块中包含一个 AppGlideModule 的实现
@GlideModule
public class MyGlideModule extends AppGlideModule {
}
3.当你第一次添加你的 AppGlideModule
或做了某些类型的修改后,你可能需要重新构建 (rebuild) 你的项目。无论何时,如果你发现 API 没有被 import ,或看起来已经过期,你可以通过以下方法重新构建:1.打开 Build 菜单;2.点击 Rebuild Project。
将 Glide.with()
替换为 GlideApp.with(),
即可使用该 API 去完成加载工作。与 Glide.with()
不同,诸如 fitCenter()
和 placeholder()
等选项在 Builder 中直接可用,并不需要再传入单独的RequestOptions对象。
GlideApp.with(fragment)
.load(myUrl)
.placeholder(R.drawable.placeholder)
.fitCenter()
.into(imageView);
8.GlideExtension与GlideOption
定义一个在频繁使用的选项集合。
@GlideExtension
public class MyAppExtension {
private MyAppExtension() {
}
@GlideOption
public static BaseRequestOptions<?> defaultImg(BaseRequestOptions<?> options){
return options
.placeholder(R.drawable.p1)
.error(R.drawable.e2)
.fallback(R.drawable.f3)
.override(100,100);
}
}
使用对比:
GlideApp.with().load(). error(R.drawable.error).fallback(R.drawable.fallback)
GlideApp.with().load().defaultImg()
相关说明与资料请参考
Glide v4 : 快速高效的Android图片加载库 (muyangmin.github.io)
Glide v4 : Fast and efficient image loading for Android (bumptech.github.io)
GitHub - bumptech/glide: An image loading and caching library for Android focused on smooth scrolling