UITableViewCell重用和图像重新渲染

我有一个UITableView,它有18个部分,每个部分有1个标题头和1个单元格。 在每个单元格中,都会有一个水平的UIScrollView,其中包含多个图像。

问题是…我可以正确加载图像和单元格,但是当图像数量增加,单元格滚动到顶部时,会出现不同单元格的图像在其他单元格中popup…以及所有的渲染和图像都是错误的…图像应该在第3节或第4节出现在第1节….等。

数据源是从JSON加载的,JSON是正确的。 当图像不多,只有5-8个部分时,一切正常。 所以,这让我相信这是UITableViewCell产生这个问题的重用。

有人可以帮我一下这个…谢谢..下面是UITableViewCell的代码

// Customize the appearance of table view cells. - (UITableViewCell *)tableView:(UITableView *)tableView cellForRowAtIndexPath:(NSIndexPath *)indexPath { UITableViewCell *cell = nil; // add a placeholder cell while waiting on table data if ([self.datasource count] == 0 && indexPath.section == 0 && indexPath.row == 0) { UILabel *Fetch; static NSString *infoCell = @"infoCell"; cell = [tableView dequeueReusableCellWithIdentifier:infoCell]; if (cell == nil) { cell = [[[UITableViewCell alloc] initWithStyle:UITableViewCellStyleSubtitle reuseIdentifier:infoCell] autorelease]; cell.selectionStyle = UITableViewCellSelectionStyleNone; CellFetch = [[[UILabel alloc] initWithFrame:CGRectMake(15.0, 120.0, 280.0, 80.0)] autorelease]; CellFetch.tag = FETCH_TAG; CellFetch.font = [UIFont boldSystemFontOfSize:16.0]; CellFetch.textColor = [UIColor grayColor]; CellFetch.shadowColor = [UIColor whiteColor]; CellFetch.shadowOffset = CGSizeMake(0, -0.5); CellFetch.textAlignment = UITextAlignmentCenter; [cell.contentView addSubview:CellFetch]; } else { CellFetch = (UILabel *)[cell.contentView viewWithTag:FETCH_TAG]; } Fetch.text = fetchStatus; return cell; } else { UIScrollView *imgScroll; static NSString *imgCell = @"imgCell"; cell = [tableView dequeueReusableCellWithIdentifier:imgCell]; if (cell == nil) { cell = [[[UITableViewCell alloc] initWithStyle:UITableViewCellStyleDefault reuseIdentifier:imgCell] autorelease]; cell.selectionStyle = UITableViewCellSelectionStyleNone; imgScroll = [[[UIScrollView alloc] initWithFrame:CGRectMake(0.0, 0.0, 320, 108.0)]autorelease]; imgScroll.tag = SCROLLVIEW_TAG; imgScroll.showsVerticalScrollIndicator = NO; imgScroll.showsHorizontalScrollIndicator = NO; } else { imgScroll = (UIScrollView *)[cell.contentView viewWithTag:SCROLLVIEW_TAG]; } NSArray *sorted = [[self.datasource allKeys] sortedArrayUsingSelector:@selector(caseInsensitiveCompare:)]; //NSArray *allDistrict = [self.datasource allValues]; NSString *key = [sorted objectAtIndex:indexPath.section]; NSArray *img = [self.datasource valueForKey:key]; int column = 0; int space = 10; int width = 80; int x = space+5.0; for (NSUInteger i=0; i < img.count; i++) { UIButton * button = [UIButton buttonWithType:UIButtonTypeCustom]; NSDictionary *Info = [img objectAtIndex:i]; NSString *iconURL = [NSString stringWithFormat:@"%@",[Info objectForKey:@"ImgURL"]]; button.frame = CGRectMake(x , 4, 80, 80); [button setImageWithURL:[NSURL URLWithString:iconURL] placeholderImage:[UIImage imageNamed:@"pholder"]]; NSString *imgID = [Info objectForKey:@"ImgID"]; int k = [imgID intValue]; button.tag = k; [button addTarget:self action:@selector(onButtonPressed:) forControlEvents:UIControlEventTouchUpInside]; [imgScroll addSubview:button]; x+=space+width; column++; } [imgScroll setContentSize:CGSizeMake(column*90+10, 108)]; [cell.contentView addSubview:imgScroll]; } // Configure the cell... return cell; 

}

尝试使每个部分的单元格标识符都是唯一的,这样他们就不会在部分之间重复使用:

  cell = [tableView dequeueReusableCellWithIdentifier:@"section1cell"]; cell = [tableView dequeueReusableCellWithIdentifier:@"section2cell"]; 

我已经看到了某些部分中的单元格没有图像的问题,但在其他部分中却是这样。 所以当它重新使用这个单元格时,除非你专门设置图像属性为零…你可以得到一个先前已经成像的图像。

更新:

这是我在谈论的部分号码

 - (UITableViewCell *)tableView:(UITableView *)tableView cellForRowAtIndexPath:(NSIndexPath *)indexPath { NSString *section = [NSString stringWithFormat:@"section%@cell", indexPath.section]; UITableViewCell *cell = [self.tableView dequeueReusableCellWithIdentifier:section]; // some configuration return cell; } 

[cell.contentView addSubview:imgScroll];cell == nil部分。

喜欢 ,

  if (cell == nil) { cell = [[[UITableViewCell alloc] nitWithStyle:UITableViewCellStyleDefault reuseIdentifier:imgCell] autorelease]; cell.selectionStyle = UITableViewCellSelectionStyleNone; imgScroll = [[[UIScrollView alloc] initWithFrame:CGRectMake(0.0, 0.0, 320, 108.0)]autorelease]; imgScroll.tag = SCROLLVIEW_TAG; imgScroll.showsVerticalScrollIndicator = NO; imgScroll.showsHorizontalScrollIndicator = NO; [cell.contentView addSubview:imgScroll]; }