Android中使用Glide加载图片闪烁问题

Kotlin 复制代码
    Glide.with(vh.image)
                .setDefaultRequestOptions(requestOptions)
                .load(mImages[pos])
                .fitCenter()
                .override(Target.SIZE_ORIGINAL, Target.SIZE_ORIGINAL)
                .into(vh.image)

当使用Glide如上面的方式加载图片时,尤其是当图片资源比较大时,在更新图片资源(即将图a换成图b)时可能会出现ImageView短暂显示为透明状态,给人以闪烁的感觉,很不友好。

原因在于Glide会将我们传入的ImageView包装成ImageViewTarget对象,当Glide为Imageview重新加载新图片前会先调用com.bumptech.glide.request.SingleRequest的clear()方法,

Kotlin 复制代码
@Override
public void clear() {
    ...
    if (state == Status.CLEARED) {
        return;
    }
    
    state = Status.CLEARED;

    if (target != null) {
        target.onLoadCleared(getPlaceholderDrawable());
    }
    ...
}

这里会调用ImageViewTarget的onLoadCleared()方法,

Kotlin 复制代码
  @Override
  public void onLoadCleared(@Nullable Drawable placeholder) {
    super.onLoadCleared(placeholder);
    if (animatable != null) {
      animatable.stop();
    }
    setResourceInternal(null);
    setDrawable(placeholder);
  }

如果我们使用Glide时没有设置placeholder占位图,这里的placeholder则为null,这是导致ImageView有短暂透明状态的直接原因。

此时,我们只要重写onLoadCleared()方法即可解决此类问题:

Kotlin 复制代码
Glide.with(vh.image)           
                .asBitmap()
                .load(image)
                .fitCenter()
                .override(com.bumptech.glide.request.target.Target.SIZE_ORIGINAL, com.bumptech.glide.request.target.Target.SIZE_ORIGINAL)
                .into(object : CustomTarget<Bitmap?>() {
                    override fun onResourceReady(
                        resource: Bitmap,
                        @Nullable transition: Transition<in Bitmap?>?
                    ) {
                        vh.image.setImageBitmap(resource) // 直接设置 Bitmap,避免清空 ImageView
                    }

                    override fun onLoadCleared(@Nullable placeholder: Drawable?) {
                    }
                })
相关推荐
Full Stack Developme38 分钟前
SQL 中的 NULL 处理
android·数据库·sql
我最厉害。,。2 小时前
XSS 跨站&SVG&PDF&Flash&MXSS&UXSS&配合上传&文件添加脚本
android·pdf·xss
界面开发小八哥3 小时前
支持iOS与Android!SciChart开源金融图表库助力高效开发交易应用
android·ios·数据分析·数据可视化·图表工具·scichart
WWWWW3 小时前
理解VSync-4-应用申请与接收VSync(上)
android·源码阅读
WWWWW3 小时前
理解VSync-3-应用添加链接
android·源码阅读
_一条咸鱼_4 小时前
Android大厂面试秘籍:Activity 启动与任务栈管理原理
android·面试·kotlin
V少年5 小时前
深入浅出安卓ANR(应用无响应)全解析
android
V少年5 小时前
深入浅出安卓内存泄漏与优化
android
V少年5 小时前
深入浅出分析内存与CPU不足导致的ANR问题
android
_一条咸鱼_5 小时前
Android 大厂面试秘籍:Activity 生命周期原理详解
android·面试·android jetpack