iOS開發中對於UITableViewCell高度自適應的文章已經很多很多,但如果cell內容比較複雜,剛使用autolayout配置自使用時還是總不能一次性成功。 KEY POINT 這裡只說設置的關鍵一點: Cell內部的Constraints一定要有一條從Cell頂部到底部的一條可聯通線。 圖 ...
iOS開發中對於UITableViewCell高度自適應的文章已經很多很多,但如果cell內容比較複雜,剛使用autolayout配置自使用時還是總不能一次性成功。
KEY POINT
這裡只說設置的關鍵一點:
Cell
內部的Constraints
一定要有一條從Cell
頂部到底部的一條可聯通線。
圖例列表:
Paste_Image.png
Paste_Image.png
Paste_Image.png
最後頂部元素居上和底部元素距底部,加上約束即可。
這條線上可以有固定高度的元素,可以有自適應高度的元素,但要保證:
設置自適應高度的元素都在這條線上。
當然如果在同一水平上有兩個需要自適應高度的元素,就有擇其一了。
OTHER POINTS
其他註意要點:
- 確保在設置約束之前,
UITableViewCell
的size inspector
裡面Row Height
是Default
而不是custom
的數值,否則之後不管你如何操作,UITableViewCell
優先使用的都是custom
的數值。
Paste_Image.png - 註意語句.
如果沒有這一行,依然無法自動佈局。_tableView.estimatedRowHeight=44.0;
- 註意設置自適應高度
Label lines
為0
人總是容易忽略最簡單的問題。
Paste_Image.png
LAST
最後在代碼文件中,添加代碼:
iOS8
使用iOS8新出的方法:
self.tableView.estimatedRowHeight=44;
self.tableView.rowHeight=UITableViewAutomaticDimension;
iOS7
(就讓iOS7丟棄在歷史中吧。)
ios中沒有UITableViewAutomaticDimension自動計算高度,就只能自己去計算了。
ios7中需要一個輔助cell,cell的內容和UITableView的內容一致,但不用於顯示,而是用於根據填充的內容計算每個cell的高度。
@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
來源:簡書
著作權歸作者所有。商業轉載請聯繫作者獲得授權,非商業轉載請註明出處。