TableCell自适应表格高度

简介:

from:http://blog.csdn.net/xcysuccess3/article/details/7776796

复制代码
- (CGFloat)tableView:(UITableView *)tableView heightForRowAtIndexPath:(NSIndexPath *)indexPath {  
    // 列寬  
    CGFloat contentWidth = self.tableView.frame.size.width;  
    // 用何種字體進行顯示  
    UIFont *font = [UIFont systemFontOfSize:13];  
      
    // 該行要顯示的內容  
    NSString *content = [data objectAtIndex:indexPath.row];  
    // 計算出顯示完內容需要的最小尺寸  
    CGSize size = [content sizeWithFont:font constrainedToSize:CGSizeMake(contentWidth, 1000) lineBreakMode:UILineBreakModeWordWrap];  
      
    // 這裏返回需要的高度  
    return size.height;   
}  
  
// Customize the appearance of table view cells.  
- (UITableViewCell *)tableView:(UITableView *)tableView cellForRowAtIndexPath:(NSIndexPath *)indexPath {  
      
    static NSString *CellIdentifier = @"Cell";  
    // 列寬  
    CGFloat contentWidth = self.tableView.frame.size.width;  
    // 用何種字體進行顯示  
    UIFont *font = [UIFont systemFontOfSize:13];  
      
    // 該行要顯示的內容  
    NSString *content = [data objectAtIndex:indexPath.row];  
    // 計算出顯示完內容需要的最小尺寸  
    CGSize size = [content sizeWithFont:font constrainedToSize:CGSizeMake(contentWidth, 1000) lineBreakMode:UILineBreakModeWordWrap];  
      
    // 構建顯示行  
    UITableViewCell *cell = [tableView dequeueReusableCellWithIdentifier:CellIdentifier];  
    if (cell == nil) {  
        cell = [[[UITableViewCell alloc] initWithStyle:UITableViewCellStyleDefault reuseIdentifier:CellIdentifier] autorelease];  
    }  
      
    CGRect rect = [cell.textLabel textRectForBounds:cell.textLabel.frame limitedToNumberOfLines:0];  
    // 設置顯示榘形大小  
    rect.size = size;  
    // 重置列文本區域  
    cell.textLabel.frame = rect;  
      
    cell.textLabel.text = content;  
      
    // 設置自動換行(重要)  
    cell.textLabel.numberOfLines = 0;  
    // 設置顯示字體(一定要和之前計算時使用字體一至)  
    cell.textLabel.font = font;  
  
    return cell;  
}  
复制代码

 本文转自老Zhan博客园博客,原文链接:http://www.cnblogs.com/mybkn/articles/2831190.html,如需转载请自行联系原作者

相关文章
|
7月前
|
编解码
element-ui 表格滚动条(不同分辨率)自适应问题;
element-ui 表格滚动条(不同分辨率)自适应问题;
314 1
|
1月前
|
弹性计算
|
7月前
表格高度根据内容自适应的瀑布流
表格高度根据内容自适应的瀑布流
67 1
|
7月前
使用SDAutoLayout实现控件根据内容进行宽度自适应和高度自适应
使用SDAutoLayout实现控件根据内容进行宽度自适应和高度自适应
126 2
|
7月前
表格宽度和高度
表格宽度和高度。
47 1
|
7月前
|
前端开发 容器
如何实现一个两栏布局,右侧自适应?三栏布局中间自适应?
要实现一个两栏布局,右侧自适应的效果,可以使用 CSS 的 Flexbox 或 Grid 布局来实现。以下是使用 Flexbox 实现的示例:
82 1
|
前端开发 容器
如何使用 CSS 来控制 img 标签在父元素中自适应宽度或高度,并按比例显示
如何使用 CSS 来控制 img 标签在父元素中自适应宽度或高度,并按比例显示
797 1
|
数据可视化
获取页面的可视化高度和宽度
获取页面的可视化高度和宽度
54 0
|
前端开发 容器
【HTML+CSS】grid自适应网站布局之服务项目展示
【HTML+CSS】grid自适应网站布局之服务项目展示
142 0
文字处理技术:表格与形状的布局差异
文字处理技术:表格与形状的布局差异
123 0