Glide ImageViewTarget 加载图片监听

本文介绍如何使用Glide加载高清大图,并在加载过程中显示进度条,加载完成后取消进度条。通过重写Glide的回调方法,可以实现加载过程中的自定义逻辑。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

引发场景:

使用 Glide 加载高清大图的时候,在加载过程中,显示一个加载进度条,加载结束之后,取消进度条。

Glide ImageViewTarget API

相关方法介绍:
 void onLoadCleared(Drawable placeholder) 

 加载时调用生命周期回调,取消了和它的资源释放。一般情况不需要我们操作。
void onLoadFailed(Exception e, Drawable errorDrawable) 

加载失败回调,根据需求,可在当前方法中进行图片加载失败的后续操作。
void onLoadStarted(Drawable placeholder) 

开始加载图片,可在当前方法中进行加载图片的初始操作。比如,显示加载进度条,
void onResourceReady(Z resource, GlideAnimation<? super Z> glideAnimation) 

当前方法表示图片资源加载完成。
Drawable getCurrentDrawable()

获取当前显示的 Drawable 
void setDrawable(Drawable drawable) 

设置 drawable 显示在当前 ImageView 
protected abstract void setResource(Z resource) 

该方法暂时不知道用途 
方法调用说明:

如果你只是想监听,不想修改Glide的默认行为,你可以继承任何一个Glide对ImageViewTargets的默认实现:

  • GlideDrawableImageViewTarget - 默认的Target,用于正常的加载和asGif()。(重写onResourceReady 方法后 .asGif() 可省略 )
  • BitmapImageViewTarget - 当使用asBitmap()加载时,使用的默认Target。

开始( onLoadStarted ),完成( onResourceReady ),失败( onLoadFailed )。这三个方法可视情况重写。完成方法在重写的时候需要注意 super.onResourceReady(resource, glideAnimation) 是需要保留的,其他方法中的,则可有可无。

示例代码:

Glide.with(context).load(mImageUrl).placeholder(R.drawable.default_error).into(new GlideDrawableImageViewTarget(mImageView) {

            @Override
            public void onLoadStarted(Drawable placeholder) {
            // 开始加载图片
                progressBar.setVisibility(View.VISIBLE);
            }

            @Override
            public void onLoadFailed(Exception e, Drawable errorDrawable) {
                progressBar.setVisibility(View.GONE);
                Toast.makeText(getActivity(), "图片加载失败", Toast.LENGTH_SHORT).show();

            }

            @Override
            public void onResourceReady(GlideDrawable resource, GlideAnimation<? super GlideDrawable> glideAnimation) {
                super.onResourceReady(resource, glideAnimation);
                // 图片加载完成
                mImageView.setImageDrawable(resource);
                progressBar.setVisibility(View.GONE);
            }
        });

这样我们就可以在 Glide 加载图片的过程中,进行添加自己的需求逻辑了。

以上属于个人测试结果,如果有什么错误的地方,还请各位指出,谢谢。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值