iOS网络开发(6)网络图片加载开源框架SDWebImage

SDWebImage是一个第三方框架,用以实现网络图像的缓存,及处理等功能。git

    Github的托管下载地址: https://github.com/rs/SDWebImagegithub


SDWebImage默认使用磁盘缓存,缓存

     在 沙盒/Library/Cache中能够找到带WebImageCache字眼的目录,能够找到缓存的图片网络


SDWebImage以分类的形式,对UIKit中的控件扩展了网络图片加载接口,使用起来很是方便。框架

介绍SDWebImage中的几个分类:异步

    UIImageView加载网络图片ide

    UIButton加载网络图片url

    UIImage显示GIF图片spa

并介绍图片下载进度的监听,以及框架内实现流程的简要说明线程



  • UIImageView+WebCache分类

提供了大量的方法,从网络中加载图片,并且这些操做所有是异步的

- (void)sd_setImageWithURL:(NSURL *)url
- (void)sd_setImageWithURL:(NSURL *)url completed:(SDWebImageCompletionBlock)completedBlock

部分方法还提供了占位图片的操做

- (void)sd_setImageWithURL:(NSURL *)url placeholderImage:(UIImage *)placeholder
- (void)sd_setImageWithURL:(NSURL *)url placeholderImage:(UIImage *)placeholder completed:(SDWebImageCompletionBlock)completedBlock

部分方法还提供了额外选项用于指定缓存的策略

- (void)sd_setImageWithURL:(NSURL *)url placeholderImage:(UIImage *)placeholder options:(SDWebImageOptions)options
- (void)sd_setImageWithURL:(NSURL *)url placeholderImage:(UIImage *)placeholder options:(SDWebImageOptions)options completed:(SDWebImageCompletionBlock)completedBlock

如:

    wKioL1bWkGyghYH5AAGsIiQrXpI720.png



  • UIButton+WebCache分类

与UIImageView+WebCache相似,不过UIButton上能够显示两个图片

背景图片的加载

- (void)sd_setBackgroundImageWithURL:(NSURL *)url forState:(UIControlState)state
- (void)sd_setBackgroundImageWithURL:(NSURL *)url forState:(UIControlState)state completed:(SDWebImageCompletionBlock)completedBlock
- (void)sd_setBackgroundImageWithURL:(NSURL *)url forState:(UIControlState)state placeholderImage:(UIImage *)placeholder
- (void)sd_setBackgroundImageWithURL:(NSURL *)url forState:(UIControlState)state placeholderImage:(UIImage *)placeholder completed:(SDWebImageCompletionBlock)completedBlock
- (void)sd_setBackgroundImageWithURL:(NSURL *)url forState:(UIControlState)state placeholderImage:(UIImage *)placeholder options:(SDWebImageOptions)options
- (void)sd_setBackgroundImageWithURL:(NSURL *)url forState:(UIControlState)state placeholderImage:(UIImage *)placeholder options:(SDWebImageOptions)options completed:(SDWebImageCompletionBlock)completedBlock

图片的加载

- (void)sd_setImageWithURL:(NSURL *)url forState:(UIControlState)state
- (void)sd_setImageWithURL:(NSURL *)url forState:(UIControlState)statecompleted:(SDWebImageCompletionBlock)completedBlock
- (void)sd_setImageWithURL:(NSURL *)url forState:(UIControlState)stateplaceholderImage:(UIImage *)placeholder
- (void)sd_setImageWithURL:(NSURL *)url forState:(UIControlState)stateplaceholderImage:(UIImage *)placeholder completed:(SDWebImageCompletionBlock)completedBlock
- (void)sd_setImageWithURL:(NSURL *)url forState:(UIControlState)stateplaceholderImage:(UIImage *)placeholder options:(SDWebImageOptions)options
- (void)sd_setImageWithURL:(NSURL *)url forState:(UIControlState)stateplaceholderImage:(UIImage *)placeholder options:(SDWebImageOptions)options completed:(SDWebImageCompletionBlock)completedBlock


  • UIImage+GIF分类,用于加载gif图片

这个分类提供了建立GIF图片对象的方法

+ (UIImage *)sd_animatedGIFNamed:(NSString *)name
+ (UIImage *)sd_animatedGIFWithData:(NSData *)data

      有兴趣的朋友,能够在框架中看看这两个方法的实现代码   


  • 图片下载进度的监听

不少App中,图片加载时会有一个加载的进度条,UIImageView一样提供了方法能够连续得到图片的下载进度:

- (void)sd_setImageWithURL:(NSURL *)url placeholderImage:(UIImage *)placeholder options:(SDWebImageOptions)options progress:(SDWebImageDownloaderProgressBlock)progressBlock completed:(SDWebImageCompletionBlock)completedBlock

 如:

    wKioL1bWkmfhs2USAAFfZ_IzU-E627.png


  • SDWebImage的原理分析

SDWebImage支持异步的图片下载+缓存,加载图片的基本流程:

  1. 显示placeholderImage,SDWebImageManager根据URL开始处理图片

  2. 从内存缓存中查找图片是否已被下载,若是找到,则回调显示图片

  3. 若是没有,则在子线程中查找磁盘缓存,,若是找到,则回调显示图片

  4. 若是没有,则开始从URL中下载图片(使用一个SDWebImageDownloader下载器对象)

  5. 经过代理方式,获得图片下载数据后,进行图片解码后,回调显示图片

  6. 将图片保存到SDImageCache中,内存缓存和磁盘缓存同时保存,写入磁盘的操做也将在子线程中执行


SDImageCache在初始化时会注册一些消息通知

     在内存警告或退到后台时清理内存缓存,

     在程序退出时清理过时图片


图片解码的目的(以空间换时间)

     UIImage的p_w_picpathWithData:每次都会将Data解压成图像,即每次显示时都会有一个解压操做

     SDWebImageDecoder是先将data资源解压画在一张图片上,显示时再也不须要解压

相关文章
相关标签/搜索