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,如需转载请自行联系原作者

相关文章
|
4月前
|
编解码
element-ui 表格滚动条(不同分辨率)自适应问题;
element-ui 表格滚动条(不同分辨率)自适应问题;
177 1
|
4月前
表格高度根据内容自适应的瀑布流
表格高度根据内容自适应的瀑布流
43 1
|
4月前
使用SDAutoLayout实现控件根据内容进行宽度自适应和高度自适应
使用SDAutoLayout实现控件根据内容进行宽度自适应和高度自适应
70 2
|
4月前
表格宽度和高度
表格宽度和高度。
33 1
|
4月前
|
前端开发 容器
css 中可以让文字在垂直和水平方向上重叠的两个属性是什么?
css 中可以让文字在垂直和水平方向上重叠的两个属性是什么?
46 1
|
4月前
|
前端开发 容器
如何实现一个两栏布局,右侧自适应?三栏布局中间自适应?
要实现一个两栏布局,右侧自适应的效果,可以使用 CSS 的 Flexbox 或 Grid 布局来实现。以下是使用 Flexbox 实现的示例:
62 1
|
前端开发 容器
如何使用 CSS 来控制 img 标签在父元素中自适应宽度或高度,并按比例显示
如何使用 CSS 来控制 img 标签在父元素中自适应宽度或高度,并按比例显示
615 1
|
数据可视化
获取页面的可视化高度和宽度
获取页面的可视化高度和宽度
42 0
|
JavaScript 前端开发 定位技术
百度地图元素宽度自适应的方法
百度地图元素宽度自适应的方法
360 0
|
移动开发 UED HTML5
CSS3——伸缩布局,文字阴影,背景渐变缩放多背景,优雅降级和渐进增强
CSS3——伸缩布局,文字阴影,背景渐变缩放多背景,优雅降级和渐进增强
131 0
CSS3——伸缩布局,文字阴影,背景渐变缩放多背景,优雅降级和渐进增强