美文网首页SB CelliOS移动开发
[自定义不等高的cell]-storyboard方式

[自定义不等高的cell]-storyboard方式

作者: Z了个L | 来源:发表于2016-02-16 23:21 被阅读158次

    对比自定义等高cell,需要几个额外的步骤(iOS8开始才支持)

    • 添加子控件和contentView之间的间距约束
    • 设置tableViewCell的真实行高和估算行高
    // 告诉tableView所有cell的真实高度是自动计算(根据设置的约束来计算)
    self.tableView.rowHeight = UITableViewAutomaticDimension;
    // 告诉tableView所有cell的估算高度
    self.tableView.estimatedRowHeight = 44;
    

    如果要支持iOS8之前

    • 如果cell内部有自动换行的label,需要设置preferredMaxLayoutWidth属性
    - (void)awakeFromNib
    {
        // 手动设置文字的最大宽度(目的是:让label知道自己文字的最大宽度,进而能够计算出自己的frame)
        self.text_label.preferredMaxLayoutWidth = [UIScreen mainScreen].bounds.size.width - 20;
    }
    
    • 设置tableView的cell估算高度
    // 告诉tableView所有cell的估算高度(设置了估算高度,就可以减少tableView:heightForRowAtIndexPath:方法的调用次数)
    self.tableView.estimatedRowHeight = 200;
    
    • 在代理方法中计算cell的高度
    XMGStatusCell *cell;
    - (CGFloat)tableView:(UITableView *)tableView heightForRowAtIndexPath:(NSIndexPath *)indexPath
    {
        // 创建一个临时的cell(cell的作用:根据模型数据布局所有的子控件,进而计算出cell的高度)
        if (!cell) {
            cell = [tableView dequeueReusableCellWithIdentifier:ID];
        }
    
        // 设置模型数据
        cell.status = self.statuses[indexPath.row];
    
        return cell.height;
    }
    
    - (CGFloat)height
    {
        // 强制布局cell内部的所有子控件(label根据文字多少计算出自己最真实的尺寸)
        [self layoutIfNeeded];
    
        // 计算cell的高度
        if (self.status.picture) {
            return CGRectGetMaxY(self.pictureImageView.frame) + 10;
        } else {
            return CGRectGetMaxY(self.text_label.frame) + 10;
        }
    }
    

    相关文章

      网友评论

        本文标题:[自定义不等高的cell]-storyboard方式

        本文链接:https://www.haomeiwen.com/subject/bptmkttx.html