cell自適應(yīng)

@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

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時(shí)請(qǐng)結(jié)合常識(shí)與多方信息審慎甄別。
平臺(tái)聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡(jiǎn)書系信息發(fā)布平臺(tái),僅提供信息存儲(chǔ)服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

友情鏈接更多精彩內(nèi)容