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

相关文章

Android使用ImageView.ScaleType实现图片的缩放与裁剪功能

《Android使用ImageView.ScaleType实现图片的缩放与裁剪功能》ImageView是最常用的控件之一,它用于展示各种类型的图片,为了能够根据需求调整图片的显示效果,Android提... 目录什么是 ImageView.ScaleType?FIT_XYFIT_STARTFIT_CENTE

关于MongoDB图片URL存储异常问题以及解决

《关于MongoDB图片URL存储异常问题以及解决》:本文主要介绍关于MongoDB图片URL存储异常问题以及解决方案,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐... 目录MongoDB图片URL存储异常问题项目场景问题描述原因分析解决方案预防措施js总结MongoDB图

python实现svg图片转换为png和gif

《python实现svg图片转换为png和gif》这篇文章主要为大家详细介绍了python如何实现将svg图片格式转换为png和gif,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录python实现svg图片转换为png和gifpython实现图片格式之间的相互转换延展:基于Py

使用Python从PPT文档中提取图片和图片信息(如坐标、宽度和高度等)

《使用Python从PPT文档中提取图片和图片信息(如坐标、宽度和高度等)》PPT是一种高效的信息展示工具,广泛应用于教育、商务和设计等多个领域,PPT文档中常常包含丰富的图片内容,这些图片不仅提升了... 目录一、引言二、环境与工具三、python 提取PPT背景图片3.1 提取幻灯片背景图片3.2 提取

Python实现图片分割的多种方法总结

《Python实现图片分割的多种方法总结》图片分割是图像处理中的一个重要任务,它的目标是将图像划分为多个区域或者对象,本文为大家整理了一些常用的分割方法,大家可以根据需求自行选择... 目录1. 基于传统图像处理的分割方法(1) 使用固定阈值分割图片(2) 自适应阈值分割(3) 使用图像边缘检测分割(4)

Redis消息队列实现异步秒杀功能

《Redis消息队列实现异步秒杀功能》在高并发场景下,为了提高秒杀业务的性能,可将部分工作交给Redis处理,并通过异步方式执行,Redis提供了多种数据结构来实现消息队列,总结三种,本文详细介绍Re... 目录1 Redis消息队列1.1 List 结构1.2 Pub/Sub 模式1.3 Stream 结

使用Python实现一个优雅的异步定时器

《使用Python实现一个优雅的异步定时器》在Python中实现定时器功能是一个常见需求,尤其是在需要周期性执行任务的场景下,本文给大家介绍了基于asyncio和threading模块,可扩展的异步定... 目录需求背景代码1. 单例事件循环的实现2. 事件循环的运行与关闭3. 定时器核心逻辑4. 启动与停

C#实现将Excel表格转换为图片(JPG/ PNG)

《C#实现将Excel表格转换为图片(JPG/PNG)》Excel表格可能会因为不同设备或字体缺失等问题,导致格式错乱或数据显示异常,转换为图片后,能确保数据的排版等保持一致,下面我们看看如何使用C... 目录通过C# 转换Excel工作表到图片通过C# 转换指定单元格区域到图片知识扩展C# 将 Excel

C#中async await异步关键字用法和异步的底层原理全解析

《C#中asyncawait异步关键字用法和异步的底层原理全解析》:本文主要介绍C#中asyncawait异步关键字用法和异步的底层原理全解析,本文给大家介绍的非常详细,对大家的学习或工作具有一... 目录C#异步编程一、异步编程基础二、异步方法的工作原理三、代码示例四、编译后的底层实现五、总结C#异步编程

JS+HTML实现在线图片水印添加工具

《JS+HTML实现在线图片水印添加工具》在社交媒体和内容创作日益频繁的今天,如何保护原创内容、展示品牌身份成了一个不得不面对的问题,本文将实现一个完全基于HTML+CSS构建的现代化图片水印在线工具... 目录概述功能亮点使用方法技术解析延伸思考运行效果项目源码下载总结概述在社交媒体和内容创作日益频繁的