最近项目中首页的banner使用的com.youth.banner使用Glide异步加载图片:
public class GlideImageLoader extends ImageLoader {
@Override
public void displayImage(Context context, Object path, ImageView imageView) {
Glide.with(context).load(path).into(imageView);
}
}
在以上加载图片的过程中关闭了应用,此时发生崩溃错误,主要的详细日志如下所示:
AndroidRuntime: FATAL EXCEPTION: main
java.lang.IllegalArgumentException: You cannot start a load for a destroyed activity
at com.bumptech.glide.manager.RequestManagerRetriever.assertNotDestroyed(RequestManagerRetriever.java:134)
at com.bumptech.glide.manager.RequestManagerRetriever.get(RequestManagerRetriever.java:102)
at com.bumptech.glide.manager.RequestManagerRetriever.get(RequestManagerRetriever.java:87)
at com.bumptech.glide.Glide.with(Glide.java:629)
at com.jms.tqg_new.util.GlideImageLoader.displayImage(GlideImageLoader.java:21)
at com.jms.tqg_new.util.GlideImageLoader.displayImage(GlideImageLoader.java:9)
....
跟踪日志进入Glide调用的地方发现,出现在RequestManagerRetriever.assertNotDestroyed()方法中:
@TargetApi(Build.VERSION_CODES.JELLY_BEAN_MR1)
private static void assertNotDestroyed(Activity activity) {
if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.JELLY_BEAN_MR1 && activity.isDestroyed()) {
throw new IllegalArgumentException("You cannot start a load for a destroyed activity");
}
}
这是一个很明显的错误:Activity已经Destroyed。
解决方法:
在加载图片之前,先进行Activity是否Destroy的判断:
//判断Activity是否Destroy
public static boolean isDestroy(Activity activity) {
if (activity == null || activity.isFinishing() || (Build.VERSION.SDK_INT >= Build.VERSION_CODES.JELLY_BEAN_MR1 && activity.isDestroyed())) {
return true;
} else {
return false;
}
}
调用时,
if(!isDestroy((Activity)context)){
Glide.with(context).load(path).into(imageView);
}
最终,问题解决。
扫描二维码关注公众号,回复:
2084641 查看本文章