我已经对这个问题感到沮丧了几天.我正在尝试将UILabel添加到UITableViewCell.我希望UILabel跨越单元格的整个宽度,在右侧和左侧减去5或10,以获得外观.我的问题在于以编程方式确定放置标签的单元格框架的大小.无论我使用哪种UITableViewStyle,cell.contentVew.frame.size.width值都不会接近单元框架本身的宽度.
例如,在我构建的表中,我可以通过继承UITableViewCell并使用手动确定的宽度(通过试验和错误)创建一个UILabel来实现我想要的结果:
CGRectMake(10,12,397,self.contentView.frame.size.height);
但这就是令人烦恼的397号码.我想要一种方法来以编程方式确定任何宽度表或样式应该是什么.这应该是一个简单的过程,只需确定单元格整个框架的宽度,然后减去10或20,这样UILabel的边缘就不会实际接触到单元格的边缘.
但是,如果我将tableViewStyle设置为UITableViewStyleDefault,然后尝试:
NSLog(@"Width: %f",self.contentView.frame.size.width);
我得到320.如果我将样式设置为其他三种样式中的任何一种,则返回的数字为302.即使320数字也不是靠近单元格框架宽度的任何位置(与我手动确定的397的数字一样).
我需要访问哪个值才能返回单元格绘图框的整个宽度?我敢肯定,就像最棘手的问题一样,解决方案会让我想要在额头上打自己,但我现在已经准备好了.
编辑更多信息:
任何有兴趣的人都要澄清一下.我的这个问题主要涉及分组样式表.对于简单的样式,上面我的问题的答案可以通过cellForRowAtIndexPath方法简单地确定:
CGFloat cellWidth = [tableView rectForRowAtIndexPath:indexPath].size.width;
我遇到的问题是rectForRowAtIndexPath方法返回绘制单元格的框架的宽度,这对于普通样式表来说很好,因为单元格宽度是框架的整个宽度.但是,在分组表中,单元格的宽度小于绘制它的框架的宽度,因此此方法将返回一个比单元格宽度宽得多的数字.分组表格样式中单元格的宽度可能是小于表格框架宽度的固定数字,因此这可能是解决问题的方法.如果是这样的话,我会调查并回答我自己的问题.
解决方法
我已经确定了自己的答案,我希望它可以帮助任何人面对同样的问题.我在
this StackOverflow answer.找到的分组tableView的边距的计算
此代码将在tableView单元格中提供一个标签,该标签横跨单元格,在单元格的两个边缘之间有一个边距,并在单元格内垂直居中.
- (UITableViewCell *)tableView:(UITableView *)tableView cellForRowAtIndexPath:(NSIndexPath *)indexPath { static NSString *CellIdentifier = @"Cell"; UITableViewCell *cell = [tableView dequeueReusableCellWithIdentifier:CellIdentifier]; UILabel *label; CGFloat groupedStyleMarginWidth,tableViewWidth; UIFont *labelFont = [UIFont boldSystemFontOfSize:17.0]; // Set to whatever you like NSString *labelText = @"Test String"; // Calculate the margin between the cell frame and the tableView // frame in a grouped table view style. tableViewWidth = tableView.frame.size.width; if (tableView.style == UITableViewStyleGrouped) { if (tableViewWidth > 20) groupedStyleMarginWidth = (tableViewWidth < 400) ? 10 : MAX(31,MIN(45,tableViewWidth*0.06)); else groupedStyleMarginWidth = tableViewWidth - 10; } else groupedStyleMarginWidth = 0.0; if (cell == nil) { CGRect tableViewRect; CGRect labelRect; CGFloat x,y,w,h,labelMargin; cell = [[[UITableViewCell alloc] initWithStyle:UITableViewCellStyleDefault reuseIdentifier:CellIdentifier] autorelease]; // Retrieve the rect of the table view. tableViewRect = [tableView rectForRowAtIndexPath:indexPath]; // Set whatever margin around the label you prefer. labelMargin = 10; // Determine rect values for the label. x = tableRect.origin.x + labelMargin; // Calculate width of label w = tableRect.size.width - (groupedStyleMargin * 2) - (labelMargin * 2); // Calculate height of table based on font set earlier. h = [labelText sizeWithFont:font].height; // Calculate y position for the label text baseline to center // vertically within the cell. y = (tableRect.origin.y / 2) - (h / 4); labelRect = CGRectMake(x,h); label = [[UILabel alloc] initWithFrame:labelRect]; label.text = labelText; label.tag = 0; [cell.contentView addSubview:stepLabel]; [label release]; } else { label = (UILabel *)[cell viewWithTag:0]; }