我有UITableView
个UILabel's
:标题,正文,作者和日期,他看起来像这样:
我想要完成的是,当用户点击单元格本身时,应该在单元格中添加另一个标签,“Body”标签和单元格应根据此标签大小进行扩展。
这样的事情:
我该怎么做?我搜索了stackoverflow,尝试了一些代码片段,但仍未找到正确的解决方案。
谢谢!
编辑1:14.11.12 14:52
我设法用当前文本更改UILabel的大小:
- (CGRect )resizeLabelByFontSize:(UILabel *)customCellLabel withMaxHeightSize:(CGFloat )maxHeight
{
CGSize maximumLabelSize = CGSizeMake(239, maxHeight);
CGSize expectedLabelSize = [customCellLabel.text sizeWithFont:customCellLabel.font constrainedToSize:maximumLabelSize lineBreakMode:customCellLabel.lineBreakMode];
//adjust the label the the new height.
CGRect newFrame = customCellLabel.frame;
newFrame.size.height = expectedLabelSize.height;
return newFrame;
}
但是如何根据新UILabel的大小更改单元格的大小?
答案 0 :(得分:1)
通过查看问题中的图像
这是为UILabel
创建动态框架的方法,看看这个
通过获取UIlabel
的高度和宽度,您可以计算整个高度,并可以设置行高UITableView.
- (void)setLabeltextWithVerticalAlignTop:(NSString *)theText
{
CGSize labelSize;
// here labelSize is hard-wired but could use constants to populate the size
labelSize = CGSizeMake(210, 129);//this is just for example
//now create the Size from textString SO that We could assign this size to the Label.
CGSize theStringSize = [theText sizeWithFont:lblTitle.font constrainedToSize:labelSize lineBreakMode:lblTitle.lineBreakMode];
lblTitle.frame = CGRectMake(lblTitle.frame.origin.x, lblTitle.frame.origin.y, theStringSize.width, theStringSize.height);
lblTitle.text = theText;
}
调用上方法要设置描述标签的高度和宽度,您需要传递要在该描述标签上显示的文本。 当你获得该标签的高度时,现在基于此你可以调整TableView的行的高度。
编辑:上面的代码只需为UILabel创建动态框架
You should take a view of this这就是你要找的...... !!!这里你会找到一个示例代码。
编辑:在您编辑问题时,请参阅此处所需的逻辑,将其转换为可运行的代码。
在代码中使用以下方法调用每一行,并在其中进行一些计算。
- (CGFloat)tableView:(UITableView *)tableView heightForRowAtIndexPath:(NSIndexPath *)indexPath
{
CGFloat rowHeight=0.0;
//here it seems cell have 4 subview added on it.
//so if you could calculate the totla hieht of them.
//so what you really need to do.you just use hieght calculative Method for getting hieght of each of three UILabel
//you need to modify `setLabeltextWithVerticalAlignTop` method .
rowHeight= [self setLabeltextWithVerticalAlignTop:@"pass the correspondingText"];// suppose it returns some hieght for FisrtLabel.
//suppoose here you get the 20.0 height here
rowHeight= rowHeight+[self setLabeltextWithVerticalAlignTop:@"pass the correspondingText"];
//假设它为secondUIlabel返回了一些高度。
//suppoose here you get the 40.0 height here
rowHeight= rowHeight+ [self setLabeltextWithVerticalAlignTop:@"pass the correspondingText"];
// suppose it returns some hieght for ThirdUIlabel.
// suppoose here you get the 15.0 height here
//here you have totla height you just need to add some gapping floating value for all of three UIlabel.so that the could not overlap like as.
rowHeight= rowHeight+20.0;
//now you can return that total height
return rowHeight;
}
注意:这只是将其转换为可运行代码所需的逻辑。我相信这可以提供帮助。
我希望它可以帮助你。
答案 1 :(得分:0)
实施以下方法
– (void) tableView:(UITableView*)tableView didSelectRowAtIndexPath:(NSIndexPath*)indexPath
{
UITableViewCell *cell = [tableView cellForRowAtIndexPath:indexPath];
// cast cell, add label, expand labels etc
[tableView reloadRowsAtIndexPaths:@[indexPath] withRowAnimation:UITableViewRowAnimationAutomatic];
}
- (CGFloat)tableView:(UITableView *)tableView heightForRowAtIndexPath:(NSIndexPath *)indexPath
{
return [indexPath isEqualTo:[tableView indexPathForSelectedRow]] ? /* expanded height */ : 80 /* normal height */;
}
如果您希望即使在选择了另一行后该行仍保持选中状态,则将自定义BOOL属性添加到您的自定义单元格,例如expanded
,并使用它来确定身高。
答案 2 :(得分:0)
您可以使用tableView:didSelectRowAtIndexPath
在该方法中,您可以创建代码以取消隐藏身体标签,调整其他所有内容的相对位置。计算行的新高度,然后调用表视图的reloadRowsAtIndexPath:withRowAnimation:方法。
很抱歉,如果没有太多细节,但希望这会让你走上正轨。
答案 3 :(得分:0)
好的,首先......要扩展你需要这样的东西:
- (CGFloat)tableView:(UITableView *)tableView heightForRowAtIndexPath:(NSIndexPath *)indexPath;
现在是抓住了:
我的建议:
UITableView
之前计算双方,因为您希望拥有动态大小。如果不这样做,所有单元格都会扩展相同的大小,你可以使用lammmert所说的。答案 4 :(得分:0)
NSIndexPath *selectedRow;
- (void)tableView:(UITableView *)tableView didSelectRowAtIndexPath:(NSIndexPath *)indexPath{
selectedRow = indexPath;
}
- (CGFloat)tableView:(UITableView *)tableView heightForRowAtIndexPath:(NSIndexPath *)indexPath{
if(indexPath == selectedRow){
//return your custom value
}
return 100;
}
我认为它看起来像那样
答案 5 :(得分:0)
所以,为了做到这一点,使用花费的UITableViewCell,我创建了2个不同的自定义单元格,在开始时表格显示第一个单元格,当我点击单元格时,表格显示第二个单元格。这很容易 - 是的!
所以我有UIViewController和UITableView来实现表委托方法:
- (CGFloat)tableView:(UITableView *)tableView heightForRowAtIndexPath:(NSIndexPath *)indexPath
{
if([self.selectedCellIndexPath isEqual:indexPath])
{
return [self expandedCellHeight:indexPath];
}
else
{
return kRegularCellHeight;
}
}
-(CGFloat)expandedCellHeight:(NSIndexPath *)indexPath
{
CGSize maxSize = CGSizeMake(303, 200);
NSString* bodyText = [[self.data objectAtIndex:indexPath.row] objectForKey:kForumMessagesBody];
CGSize fitSize = [bodyText sizeWithFont:[UIFont systemFontOfSize:13] constrainedToSize:maxSize lineBreakMode:UILineBreakModeWordWrap];
CGFloat height = 384 - 69 + fitSize.height;
NSLog(@"expandedHeight: %f",height);
return height;
}
- (UITableViewCell *)tableView:(UITableView *)tableView cellForRowAtIndexPath:(NSIndexPath *)indexPath
{
// Answer cell
if ([self.selectedCellIndexPath isEqual:indexPath])
{
cell = [tableView dequeueReusableCellWithIdentifier:[ForumCell expandedAnswerReuseIdentifier]];
if (cell == nil)
{
cell = [ForumCell expandedAnswerCell];
}
self.expandedCell = cell;
}
else
{
cell = [tableView dequeueReusableCellWithIdentifier:[ForumCell reqularAnswerReuseIdentifier]];
if (cell == nil)
{
cell = [ForumCell regularAnswerCell];
}
}
cell.labelMedia.text = [self.data objectAtIndex:indexPath.row];
return cell;
}
我还有自定义单元格,名为ForumCell.h
和ForumCell.m
的类,它有2个不同的XIB文件:ForumRegularAnswerCell.xib
和ForumExpandedAnswerCell.xib
,我在ForumCell.h
内有以下代码{1}}:
+ (NSString*)reqularAnswerReuseIdentifier
{
return @"RegularAnswerCellReuseIdentifier";
}
+ (NSString*)expandedAnswerReuseIdentifier
{
return @"ExpandedAnswerCellReuseIdentifier";
}
+ (ForumCell*)regularAnswerCell
{
NSArray* objs = [[NSBundle mainBundle] loadNibNamed:@"ForumRegularAnswerCell" owner:self options:nil];
ForumCell* result = [objs objectAtIndex:0];
return result;
}
+ (ForumCell*)expandedAnswerCell
{
NSArray* objs = [[NSBundle mainBundle] loadNibNamed:@"ForumExpandedAnswerCell" owner:self options:nil];
ForumCell* result = [objs objectAtIndex:0];
return result;
}
- (id)initWithCoder:(NSCoder *)decoder
{
self = [super initWithCoder:decoder];
if (self)
{
_originalCellHeight = self.frame.size.height;
_originalLblBodyHeight = self.lblBody.frame.size.height;
}
return self;
}
如果您愿意,也可以使用2个以上的xib。但这是基础。
享受!