自定義不等高cell的storyboard方法
阿新 • • 發佈:2019-02-06
對比自定義等高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;
}
}