1. 程式人生 > >自定義不等高cell的storyboard方法

自定義不等高cell的storyboard方法

對比自定義等高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; } }