當(dāng)在一個(gè)頁(yè)面加載多張圖片時(shí),加載速度上要求順暢,則需要用到緩存機(jī)制,SDWebImage可以解決之。下面方法1 沒有用到緩存機(jī)制,加載圖片較慢,方法2 用到緩存,加載速度快。
- 方法1
NSData *data1 = [NSData dataWithContentsOfURL:[NSURL URLWithString:@"http://video-zfish.oss-cn-shenzhen.aliyuncs.com/camera/pictures/201702/18140700_1.jpeg”]];
UIImage *img1 = [UIImage imageWithData:data1];
NSLog(@"img1 像素 w:%f, h:%f", img1.size.width, img1.size.height);
- 方法2
// 優(yōu)化 計(jì)算網(wǎng)絡(luò)圖片的大小Size
// 1. 先查看SDWebImage有沒有緩存這張圖片,如果有則不用下載網(wǎng)絡(luò)圖片,直接獲取到圖片的大小
// 2. 如果沒有則會(huì)下載完整的圖片NSData來計(jì)算大小
SDWebImageManager *manager = [SDWebImageManager sharedManager];
UIImage *img;
if ([manager diskImageExistsForURL:[NSURL URLWithString:imgURL]]) {
img = [[manager imageCache] imageFromDiskCacheForKey: [NSURL URLWithString:imgURL].absoluteString];
ZFLOG(@"SD--獲取網(wǎng)絡(luò)圖片的大小--Size : %@", NSStringFromCGSize(img.size));
} else {
NSData *data = [NSData dataWithContentsOfURL:[NSURL URLWithString:imgURL]];
img = [UIImage imageWithData:data];
ZFLog(@"NSData--獲取網(wǎng)絡(luò)圖片的大小--Size : %@", NSStringFromCGSize(img.size));

編程愉快