Glide图片加载库的用法已经够简单了,为什么还要封装呢?主要考虑到以下这些问题:
1、如果未来出现了更加优秀的图片加载库,我们可以迅速的更换
2、对具有相同占位符、加载错误图片和淡入淡出动画的加载配置,抽取成公共方法,方便修改共同属性
下面我们简单的分析下如何封装?先看下Glide的简单用法
Glide.with(context)
.load(url)
.crossFade(300)//淡入淡出动画
.placeholder(R.drawable.default_header)//占位符
.error(R.drawable.default_header)//加载失败显示的图片
.into(imageView);
总共有六个入参,context可以通过view.getContext()获取,url接口获取,imageView需要我们传进来,其他参数都是上述所说的公共参数,可抽取成方法,主要参数有url和ImageView,因此有了接口IImageLoader,使用的时候通过该接口调用对应的方法即可
/**
* 类描述:图片请求接口
* 作者:xues
* 时间:2017年08月23日
*/
public interface IImageLoader {
/**
* 加载头像
*
* @param url
* @param imageView
*/
public void loadHead(Object url, ImageView imageView);
/**
* 加载商品
*
* @param url
* @param imageView
*/
public void loadGoods(Object url, ImageView imageView);
/**
* 加载轮播图
*
* @param url
* @param imageView
*/
public void loadBanner(Object url, ImageView imageView);
/**
* 清除缓存
*/
public void clearCache();
}
GlideLoader实现类
/**
* 类描述:Glide网络图片加载库
* 作者:xues
* 时间:2017年08月23日
*/
public class GlideLoader implements IImageLoader {
private Context mContext;
/**
* 初始化Glide工具
*/
public GlideLoader() {
mContext = AppApplication.getInstance();
}
/**
* 加载头像
*
* @param url
* @param imageView
*/
@Override
public void loadHead(Object url, ImageView imageView) {
Glide.with(imageView.getContext())
.load(url)
.crossFade(300)//淡入淡出动画
.placeholder(R.drawable.default_header)//占位符
.error(R.drawable.default_header)//加载失败显示的图片
.into(imageView);
}
/**
* 加载商品图片
*
* @param url
* @param imageView
*/
@Override
public void loadGoods(Object url, ImageView imageView) {
Glide.with(imageView.getContext())
.load(url)
.crossFade(300)//淡入淡出动画
.placeholder(R.drawable.default_image)//占位符
.error(R.drawable.default_image)//加载失败显示的图片
.into(imageView);
}
@Override
public void loadBanner(Object url, ImageView imageView) {
Glide.with(imageView.getContext())
.load(url)
.crossFade(300)//淡入淡出动画
.placeholder(R.drawable.default_image)//占位符
.error(R.drawable.default_image)//加载失败显示的图片
.into(imageView);
}
/**
* 清空缓存
*/
@Override
public void clearCache() {
Glide.get(mContext).clearMemory();
Glide.get(mContext).clearDiskCache();
}
}
初始化GlideLoader或者OtherLoader
/**
* 类描述:网络图片加载工具类
* 作者:xues
* 时间:2017年08月23日
*/
public class ImageUtil {
public final static IImageLoader mImageLoader;
static {
//入参传入GlideLoader.class或OtherLoader.class
mImageLoader = init(GlideLoader.class);
}
/**
*
* @param clazz
* @param <T>
* @return
*/
public static <T extends IImageLoader> T init(Class<T> clazz) {
try {
IImageLoader imageLoader = (IImageLoader) Class.forName(clazz.getName()).newInstance();
return (T) imageLoader;
} catch (InstantiationException e) {
e.printStackTrace();
} catch (IllegalAccessException e) {
e.printStackTrace();
} catch (ClassNotFoundException e) {
e.printStackTrace();
}
return null;
}
}
加载网络图片时,传入url和imagView控件即可
ImageUtil.mImageLoader.loadGoods(url, imageView);
如果出现了更加优秀的图片加载库,只需要新建一个实现了IImageLoader接口的类,在ImageUtil的静态代码块中传入class即可,当然,实现类的方法体内容需要自己去实现。有问题的地方请多多指教,共同进步!