入口setImageWithUrl:placeHolderImage:options:會把placeHolderImage顯示,然后SDWebImageManager根據(jù)URL開始處理圖片.
進入SDWebImageManager-downloadWithURL:delegate:options:userInfo:交給SDImageCache從緩存查找圖片是否已經(jīng)下載queryDiskCacheForKey:delegate:userInfo:
先從內(nèi)存圖片緩存查找是否有圖片,如果內(nèi)存中已經(jīng)有圖片緩存,SDImageCacheDelegate回調(diào)imageCache:didFineImage:forKey:userInfo:到SDWebImageManager.
SDWebImageManagerDelegate回調(diào)webImageManager:didFinishWithImage:到UIImageView + WebCache等前端展示圖片.
如果內(nèi)存緩存中沒有,生成NSInvocationOperation添加到隊列開始從硬盤查找圖片是否已經(jīng)緩存
根據(jù)URLKey在硬盤緩存目錄下嘗試讀取圖片文件.這一步是在NSOperation進行的操作,所以回主線程進行結(jié)果回調(diào)notifyDelegate.
如果上一操作從硬盤讀取到了圖片,將圖片添加到內(nèi)存緩存中(如果空閑內(nèi)存過小 會先清空內(nèi)存緩存).SDImageCacheDelegate 回調(diào)imageCache:didFinishImage:forKey:userInfo:進而回調(diào)展示圖片.
如果從硬盤緩存目錄讀取不到圖片,說明所有緩存都不存在該圖片,需要下載圖片,回調(diào)imageCache:didNotFindImageForKey:userInfo.
共享或重新生成一個下載器SDWebImageDownLoader開始下載圖片
圖片下載由NSURLConnection來做,實現(xiàn)相關(guān)delegate來判斷圖片下載中,下載完成和下載失敗
connection:didReceiveData:中利用ImageIO做了按圖片下載進度加載效果
connectionDidFinishLoading:數(shù)據(jù)下載完成后交給SDWebImageDecoder做圖片解碼處理
圖片解碼處理在一個NSOperationQueue完成,不會拖慢主線程UI.如果有需要對下載的圖片進行二次處理,最好也在這里完成,效率會好很多.
在主線程notifyDelegateOnMainThreadWithInfo:宣告解碼完成imageDecoder:didFinishDecodingImage:userInfo:回調(diào)給SDWebImageDownloader
imageDownLoader:didFinishWithImage:回調(diào)給SDWebImageManager告知圖片下載完成
通知所有的downloadDelegates下載完成,回調(diào)給需要的地方展示圖片
將圖片保存到SDImageCache中內(nèi)存緩存和硬盤緩存同時保存,寫文件到硬盤也在以單獨NSInvocationOperation完成,避免拖慢主線程
SDImageCache在初始化的時候會注冊一些消息通知,在內(nèi)存警告或退到后臺的時候清理內(nèi)存圖片緩存,應(yīng)用結(jié)束的時候清理過期圖片
SDWI也提供UIButton + WebCache和MKAnnptation + WebCache方便使用
SDWebImagePrefetcher 可以預(yù)先下載圖片,方便后續(xù)使用
