最近我有这个在我的视图中加载图像
Glide.with(getApplicationContext()).load(url).into(imageView);
现在,我想用接口实现一个回调来知道从url中获取图像的时间,我需要这个回调才能显示我自己创建的自定义进度条。
搜索我发现了这个,但不是我想要的
.listener(new RequestListener<Uri, GlideDrawable>() {
@Override public boolean onException(Exception e, Uri model, Target<GlideDrawable> target, boolean isFirstResource) {
return false;
}
@Override public boolean onResourceReady(GlideDrawable resource, Uri model, Target<GlideDrawable> target, boolean isFromMemoryCache, boolean isFirstResource) {
return false;
}
})
.into(imageView)
;
因为它没有为资源定义自定义回调接口,是否有任何方法可以附加回调滑动,所以我知道图像的downlad何时完成?
您可以将上述方法与.listener()一起使用,但将其传递给您定义的新类类型的对象。该新类实现了RequestListener,并在构造函数中将所需的任何自定义回调对象作为参数。下载已在onResourceReady()中准备就绪。假设您将自定义回调作为对象:
CustomCallback CustomCallback;
并在使用滑动加载图像之前开始进度:
customCallback.startProgressBar();
Glide.with(this)
.listener(new CustomRequestListener(customCallback))
.into(imageView);
是自定义类是:
private static class CustomRequestListener implements RequestListener<Uri, GlideDrawable> {
private CustomCallback cc;
public CustomRequestListener(CustomCallback cc) {
this.cc = cc;
}
@Override public boolean onException(Exception e, Uri model, Target<GlideDrawable> target, boolean isFirstResource) {
cc.stopProgressBar();
return false;
}
@Override public boolean onResourceReady(GlideDrawable resource, Uri model, Target<GlideDrawable> target, boolean isFromMemoryCache, boolean isFirstResource) {
cc.stopProgressBar();
return false;
}
}