@implemation BaseCell
+ (CGFloat)calcCellHeight:(id)data {
? ? if(__cell==nil) {
? ? ? ? __cell = [[[NSBundle mainBundle] loadNibNamed:@"XXX" owner:nil options:nil] firstObject];
? ? }
? ? [__cell parseData:data];
? ? [__cell layoutIfNeeded];
? ? [__cell updateConstraintsIfNeeded];
? ? CGFloat height = [__cell.contentView systemLayoutSizeFittingSize:UILayoutFittingCompressedSize].height + 1;
? ? returnheight;
}
@end
以下內(nèi)容為轉(zhuǎn)載自作者Seas
UITableViewCell高度自適應(yīng)的關(guān)鍵點(diǎn)
iOS開發(fā)中對(duì)于UITableViewCell高度自適應(yīng)的文章已經(jīng)很多很多,但如果cell內(nèi)容比較復(fù)雜,剛使用autolayout配置自使用時(shí)還是總不能一次性成功。
KEY POINT
這里只說設(shè)置的關(guān)鍵一點(diǎn):
Cell內(nèi)部的Constraints一定要有一條從Cell頂部到底部的一條可聯(lián)通線。
圖例列表:

Paste_Image.png

Paste_Image.png

Paste_Image.png
最后頂部元素居上和底部元素距底部,加上約束即可。
這條線上可以有固定高度的元素,可以有自適應(yīng)高度的元素,但要保證:
設(shè)置自適應(yīng)高度的元素都在這條線上。
當(dāng)然如果在同一水平上有兩個(gè)需要自適應(yīng)高度的元素,就有擇其一了。
OTHER POINTS
其他注意要點(diǎn):
確保在設(shè)置約束之前,UITableViewCell的size inspector里面?Row Height是Default而不是custom的數(shù)值,否則之后不管你如何操作,UITableViewCell優(yōu)先使用的都是custom的數(shù)值。

Paste_Image.png
注意語句.
_tableView.estimatedRowHeight=44.0;
如果沒有這一行,依然無法自動(dòng)布局。
注意設(shè)置自適應(yīng)高度Label lines?為0
人總是容易忽略最簡(jiǎn)單的問題。

Paste_Image.png
LAST
最后在代碼文件中,添加代碼:
iOS8
使用iOS8新出的方法:
self.tableView.estimatedRowHeight=44;self.tableView.rowHeight=UITableViewAutomaticDimension;
iOS7
(就讓iOS7丟棄在歷史中吧。)
ios中沒有UITableViewAutomaticDimension自動(dòng)計(jì)算高度,就只能自己去計(jì)算了。
ios7中需要一個(gè)輔助cell,cell的內(nèi)容和UITableView的內(nèi)容一致,但不用于顯示,而是用于根據(jù)填充的內(nèi)容計(jì)算每個(gè)cell的高度。
@property (strong,nonatomic) AdaptionCell *adaptionCell;
//-(void)viewDidLoad 這里為什么不能使用[tableView dequeueReusableCellWithIdentifier:cellIdentifier forIndexPath:indexPath]設(shè)置一個(gè)cell。因?yàn)檫@會(huì)導(dǎo)致cell被創(chuàng)建了但是又未曾被tableView:cellForRowAtIndexPath:方法返回,會(huì)造成內(nèi)存泄露。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,因?yàn)閁ITableViewCell有個(gè)邊緣線,比其ContentView高1(其實(shí)應(yīng)該是0.5)
上面的方法里使用的一個(gè)函數(shù)systemLayoutSizeFittingSize獲取contentView的size,最終得到一個(gè)自適應(yīng)后的height。
但這里有個(gè)問題---為什么這個(gè)方法得到了一個(gè)自適應(yīng)的height,而不一個(gè)自適應(yīng)的Width!
所以應(yīng)該有個(gè)地方來限定Width,使得Cell的內(nèi)容的填充是在縱向上,而不是橫向。
//? AdaptionCell.m- (void)layoutSubviews{? ? [super layoutSubviews];? ? [self.contentView layoutIfNeeded];self.contentLabel.preferredMaxLayoutWidth =CGRectGetWidth(self.contentLabel.frame);
}
LAST LAST
最后的最后,附上結(jié)果圖:

Paste_Image.png
和一個(gè)問題:
如果cell中需要自適應(yīng)高度的文本是富文本,是否還可以使用autolayout做自適應(yīng)?
簡(jiǎn)單的UILabel?attributedText可以通過

作者:Seas
鏈接:http://www.itdecent.cn/p/386b792054b1