iOS開發實踐之cell下載圖片(SDWebImage)
阿新 • • 發佈:2019-02-20
前兩篇是自己寫的下載圖片方法,現在用第三方框架只要幾行程式碼就可以實現圖片的下載。SDWebImage底層實現的思路也是和前面說的一樣。 SDWebImage是網路圖片處理框架,封裝很很多方法,例如:圖片下載、圖片快取、下載進度監聽、gif處理等等。大大提高了網路圖片處理的效率。值得使用。
實現cell圖片下載之前,先了解一下SDWebImage的使用:
1、匯入框架,引入標頭檔案:
#import "UIImageView+WebCache.h"
2、圖片下載並快取方法:
UIImageView+WebCache.h
//得到當前圖片的url - (NSURL *)sd_imageURL; /** * 非同步下載圖片並快取 */ - (void)sd_setImageWithURL:(NSURL *)url; /** * 非同步下載圖片並快取,沒下載完之前先顯示佔位圖片,下載完之後再替換 */ - (void)sd_setImageWithURL:(NSURL *)url placeholderImage:(UIImage *)placeholder; /** * 非同步下載圖片並快取 * @param url 下載圖片路徑 * @param placeholder 佔位圖片,直到下載完成才替換 * @param options 下載圖片選擇方式 */ - (void)sd_setImageWithURL:(NSURL *)url placeholderImage:(UIImage *)placeholder options:(SDWebImageOptions)options; /** * 非同步下載圖片並快取,完成後可以在block中做事情 * @param url 下載圖片url * @param completedBlock SDWebImageCompletionBlock:UIImage *image, NSError *error, SDImageCacheType cacheType, NSURL *imageURL) block中可以得到下載圖片,錯誤資訊,快取型別,下載圖片地址 引數,給使用者做相應操作 */ - (void)sd_setImageWithURL:(NSURL *)url completed:(SDWebImageCompletionBlock)completedBlock; /** * 非同步下載圖片並快取,提供佔位圖片,並完成後可以在block中做事情 * * @param url T下載圖片url * @param placeholder T佔位圖片,直到下載完成才替換 * @param completedBlock SDWebImageCompletionBlock:UIImage *image, NSError *error, SDImageCacheType cacheType, NSURL *imageURL) block中可以得到下載圖片,錯誤資訊,快取型別,下載圖片地址 引數,給使用者做相應操作 */ - (void)sd_setImageWithURL:(NSURL *)url placeholderImage:(UIImage *)placeholder completed:(SDWebImageCompletionBlock)completedBlock; /** * 非同步下載圖片並快取,完成後可以在block中做事情 * @param url 下載圖片路徑 * @param placeholder 佔位圖片,直到下載完成才替換 * @param options 下載圖片選擇方式 * @param completedBlock 同上 */ - (void)sd_setImageWithURL:(NSURL *)url placeholderImage:(UIImage *)placeholder options:(SDWebImageOptions)options completed:(SDWebImageCompletionBlock)completedBlock; /** * 非同步下載圖片並快取,可以監聽下載進度,完成後可以在block中做事情 * @param url 下載圖片路徑 * @param placeholder 佔位圖片,直到下載完成才替換 * @param options 下載圖片選擇方式 * @param progress * SDWebImageDownloaderProgressBlock:NSInteger receivedSize(當前下載大小), NSInteger expectedSize(總大小) * @param completedBlock 同上 */ - (void)sd_setImageWithURL:(NSURL *)url placeholderImage:(UIImage *)placeholder options:(SDWebImageOptions)options progress:(SDWebImageDownloaderProgressBlock)progressBlock completed:(SDWebImageCompletionBlock)completedBlock; /** * 非同步下載圖片並快取,可以監聽下載進度,完成後可以在block中做事情 * @param url 下載圖片路徑 * @param placeholder 佔位圖片,直到下載完成才替換 * @param options 下載圖片選擇方式 * @param progress * SDWebImageDownloaderProgressBlock:NSInteger receivedSize(當前下載大小), NSInteger expectedSize(總大小) * @param completedBlock 同上 */ - (void)sd_setImageWithPreviousCachedImageWithURL:(NSURL *)url placeholderImage:(UIImage *)placeholder options:(SDWebImageOptions)options progress:(SDWebImageDownloaderProgressBlock)progressBlock completed:(SDWebImageCompletionBlock)completedBlock;
3、options所有選項
//失敗後重新下載 SDWebImageRetryFailed = 1 << 0, //最低優先順序,當正在進行UI互動時,自動暫停內部的一些下載操作 SDWebImageLowPriority = 1 << 1, //只快取記憶體 SDWebImageCacheMemoryOnly = 1 << 2, //漸進式下載,顯示的影象是逐步在下載 SDWebImageProgressiveDownload = 1 << 3, //重新整理快取 SDWebImageRefreshCached = 1 << 4, //後臺下載 SDWebImageContinueInBackground = 1 << 5, /** * Handles cookies stored in NSHTTPCookieStore by setting * NSMutableURLRequest.HTTPShouldHandleCookies = YES; */ SDWebImageHandleCookies = 1 << 6, //允許使用無效的SSL證書 SDWebImageAllowInvalidSSLCertificates = 1 << 7, //高優先順序下載 SDWebImageHighPriority = 1 << 8, //延遲佔位符 SDWebImageDelayPlaceholder = 1 << 9, //改變動畫形象 SDWebImageTransformAnimatedImage = 1 << 10, /** * By default, image is added to the imageView after download. But in some cases, we want to * have the hand before setting the image (apply a filter or add it with cross-fade animation for instance) * Use this flag if you want to manually set the image in the completion when success */ SDWebImageAvoidAutoSetImage = 1 << 11
4、記憶體處理:當app接收到記憶體警告時,我們要釋放記憶體。
SDWebImageManager *manager = [SDWebImageManager sharedManager];
// 取消正在下載的操作
[manager cancelAll];
// 清除記憶體快取
[manager.imageCache clearMemory];
//釋放磁碟的快取
[manager.imageCache cleanDisk];
上面只是實現圖片下載的方法和使用步驟而已,SDWebImage還要很多強大的功能,如本地快取引入SDImageCache.h,SDImageCache檔案裡面可以看到它提供了很多方法,並可以設定快取的時間(預設一個星期),快取大小等等。具體用到我們看一下相應的標頭檔案提高的方法即可,這裡不一一詳述。
cell下載圖片(SDWebImage) demo:
//
// AppsViewController.m
// cell圖片下載-SDWebImage
//
#import "AppsViewController.h"
#import "App.h"
#import "UIImageView+WebCache.h"
@interface AppsViewController ()
@property(nonatomic,strong) NSArray *apps;
@end
@implementation AppsViewController
- (void)viewDidLoad {
[super viewDidLoad];
}
- (void)didReceiveMemoryWarning {
[super didReceiveMemoryWarning];
// Dispose of any resources that can be recreated.
}
-(NSArray *)apps{
if (!_apps) {
NSMutableArray *appArr = [NSMutableArray array];
NSString *file = [[NSBundle mainBundle]pathForResource:@"apps" ofType:@"plist"];
NSArray *dictArr = [NSArray arrayWithContentsOfFile:file];
for (NSDictionary *dict in dictArr) {
App *app = [App appWithDict:dict];
[appArr addObject:app];
}
_apps = appArr;
}
return _apps;
}
#pragma mark - Table view data source
- (NSInteger)numberOfSectionsInTableView:(UITableView *)tableView {
return 1;
}
- (NSInteger)tableView:(UITableView *)tableView numberOfRowsInSection:(NSInteger)section {
return self.apps.count;
}
- (UITableViewCell *)tableView:(UITableView *)tableView cellForRowAtIndexPath:(NSIndexPath *)indexPath {
static NSString *ID = @"app";
UITableViewCell *cell = [tableView dequeueReusableCellWithIdentifier:ID];
if (!cell) {
cell = [[UITableViewCell alloc]initWithStyle:UITableViewCellStyleSubtitle reuseIdentifier:ID];
}
App *app = self.apps[indexPath.row];
cell.textLabel.text = app.name;
cell.detailTextLabel.text = app.download;
//下載圖片
NSURL *url = [NSURL URLWithString:app.icon];
//[cell.imageView sd_setImageWithURL:url];
//[cell.imageView sd_setImageWithURL:url placeholderImage:[UIImage imageNamed:@"placeholder"]];
//[cell.imageView sd_setImageWithURL:url completed:^(UIImage *image, NSError *error, SDImageCacheType cacheType, NSURL *imageURL) {
// NSLog(@"%@",imageURL);
//}];
//SDWebImage下載圖片
SDWebImageOptions options = SDWebImageRetryFailed | SDWebImageLowPriority;
[cell.imageView sd_setImageWithPreviousCachedImageWithURL:url placeholderImage:[UIImage imageNamed:@"placeholder"] options:options progress:^(NSInteger receivedSize, NSInteger expectedSize) {
NSLog(@"下載進度:%f",(double)receivedSize/expectedSize);
} completed:^(UIImage *image, NSError *error, SDImageCacheType cacheType, NSURL *imageURL) {
NSLog(@"下載圖片完成%@",image);
}];
return cell;
}
@end
注意:app接收到記憶體警告時,要釋放記憶體。 整個程式的要實現警告釋放記憶體,因此在AppDelegate.m 的applicationDidReceiveMemoryWarning方法中釋放。
-(void)applicationDidReceiveMemoryWarning:(UIApplication *)application{
SDWebImageManager *manager = [SDWebImageManager sharedManager];
// 1.取消正在下載的操作
[manager cancelAll];
// 2.清除記憶體快取
[manager.imageCache clearMemory];
}