關于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下來一次后就將圖片緩存起來,再次顯示的時候就不用去下載。


上一篇: 深入了解OpenGL——顏色混合

下一篇: 沒有符合條件的記錄

分享到: 更多
吉林时时连线走势图表 幸运pc28最快结果参考 重庆时时人工计划稳赢 手机足球即时比分预测 幸运飞艇5码倍投 福建时时开奖现场 广东时时任选2 云南时时几点开奖号码 北京pk10走势图解析 pk10双面盘攻略 北京pk106码技巧规律 鹿岛鹿角 时时彩改欢乐生肖 21点技巧16点碰到17点 酒吧5个骰子玩法及讲解 内蒙古时时彩