博客
关于我
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/

你可能感兴趣的文章
nodejs中Express 路由统一设置缓存的小技巧
查看>>
Node入门之创建第一个HelloNode
查看>>
NOIp2005 过河
查看>>
NotImplementedError: Cannot copy out of meta tensor; no data! Please use torch.nn.Module.to_empty()
查看>>
npm run build 失败Compiler server unexpectedly exited with code: null and signal: SIGBUS
查看>>
npm WARN deprecated core-js@2.6.12 core-js@<3.3 is no longer maintained and not recommended for usa
查看>>
npm前端包管理工具简介---npm工作笔记001
查看>>
npm和yarn的使用对比
查看>>
npm报错unable to access ‘https://github.com/sohee-lee7/Squire.git/‘
查看>>
npm的问题:config global `--global`, `--local` are deprecated. Use `--location=global` instead 的解决办法
查看>>
NPOI利用多任务模式分批写入多个Excel
查看>>
NR,NF,FNR
查看>>
nrf开发笔记一开发软件
查看>>
NSDateFormatter的替代方法
查看>>
nsis 安装脚本示例(转)
查看>>
NSOperation基本操作
查看>>
NSSet集合 无序的 不能重复的
查看>>
NT AUTHORITY\NETWORK SERVICE 权限问题
查看>>
ntko web firefox跨浏览器插件_深度比较:2019年6个最好的跨浏览器测试工具
查看>>
ntko文件存取错误_苹果推送 macOS 10.15.4:iCloud 云盘文件夹共享终于来了
查看>>