I have this table whose cells look like this: 
As you can see, the top border of each cell should overlap with the cell above. Right now this border is part of the background (until it overlaps).
Now I have separated the border from the background, and the code for creating my cell is as follows:
#define QAImage(NAME) [[[UIImageView alloc] initWithImage:[UIImage imageNamed:NAME]] autorelease] - (UITableViewCell*) tableView:(UITableView*)table cellForRowAtIndexPath:(NSIndexPath*)index { UITableViewCell *cell = [table dequeueReusableCellWithIdentifier:@"Entry"]; if (cell == nil) { cell = [[[UITableViewCell alloc] initWithStyle:UITableViewCellStyleDefault reuseIdentifier:@"Entry"] autorelease]; cell.backgroundView = QAImage(@"bg-cell.png"); cell.selectedBackgroundView = QAImage(@"bg-cell-sel.png"); cell.selectionStyle = UITableViewCellSelectionStyleGray; UIImageView *img = QAImage(@"disclosure.png"); img.highlightedImage = [UIImage imageNamed:@"disclosure-sel.png"]; cell.accessoryView = img; CGRect r = cell.frame; r.size.height = table.rowHeight; r.size.width = table.frame.size.width; cell.frame = r; r = cell.contentView.frame; r.origin = CGPointMake(13, 13); r.size.width -= 8 + img.frame.size.width; r.size.height -= 25; [cell.contentView addSubview:[[[TagView alloc] initWithFrame:r] autorelease]]; img = QAImage(@"cell-top.png"); img.highlightedImage = [UIImage imageNamed:@"cell-top-sel.png"]; img.opaque = NO; r = img.frame; r.origin = CGPointMake(0, 1 - r.size.height);
The problem is that the border is displayed only when scrolling up in the table , otherwise it itself is overlapped by a cell above it. (Wrong.)
I tried [cell setNeedsDisplay] in -tableView:willDisplayCell:forRowAtIndexPath: adding a border ( cell-top.png ) every time a cell is requested (which obviously leads to several drawings and doesn't look good, regardless of whether I solve my problem) and set img.layer.zPosition = 2 .
How can I make UIImageView stay on top all the time?
source share