LazyTableImages是apple官方例子一个图片延迟加载的典型示例,本文简单记录该例子中的几个重点和一些心得。
1)为了增强tableview的滑动性能,采用了图片延迟加载的策略,具体实现有以下几个重点:
point1:tableview所在的视图控制器类中,添加一个用于记录当前正在进行中的图片请求的字典对象imageDownloadsInProgress,key为对应的indexPath;
point2:当tableview拖动结束并暂停后或者当前tableview静止时(即tableview的dragging为NO,decelerating为YES时),将当前可见的cells对应的图片请求加入到imageDownloadsInProgress中,并启动imageDownloadsInProgress中的所有图片请求;
point3:某一个indexPath对应的图片请求成功完成后,将indexPath对应的图片请求移除imageDownloadsInProgress,若图片请求错误,不移除,以后重试(等下次滚动并静止后或者reload列表的时候);
2)图片请求成功后,网络图片数据的尺寸和cell中imageview的尺寸不合,采用预渲染的策略,相关代码:
if (image.size.width != kAppIconSize || image.size.height != kAppIconSize)
{
CGSize itemSize = CGSizeMake(kAppIconSize, kAppIconSize);
UIGraphicsBeginImageContext(itemSize);
CGRect imageRect = CGRectMake(0.0, 0.0, itemSize.width, itemSize.height);
[image drawInRect:imageRect];
self.appRecord.appIcon = UIGraphicsGetImageFromCurrentImageContext();
UIGraphicsEndImageContext();
}
3)自定义的NSOperation的子类,在重载main方法中,要注意对当前NSOperation状态的判断if (![self isCancelled]);
4)为了尽可能的提升tableview的性能,减少不必要的协议方法的调用,比如,当cell的高度为常数kCustomRowHeight的时候,可用self.tableView.rowHeight = kCustomRowHeight代替相应的代理方法。