通过单元重用错误地绘制UITableView分隔符?

时间:2012-04-03 14:20:12

标签: ios uitableview reuseidentifier heightforrowatindexpath

我正在开发一个带有故事板的iOS 5项目,因此在IB中使用动态表格单元原型。在其中一个视图中,我有一个带有可变高度单元格的表格视图,单元格高度是根据内容的高度计算的。

首次显示表视图时,

tableView:heightForRowAtIndexPath:将返回所有单元格的正确值。当向下滚动几个项目时,一切都很好,但随后出现问题:实际单元格似乎是正确的高度,包括它们的触摸区域,但它们的分隔符在错误的位置(在单元格内而不是它们之间)呈现。 / p>

从测量分隔符位置开始,似乎单元格重用可能与此有关。前三个单元格的分隔符正确呈现,但不是第四个。 heightForRowAtIndexPath:返回正确的高度(本例中为125像素),其包含的子视图都在正确的位置。但是,分隔符仅从前一个分隔符渲染108个像素,将其放置在单元格的125像素高区域内。

这是踢球者:108px是第一个表格单元格的高度,现在看不见了,可能会重复使用。我没有明确的证据,但似乎表视图忽略了heightForRowAtIndexPath:这些单元格,只是根据重用的单元格高度渲染分隔符。

这并不能解释为什么一堆较晚的较短单元格根本不会呈现分隔符。但这就是我必须继续下去的事情。

是否有解决方法,IB设置或其他可能有用的内容?

2 个答案:

答案 0 :(得分:22)

我有同样的问题,分隔符在看似随机的位置显示。

原来问题是我覆盖了layoutSubviews,但忘了拨打[super layoutSubviews]。添加该调用可以解决我的问题。

答案 1 :(得分:1)

我也遇到了这个奇怪的问题。对于自定义表格单元格,添加图层作为分隔符可能是更好的选择。

在自定义表格单元类的initWith ***方法中:

separator = [CALayer layer];
separator.backgroundColor = [UIColor colorWithWhite:0.8f alpha:1.0f].CGColor;
[self.layer addSublayer:separator];

在layoutSubviews方法中更新分隔符的框架:

- (void)layoutSubviews {
   CGFloat height = 1.0f;
   separator.frame = CGRectMake(0.0f, self.frame.size.height - height, self.frame.size.width, height);
   [super layoutSubviews];
}