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資源解壓畫在一張圖片上,顯示時再也不須要解壓

相關文章
相關標籤/搜索