当前位置:新注册送38元体验金 > 新注册送38元体验金操作系统 > 详解TableView中图片延时加载

详解TableView中图片延时加载

文章作者:新注册送38元体验金操作系统 上传时间:2019-08-22

TableView图片延时加载是本文要介绍的内容,经常我们会用tableView显示很多条目,有时候需要显示图片。但是一次性从服务器上取来所有图片对用户来浪费流量,对服务器也是负担,最好是按需加载,即当该用户要浏览该条目时再去加载经常我们会用tableView显示很多条目。

有时候需要显示图片, 但是一次从服务器上取来所有图片对用户来浪费流量,,对服务器也是负担.最好是按需加载,即当该用户要浏览该条目时再去加载它的图片。

重写如下方法

- (void)tableView:(UITableView *)tableView willDisplayCell:(UITableViewCell *)cell forRowAtIndexPath:(NSIndexPath *)indexPath  {      UIImage *image = [self getImageForCellAtIndexPath:indexPath];  //从网上取得图片      [cell.imageView setImage:image];  } 

这虽然解决了延时加载的问题, 但当网速很慢, 或者图片很大时(假设,虽然一般cell中的图很小),你会发现程序可能会失去对用户的响应.

原因是

UIImage *image = [self getImageForCellAtIndexPath:indexPath]; 

这个方法可能要花费大量的时间,主线程要处理这个method,所以失去了对用户的响应.

所以要将该方法提出来:

- (void)updateImageForCellAtIndexPath:(NSIndexPath *)indexPath  {      NSAutoreleasePool *pool = [[NSAutoreleasePool alloc] init];      UIImage *image = [self getImageForCellAtIndexPath:indexPath];      UITableViewCell *cell = [self.tableView cellForRowAtIndexPath:indexPath];      [cell.imageView performSelectorOnMainThread:@selector(setImage:) withObject:image waitUntilDone:NO];      [pool release];  } 

然后再新开一个线程去做这件事情

- (void)tableView:(UITableView *)tableView willDisplayCell:(UITableViewCell *)cell forRowAtIndexPath:(NSIndexPath *)indexPath  {      [NSThread detachNewThreadSelector:@selector(updateImageForCellAtIndexPath:) toTarget:self withObject:indexPath];  } 

同理当我们需要长时间的计算时,也要新开一个线程 去做这个计算以避免程序处于假死状态

以上代码只是示例, 还可以改进的更多, 比如从网上down下来一次后就将图片缓存起来,再次显示的时候就不用去下载。

小结:详解TableView图片延时加载的内容介绍完了,希望通过本文的学习能对你有所帮助!

中 图片 延时加载是本文要介绍的内容,经常我们会用 tableView 显示很多条目,有时候需要显示 图片 。但是一次性从 服务器 上取来...

本文由新注册送38元体验金发布于新注册送38元体验金操作系统,转载请注明出处:详解TableView中图片延时加载

关键词: