SDWebImage大家肯定都恨熟悉了帮匾,國(guó)內(nèi)外太多的App使用其進(jìn)行圖片加載查描。
但是最近在使用過(guò)程中發(fā)現(xiàn)耗溜,我用SDWebImage加載多個(gè)圖片组力,類似微博動(dòng)態(tài)那種,在加載的過(guò)程中抖拴。我發(fā)現(xiàn)當(dāng)圖片分辨率比較大的時(shí)候(不是圖片大)燎字,加載幾張圖片就崩潰了。
網(wǎng)上說(shuō)可以每次加載圖片清空memcache,但是效果并不好阿宅。
[[SDImageCache sharedImageCache] setValue:nil forKey:@"memCache"];
這地方采用的方法是:
第一步:在 UIImage+MultiFormat這個(gè)類里面添加如下壓縮方法
+(UIImage *)compressImageWith:(UIImage *)image {
float imageWidth = image.size.width;
float imageHeight = image.size.height;
float width = 320;
float height = image.size.height/(image.size.width/width);
float widthScale = imageWidth /width;
float heightScale = imageHeight /height;
// 創(chuàng)建一個(gè)bitmap的context
// 并把它設(shè)置成為當(dāng)前正在使用的context
UIGraphicsBeginImageContext(CGSizeMake(width, height));
if (widthScale > heightScale) {
[image drawInRect:CGRectMake(0, 0, imageWidth /heightScale , height)];
}else {
[image drawInRect:CGRectMake(0, 0, width , imageHeight /widthScale)];
}
// 從當(dāng)前context中創(chuàng)建一個(gè)改變大小后的圖片
UIImage *newImage = UIGraphicsGetImageFromCurrentImageContext();
// 使當(dāng)前的context出堆棧
UIGraphicsEndImageContext();
return newImage;
}
第二步: 在下面這個(gè)方法里調(diào)用壓縮方法
+ (nullable UIImage *)sd_imageWithData:(nullable NSData *)data {
if (!data) {
return nil;
}
UIImage *image;
SDImageFormat imageFormat = [NSData sd_imageFormatForImageData:data];
if (imageFormat == SDImageFormatGIF) {
image = [UIImage sd_animatedGIFWithData:data];
}
#ifdef SD_WEBP
else if (imageFormat == SDImageFormatWebP){
image = [UIImage sd_imageWithWebPData:data];
}
#endif
else {
image = [[UIImage alloc] initWithData:data];
image = [[UIImage alloc] initWithData:data];
if (data.length/1024 > 90) {
image = [self compressImageWith:image];
}
UIImageOrientation orientation = [self sd_imageOrientationFromImageData:data];
if (orientation != UIImageOrientationUp) {
image = [UIImage imageWithCGImage:image.CGImage scale:image.scale orientation:orientation];
}
}
return image;
}
第三步:
就是在SDWebImageDownloaderOperation的connectionDidFinishLoading方法里面的:
UIImage *image = [UIImage sd_imageWithData:self.imageData];
NSString *key = [[SDWebImageManager sharedManager] cacheKeyForURL:self.request.URL];
image = [self scaledImageForKey:key image:image];
NSData *data = UIImageJPEGRepresentation(image, 1);
self.imageData = [NSMutableData dataWithData:data];
最后;再配合 [[SDImageCache sharedImageCache] setValue:nil forKey:@"memCache"];(圖片加載后使用)大功告成候衍,親測(cè)內(nèi)存基本變化不大,自動(dòng)釋放也來(lái)得及
waring!!!注意:這個(gè)方法慎用,否則的話你所有的圖片都會(huì)被壓縮以后展示的時(shí)候就不清晰了.這個(gè)方法的原理是通過(guò)壓縮圖片質(zhì)量實(shí)現(xiàn)的.但是本人認(rèn)為最好不要采用這個(gè)方法.除非你自己在需要加載小圖的地方加標(biāo)志,來(lái)告訴sd,這個(gè)時(shí)候就需要修改sd了大家可以按這個(gè)思路進(jìn)行,但是修改起來(lái)可能麻煩.
第二種方案有一個(gè)比較好的處理方法,可以考慮一下,當(dāng)年寫這個(gè)的時(shí)候腦子沒(méi)轉(zhuǎn)過(guò)來(lái)