UIday1603:图片异步下载、KVO

2024-04-08 04:58

本文主要是介绍UIday1603:图片异步下载、KVO,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

图片异步下载、KVO


 一、异步下载图⽚
 二、UITableView中图⽚的异步下载
 三、KVO
 四、KVO监测Model图⽚下载
 
 ⼀、异步下载图⽚
 真实开发中,网络接⼝返回的JSON或XML数据中,通常不会直接包含图⽚,而是给出图⽚的URL。
 因此,需要根据图⽚URL 获取图⽚数据,以便UI展⽰。
 
 因为 HTTP 协议是超⽂本传输协议,所以可以传输图⽚。
 图⽚下载与普通网络请求流程相同:
 1、创建⼀个request。
 2、建立urlConnection。
 3、使⽤请求到的数据。
 
 ImageDownloader
 图⽚下载是iOS开发中常⽤的功能,但系统并未提供图⽚下载类。
 为了便于后续使用,可以将图⽚下载封装到⼀个类⾥面(ImageDownloader)。
 ImageDownloader 允许外界指定URL,提供开始下载和取消下载功能,并提供delegate或block将图⽚传递给外界。
 
 ⼆、UITableView异步下载图片
 多数App中,UITableView 都会显⽰图片。
 UITableView 的重⽤机制,让我们能⽤很少的cell来呈现很多的内容(cell和model的数量不统⼀)。
 为了能正确显⽰图⽚,Model 类应该提供图⽚获取功能(Model 通过 ImageDownloader下载图片,供cell使用)。
 
 Model
 类注意事项:
 1、除了包含必要的数据外,还要包含⼀个ImageDownloader对象。
 2、包含一个image。
 3、包含⼀个图⽚是否正在下载的BOOL值。(⽤于判断是否需要开始下载)
 Cell 注意事项:
 根据 Model 信息,做⻚面显示。
 
 三、KVO
 KVO:(Key-Value-Observer)键值观察者,是观察者设计模式的一种具体实现。
 KVO触发机制:⼀个对象(观察者),监测另一对象(被观察者)的某属性是否发⽣变
 化,若被监测的属性发⽣的更改,会触发观察者的⼀个⽅法(⽅法名固定,类似代理⽅法)
 KVO 使⽤步骤:
 1、注册观察者(为被观察者指定观察者以及被观察属性)
 2、实现回调⽅法
 3、触发回调⽅法(被观察属性发⽣更改)
 4、移除观察者
 
 KVO 使⽤场景:MVC中M与C通信,M发⽣变化通知C。其中M是被观察者,C是观察者。
 KVO 注意事项:观察者销毁之前,移除观察者,否则会出现程序异常(给已经销毁的对象发送消息)
 
 四、KVO监测Model图⽚下载
 cell 图⽚及时显示
 tableView:cellForRowAtIndexPath: 会在重⽤的时候,根据Model显示image或者placeholderImage。
 如果tableView并未滑动,此时有图⽚下载完毕,是不会⽴即更新到cell上的。
 如何及时更新图⽚?
 
 KVO 监测 Model 属性
 ableView:cellForRowAtIndexPath:中,为Model的image属性添加观察者。
 image属性由nil变为⾮空的时候,视图控制器根据indexPath更新cell显⽰。
 
 总结
 ImageDownloader 封装了下载过程,提供了下载相关的⽅法。
 KVO 是观察者模式中的一种,当被观察属性发⽣变化,会及时触发相关事件。
 tableView 可以借助 KVO 监测下载,及时更新 cell。

这篇关于UIday1603:图片异步下载、KVO的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/884620

相关文章

Java下载文件中文文件名乱码的解决方案(文件名包含很多%)

《Java下载文件中文文件名乱码的解决方案(文件名包含很多%)》Java下载文件时,文件名中文乱码问题通常是由于编码不正确导致的,使用`URLEncoder.encode(filepath,UTF-8... 目录Java下载文件中文文件名乱码问题一般情况下,大家都是这样为了解决这个问题最终解决总结Java下

Python利用PIL进行图片压缩

《Python利用PIL进行图片压缩》有时在发送一些文件如PPT、Word时,由于文件中的图片太大,导致文件也太大,无法发送,所以本文为大家介绍了Python中图片压缩的方法,需要的可以参考下... 有时在发送一些文件如PPT、Word时,由于文件中的图片太大,导致文件也太大,无法发送,所有可以对文件中的图

java获取图片的大小、宽度、高度方式

《java获取图片的大小、宽度、高度方式》文章介绍了如何将File对象转换为MultipartFile对象的过程,并分享了个人经验,希望能为读者提供参考... 目China编程录Java获取图片的大小、宽度、高度File对象(该对象里面是图片)MultipartFile对象(该对象里面是图片)总结java获取图片

Java实战之自助进行多张图片合成拼接

《Java实战之自助进行多张图片合成拼接》在当今数字化时代,图像处理技术在各个领域都发挥着至关重要的作用,本文为大家详细介绍了如何使用Java实现多张图片合成拼接,需要的可以了解下... 目录前言一、图片合成需求描述二、图片合成设计与实现1、编程语言2、基础数据准备3、图片合成流程4、图片合成实现三、总结前

使用Python实现图片和base64转换工具

《使用Python实现图片和base64转换工具》这篇文章主要为大家详细介绍了如何使用Python中的base64模块编写一个工具,可以实现图片和Base64编码之间的转换,感兴趣的小伙伴可以了解下... 简介使用python的base64模块来实现图片和Base64编码之间的转换。可以将图片转换为Bas

异步线程traceId如何实现传递

《异步线程traceId如何实现传递》文章介绍了如何在异步请求中传递traceId,通过重写ThreadPoolTaskExecutor的方法和实现TaskDecorator接口来增强线程池,确保异步... 目录前言重写ThreadPoolTaskExecutor中方法线程池增强总结前言在日常问题排查中,

css实现图片旋转功能

《css实现图片旋转功能》:本文主要介绍了四种CSS变换效果:图片旋转90度、水平翻转、垂直翻转,并附带了相应的代码示例,详细内容请阅读本文,希望能对你有所帮助... 一 css实现图片旋转90度.icon{ -moz-transform:rotate(-90deg); -webkit-transfo

微服务架构之使用RabbitMQ进行异步处理方式

《微服务架构之使用RabbitMQ进行异步处理方式》本文介绍了RabbitMQ的基本概念、异步调用处理逻辑、RabbitMQ的基本使用方法以及在SpringBoot项目中使用RabbitMQ解决高并发... 目录一.什么是RabbitMQ?二.异步调用处理逻辑:三.RabbitMQ的基本使用1.安装2.架构

Python实现文件下载、Cookie以及重定向的方法代码

《Python实现文件下载、Cookie以及重定向的方法代码》本文主要介绍了如何使用Python的requests模块进行网络请求操作,涵盖了从文件下载、Cookie处理到重定向与历史请求等多个方面,... 目录前言一、下载网络文件(一)基本步骤(二)分段下载大文件(三)常见问题二、requests模块处理

C#实现添加/替换/提取或删除Excel中的图片

《C#实现添加/替换/提取或删除Excel中的图片》在Excel中插入与数据相关的图片,能将关键数据或信息以更直观的方式呈现出来,使文档更加美观,下面我们来看看如何在C#中实现添加/替换/提取或删除E... 在Excandroidel中插入与数据相关的图片,能将关键数据或信息以更直观的方式呈现出来,使文档更