IOS开发笔记 - 基于SDWebImage的网络图片加载处理
2023-09-27 14:23:52 时间
前言:
在IOS下通过URL读一张网络图片并不像Asp.net那样可以直接把图片路径放到图片路径的位置就ok,
而是需要我们通过一段类似流的方式去加载网络图片,接着才能把图片放入图片路径显示。
这里找了一段代码是用来加载图片:
-(UIImage *) getImageFromURL:(NSString *)fileURL { //NSLog(@"执行图片下载函数"); UIImage * result; NSData * data = [NSData dataWithContentsOfURL:[NSURL URLWithString:fileURL]]; result = [UIImage imageWithData:data]; return result; }
通过这个方法处理后可以得到一个UIImage,这样就可以放入UI界面的UIImageView了。
/*-----------------------------------------------切入主题-----------------------------------------------*/
在APP开发中,加载网络图片中大多是以一连串的形式去加载图片,所以当图片多的话,线程就会卡死= =!
所以,考虑到用户体验,这里需要找一种方法去异步加载图片!
关于图片异步加载这个思路,其实我也不太懂,于是借鉴了网上一个开源的项目SDWebImage去对UIImageView进行扩展,
最终优化网络图片的加载,使之获得两个新特性:
1.多图片异步加载。
2.加载完图片会用一个图片管理器去进行缓存。
其中最重要的一段代码如下:
- (void)setImageWithURL:(NSURL *)url refreshCache:(BOOL)refreshCache placeholderImage:(UIImage *)placeholder { // Remove in progress downloader from queue self.image = placeholder; if (url) { if ([[CustomObject sharedCustomObject] isExistImage:url]) { NSLog(@"存在图片"); self.image = [[CustomObject sharedCustomObject]getImage:url]; } else{ dispatch_async(dispatch_get_global_queue(DISPATCH_QUEUE_PRIORITY_DEFAULT, 0), ^{ NSData * data = [[NSData alloc]initWithContentsOfURL:url]; UIImage *image = [[UIImage alloc]initWithData:data]; if (data != nil) { dispatch_async(dispatch_get_main_queue(), ^{ [[CustomObject sharedCustomObject] addImage:image key:url]; self.image = image; }); } }); } } }
可以直接传入一个NSURL的图片路径对象对图片进行加载,若加载不为空则把图片缓存放入图片管理器单例保存起来,下一次再调用这个方式时会判断URL是否存在去读缓存。
这样异步加载,缓存图片的任务就完成了。
实例源码可以戳这里。OK。
主动用心,工作努力,坚持学习,坦诚分享,正面乐观,心存感恩
相关文章
- iOS开发技巧 - Size Class与iOS 8多屏幕适配(一)
- 《iOS 9 开发指南》——第1章,第1.3节工欲善其事,必先利其器——搭建开发环境
- 《iOS 6核心开发手册(第4版)》——2.3节Interface Builder中的按钮
- SwiftUI iOS 精品开源项目之 02 完整播客Podcast采用网络类项目Alamofire Feedkit SQLite (教程含源码)
- iOS 渲染
- iOS 10 之 网络权限带来的坑
- iOS 播放远程网络音乐的核心技术点
- iOS10 资料汇总:值得回看的 10 篇 iOS 热文
- iOS中集成ijkplayer视频直播框架
- iOS应用内支付(内购)的个人开发过程及坑!
- 聊聊 iOS 中的网络加密
- iOS_GET_网络请求
- iOS开发之网络编程--XCode7 更新以来需要手动设置的内容
- iOS开发网络篇—HTTP协议
- 苹果新iOS升级iMassage 以云端同步功能抗衡微信