iOS tableView cell高度自适应 两种方法

最近在开发遇到cell高度不确定的情况,主要原因是cell里面的label的高度是不确定。从而导致cell高度不确定。


iOS tableView cell高度自适应 两种方法_第1张图片
案例图片

我找到了两种解决方案。第一种 利用iOS8的新特性,自动计算cell的高度。第二种 自己计算每个cell的高度。

下面我们来一个一个演示:

第一种方法:利用iOS7 的新特性

首先我们先创建一个tableView:

iOS tableView cell高度自适应 两种方法_第2张图片
viewDidload创建tableView

大家注意 :tableView.estimatedRowHeight=44.0;

tableView.rowHeight=UITableViewAutomaticDimension;//高度设置为自适应

这两行代码就是把tableView 的高度设置为自适应的了

iOS tableView cell高度自适应 两种方法_第3张图片
tableView的代理及数据源方法

注意:如果tableView rowHight设置为自适应,那么就需要在代理里面设置cell的高度了,换而言之,就是不用再调用-(CGFloat)tableView:(UITableView *)tableView heightForRowAtIndexPath:(NSIndexPath *)indexPath 这个方法。

接下来的问题来了,它是怎么计算cell的高度呢,它是根据布局来计算的。

iOS tableView cell高度自适应 两种方法_第4张图片

我们把高度不确定的label的高度 设置为大于等于当前高度,并且把label的行数设置为0


iOS tableView cell高度自适应 两种方法_第5张图片
高度设置为大于等于
行数设置为0

这样,label的行数就是无限行,label的高度就可以随着行数的变化而变化。

还有一点需要注意的,系统计算cell的高度,必须要知道,当前cell 内控件的高度及cell控件之间竖直之间的距离,所以,在布局的时候下图的约束必须要加的。不然高度计算会不对。

iOS tableView cell高度自适应 两种方法_第6张图片
iOS tableView cell高度自适应 两种方法_第7张图片

这是第一种方法。

第二种方法,我当初的想法是,在-(CGFloat)tableView:(UITableView *)tableView heightForRowAtIndexPath:(NSIndexPath *)indexPath 的方法里直接遍历cell里面的控件,拿到cell控件的高度,计算cell的高度。

 然而这种方法是不可行的。理由如下:heightForRowAtIndexPath这个代理方法,在(UITableViewCell*)tableView:(UITableView*)tableView cellForRowAtIndexPath:(NSIndexPath*)indexPath 这个代理方法前调用,所以压根取不到当前的cell,cell压根没有创建,会导致崩溃。

于是我就换了一种方法,把计算高度的方法写在model里面。

iOS tableView cell高度自适应 两种方法_第8张图片

每个model对应一个cell ,每个model里面都包含cell控件的值,我在model里面添加计算高度的方法。

iOS tableView cell高度自适应 两种方法_第9张图片

我们怎么确定cell的高度,我们来分析一下,cell的高度 = titleLabel的上边距 + titleLabel的高度 +titleLabel的下边距 + descLabel的高度 + descLabel的下边距。

iOS tableView cell高度自适应 两种方法_第10张图片

现在唯一不确定的是descLabel的高度,因为他的高度是可变的,所以我们只要计算他的高度,在加上其他已经确定的值就好了。

那么 怎么计算descLabel的高度呢。 根据 boundingRectWithSize这个方法,根据lable的字体大小,计算出label的高度。

接下来,在-(CGFloat)tableView:(UITableView*)tableView heightForRowAtIndexPath:(NSIndexPath*)indexPath 方法里 取出每个cell的高度。

iOS tableView cell高度自适应 两种方法_第11张图片

第二种方法完成了。

你可能感兴趣的:(iOS tableView cell高度自适应 两种方法)