今天在4S真機(jī)上頻繁發(fā)生閃退問(wèn)題,并且在控制臺(tái)打邮凉馈:Received memory warning.打印三次之后就會(huì)造成程序閃退.
這是因?yàn)?S真機(jī)上內(nèi)存過(guò)小,而在多個(gè)cell上圖片占用內(nèi)存過(guò)多, 雖然是tableView上是復(fù)用的, 圖片分辨率過(guò)大,依然會(huì)出現(xiàn)內(nèi)存警告的問(wèn)題.因?yàn)槲覀円恢倍际鞘褂肧DWebImage來(lái)加載圖片.所以就要從這里來(lái)下手解決了.
網(wǎng)上說(shuō)可以每次加載圖片清空memcache,但是效果并不好谓媒。
[[SDImageCache sharedImageCache] setValue:nil forKey:@"memCache"];
或者是把下面這個(gè)方法全部注釋掉
+ (UIImage *)decodedImageWithImage:(UIImage *)image
但是效果不明顯同時(shí)加載5-7張高分辨率圖片的話還是會(huì)立即崩潰
這就需要我們進(jìn)入到SDWebImage內(nèi)部去把圖片進(jìn)行等比例的壓縮了.下面就是具體的操作步驟
我們?cè)赨IImage+MultiFormat這個(gè)類(lèi)里面添加如下壓縮方法
+(UIImage *)compressImageWith:(UIImage *)image
{
float imageWidth = image.size.width;
float imageHeight = image.size.height;
float width = 640;
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;
}
然后在下面這張圖片箭頭所指處對(duì)圖片進(jìn)行壓縮
添加上這句代碼:
if (data.length/1024 > 128) {
image = [self compressImageWith:image];
}
如圖:
接下來(lái)就要去SDWebImageDownloaderOperation的connectionDidFinishLoading方法里面的:UIImage *image = [UIImage sd_imageWithData:self.imageData];箭頭所指處將等比壓縮過(guò)的image在賦在轉(zhuǎn)成data賦給self.imageData
//將等比壓縮過(guò)的image在賦在轉(zhuǎn)成data賦給self.imageData
NSData *data = UIImageJPEGRepresentation(image, 1);self.imageData = [NSMutableData dataWithData:data];
如圖:
再配合 [[SDImageCache sharedImageCache] setValue:nil forKey:@"memCache"];圖片加載后使用就可以了.