博客
关于我
Glide源码学习五:回调与监听
阅读量:595 次
发布时间:2019-03-11

本文共 2714 字,大约阅读时间需要 9 分钟。

Glide是一个强大的图片加载框架,支持自定义回调和监听,能够满足多种复杂的图片加载需求。在这一篇文章中,我们将深入探讨Glide中回调和监听的实现原理以及实际应用场景。

配置

目录

  • 1. into()方法
  • 2. 预加载方法 preload()
  • 3. 只下载方法 downloadOnly()
  • 4. listener()监听方法

1. into()方法

简单用法

Glide.with(this).load(url).into(imageView);

自定义Target

Glide的into()方法不仅可以接收ImageView,还可以接收自定义的Target实例。

示例

// 创建自定义的SimpleTargetSimpleTarget
simpleTarget = new SimpleTarget
() { @Override public void onResourceReady(Drawable resource, GlideAnimation glideAnimation) { imageView.setImageDrawable(resource); }};Glide.with(this) .load("图片地址") .into(simpleTarget);

2. 预加载方法 preload()

用法

Glide.with(this)    .load(url)    .diskCacheStrategy(DiskCacheStrategy.SOURCE) // 确保预加载的缓存被使用    .preload();

详细说明

Glide在预加载时,会下载图片的原始尺寸,缓存在硬盘中。之后在需要显示的时候,直接从缓存读取,速度加快。为了确保预加载的缓存被读取,可以在后续加载时使用diskCacheStrategy指定策略。

3. 只下载方法 downloadOnly()

用法一(子线程)

class DownloadImageTask extends AsyncTask
{ @Override protected File doInBackground(String... strings) { String url = strings[0]; File imageFile = new File( getExternalStorageDirectory().toString() + "/" + url ); try { FutureTarget
futureTarget = Glide.with(getBaseContext()) .load(url) .downloadOnly(Target.SIZE_ORIGINAL, Target.SIZE_ORIGINAL); return futureTarget.get(); } catch (Exception e) { e.printStackTrace(); return null; } }}

用法二(自定义Target)

public class MyDownloadTarget implements Target
{ @Override public void onResourceReady(File file, GlideAnimation animation) { // 处理文件 }}

Glide在子线程下载图片,确保不影响主线程性能。通过FutureTarget实现非阻塞下载,适合在子线程中使用。

4. listener()监听方法

用法示例

Glide.with(this)    .load(url)    .listener(new RequestListener
() { @Override public boolean onResourceReady(Resource resource, String model, Target
target, boolean isFromMemoryCache, boolean isFirstResource) { // 在图片加载完成时调用此方法 return false; } @Override public boolean onException(Exception e, String model, Target
target, boolean isFirstResource) { // 在图片加载失败时调用此方法 return false; } }) .into(imageView);

通过提供一个RequestListener实例,可以接收图片加载成功和失败的事件,从而实现对图片状态的监听和处理,尤其适用于错误处理和状态跟踪。

实现细节

into()方法的内部逻辑

Glide将图片加载完成后,调用ImageViewsetImageDrawable(),展示图片。同时,触发onResourceReady回调,供自定义逻辑处理。

preload()downloadOnly()的实现原理

这两个方法通过构建特定类型的Target(如PreloadTarget),在后台下载图片,确保缓存的准备。

listener()的实现机制

Glide在GenericRequest类中维护一个RequestListener,在图片加载过程中触发回调,支持自定义事件处理。

总结

通过以上方法,可以灵活控制Glide图片加载过程,从自定义Target,预加载,仅下载,到添加自定义监听,都能满足不同场景的需求。掌握这些技巧,有助于优化应用性能和用户体验。

转载地址:http://yfttz.baihongyu.com/

你可能感兴趣的文章
nginx日志分割并定期删除
查看>>
Nginx日志分析系统---ElasticStack(ELK)工作笔记001
查看>>
Nginx映射本地json文件,配置解决浏览器跨域问题,提供前端get请求模拟数据
查看>>
nginx最最最详细教程来了
查看>>
Nginx服务器---正向代理
查看>>
Nginx服务器上安装SSL证书
查看>>
Nginx服务器的安装
查看>>
Nginx模块 ngx_http_limit_conn_module 限制连接数
查看>>
nginx添加模块与https支持
查看>>
Nginx用户认证
查看>>
Nginx的location匹配规则的关键问题详解
查看>>
Nginx的Rewrite正则表达式,匹配非某单词
查看>>
Nginx的使用总结(一)
查看>>
Nginx的使用总结(三)
查看>>
Nginx的使用总结(二)
查看>>
Nginx的可视化神器nginx-gui的下载配置和使用
查看>>
Nginx的是什么?干什么用的?
查看>>
Nginx访问控制_登陆权限的控制(http_auth_basic_module)
查看>>
nginx负载均衡和反相代理的配置
查看>>
nginx负载均衡器处理session共享的几种方法(转)
查看>>