UITableViewCell高度自適應的關鍵點

iOS開發中對於UITableViewCell高度自適應的文章已經不少不少,但若是cell內容比較複雜,剛使用autolayout配置自使用時仍是總不能一次性成功。ios

KEY POINT

這裏只說設置的關鍵一點:markdown

Cell內部的Constraints必定要有一條從Cell頂部到底部的一條可聯通線。函數

圖例列表:佈局


Paste_Image.png

Paste_Image.png

Paste_Image.png

最後頂部元素居上和底部元素距底部,加上約束便可。
這條線上能夠有固定高度的元素,能夠有自適應高度的元素,但要保證:ui

設置自適應高度的元素都在這條線上。atom

固然若是在同一水平上有兩個須要自適應高度的元素,就有擇其一了。spa

OTHER POINTS

其餘注意要點:3d

  1. 確保在設置約束以前,UITableViewCellsize inspector裏面 Row HeightDefault而不是custom的數值,不然以後無論你如何操做,UITableViewCell優先使用的都是custom的數值。

    Paste_Image.png
  2. 注意語句.
    _tableView.estimatedRowHeight=44.0;
    若是沒有這一行,依然沒法自動佈局。
  3. 注意設置自適應高度Label lines0
    人老是容易忽略最簡單的問題。

Paste_Image.png

LAST

最後在代碼文件中,添加代碼:
iOS8
使用iOS8新出的方法:code

self.tableView.estimatedRowHeight=44; self.tableView.rowHeight=UITableViewAutomaticDimension;

iOS7
(就讓iOS7丟棄在歷史中吧。)
ios中沒有UITableViewAutomaticDimension自動計算高度,就只能本身去計算了。
ios7中須要一個輔助cell,cell的內容和UITableView的內容一致,但不用於顯示,而是用於根據填充的內容計算每一個cell的高度。router

@property (strong,nonatomic) AdaptionCell *adaptionCell;
//-(void)viewDidLoad 這裏爲何不能使用[tableView dequeueReusableCellWithIdentifier:cellIdentifier forIndexPath:indexPath]設置一個cell。由於這會致使cell被建立了可是又不曾被tableView:cellForRowAtIndexPath:方法返回,會形成內存泄露。
self.adaptionCell = [cellNib instantiateWithOwner:nil options:nil][0];
- (CGFloat)tableView:(UITableView *)tableView heightForRowAtIndexPath:(NSIndexPath *)indexPath{ self.adaptionCell.contentLabel.text=self.dataArray[indexPath.row%2]; [self.adaptionCell layoutIfNeeded]; CGFloat height = [self.adaptionCell.contentView systemLayoutSizeFittingSize:UILayoutFittingCompressedSize].height; return height+1; }

這裏爲何要+1,由於UITableViewCell有個邊緣線,比其ContentView高1(其實應該是0.5)

上面的方法裏使用的一個函數systemLayoutSizeFittingSize獲取contentView的size,最終獲得一個自適應後的height。

但這裏有個問題---爲何這個方法獲得了一個自適應的height,而不一個自適應的Width!
因此應該有個地方來限定Width,使得Cell的內容的填充是在縱向上,而不是橫向。

// AdaptionCell.m - (void)layoutSubviews{ [super layoutSubviews]; [self.contentView layoutIfNeeded]; self.contentLabel.preferredMaxLayoutWidth = CGRectGetWidth(self.contentLabel.frame); }

LAST LAST

最後的最後,附上結果圖:


Paste_Image.png

和一個問題:
若是cell中須要自適應高度的文本是富文本,是否還可使用autolayout作自適應?
簡單的UILabel attributedText能夠經過

做者:Seas 連接:http://www.jianshu.com/p/386b792054b1 來源:簡書 著做權歸做者全部。商業轉載請聯繫做者得到受權,非商業轉載請註明出處。
相關文章
相關標籤/搜索