Logo Questions Linux Laravel Mysql Ubuntu Git Menu
 

UITableView separators drawn incorrectly through cell reuse?

I'm working on an iOS 5 project with storyboards, and thus using dynamic table cell prototypes in IB. In one of the views, I've got a table view with variable-height cells, with the cell height calculated from the height of the contents.

tableView:heightForRowAtIndexPath: returns correct values for all cells when the table view is first displayed. All is well when scrolling down for a few items, but then something goes amiss: the actual cells seem to be correct height, including their touch areas, but their separators are rendered in the wrong places (inside cells instead of between them).

From measuring the separator placement, it appears as if cell reuse might have something to do with this. The separators for the first three cells are rendered correctly, but not the fourth one. heightForRowAtIndexPath: returns the correct height for it (125 pixels in this case), and its contained subviews are all in their right places. However, the separator is rendered only 108 pixels from the previous separator, placing it inside the 125 pixel high area of the cell.

Here's the kicker: 108px is the height of the first table cell, now out of sight and probably reused. I don't have definite proof of this, but it appears that the table view is ignoring heightForRowAtIndexPath: for these cells and is just rendering the separator according to the reused cell height.

This doesn't explain why a bunch of later, shorter cells are not rendered separators at all. But this is all I've got to go on.

Is there a workaround, an IB setting or something else that might help?

like image 512
JK Laiho Avatar asked Apr 03 '12 14:04

JK Laiho


1 Answers

I had the same problem where the separators were showing at seemingly random positions.

It turned out the problem was that I was overriding layoutSubviews but forgot to call [super layoutSubviews]. Adding that call fixed the issue for me.

like image 60
pfluger Avatar answered Oct 08 '22 03:10

pfluger