我对这个问题感到沮丧了几天。我正在尝试将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方法返回绘制单元格的框架的宽度,这对于普通样式表来说很好,因为单元格宽度是框架的整个宽度。但是,在分组表中,单元格的宽度小于绘制它的框架的宽度,因此此方法将返回一个比单元格宽度宽一些的数字。分组表格样式中单元格的宽度可能是小于表格框架宽度的固定数字,因此这可能是解决问题的方法。如果是这样的话,我会调查并回答我自己的问题。
答案 0 :(得分:8)
我已经确定了自己的答案,我希望它可以帮助任何人面对同样的问题。我在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, y, w, h);
label = [[UILabel alloc] initWithFrame:labelRect];
label.text = labelText;
label.tag = 0;
[cell.contentView addSubview:stepLabel];
[label release];
}
else {
label = (UILabel *)[cell viewWithTag:0];
}
答案 1 :(得分:1)
现在最好通过自动布局约束处理这个问题。