iOS开发中对于UITableViewCell高度自适应的文章已经很多很多,但如果cell内容比较复杂,刚使用autolayout配置自使用时还是总不能一次性成功。

KEY POINT

这里只说设置的关键一点:

Cell内部的Constraints一定要有一条从Cell顶部到底部的一条可联通线。

图例列表:

Paste_Image.png

Paste_Image.png

Paste_Image.png

最后顶部元素居上和底部元素距底部,加上约束即可。
这条线上可以有固定高度的元素,可以有自适应高度的元素,但要保证:

设置自适应高度的元素都在这条线上。

当然如果在同一水平上有两个需要自适应高度的元素,就有择其一了。

OTHER POINTS

其他注意要点:

  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新出的方法:

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
來源:简书
著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。

UITableViewCell高度自适应的关键点的更多相关文章

  1. uitableviewcell高度自适应笔记

    今天看了几篇uitableviewcell高度自适应的文章,大体分为两种方式. 第一种方式,cell里面有label,在cellforrow绘制的时候计算Label的可能高度,并且在此时重新计算cel ...

  2. UITableViewCell高度自适应探索--AutoLayout结合Frame

    UITableViewCell高度自适应探索--UITableView+FDTemplateLayoutCell地址: http://www.jianshu.com/p/7839e3a273a6UIT ...

  3. UITableViewCell 高度自适应

    UITableViewCell 高度自适应一直是我们做动态Cell高度时遇到的最烦躁的问题,Cell动态高度计算可以去看看sunny的这篇文章介绍,今天主要和大家分享下我在使用systemLayout ...

  4. 原生的UITableViewCell高度自适应,textLabel自动换行显示

    /* * 设置子项cell **/ - (UITableViewCell *)getChildCell:(UITableView *)tableView and:(NSIndexPath *)inde ...

  5. 第二篇、为UITableViewCell 高度自适应加速 缓存cell的高度

    通过NSCache缓存已经算好的行高 @interface ZHCellHeightCalculator : NSObject //系统计算高度后缓存进cache -(void)setHeight:( ...

  6. UITableViewCell 高度计算从混沌初始到天地交泰

    [原创]UITableViewCell 高度计算从混沌初始到天地交泰 本文主要基予iOS UITableViewCell 高度自适应计算问题展开陈述,废话少说直入正题: UITableView控件可能 ...

  7. autolayout 高度自适应

    https://lvwenhan.com/ios/449.html #import "ViewController.h" #import "MyTableViewCell ...

  8. 关于TableViewCell高度自适应问题的整理

    TableViewCell高度自适应在网上有很多资料,我只想找出最最最简单的一种方法. 首先梳理一下思路.说到TableViewCell我们第一个想到的问题或许就是cell的复用问题. 1.  [se ...

  9. SnapKit swift实现高度自适应的新浪微博布局

    SnapKit swift版的自动布局框架,第一次使用感觉还不错. SnapKit是一个优秀的第三方自适应布局库,它可以让iOS.OS X应用更简单地实现自动布局(Auto Layout).GtiHu ...

随机推荐

  1. mongoDB 高级查询语法

    http://www.cnblogs.com/ITAres/articles/2084794.html本文参考自官方的手册:http://www.mongodb.org/display/DOCS/Ad ...

  2. 创建标题栏,UINavigationBar的使用

    IOS 开发有关界面的东西不仅可以使用代码来编写,也可以使用Interface Builder可视化工具来编写.今天有个朋友问我这两个有什么区别,首先说说IB ,使用它编辑出来的控件其实底层还是调用代 ...

  3. 【已解决】WebUploader 0.1.5 安卓手机不能访问相机、IOS直接访问相机 的问题

    WebUploader 0.1.5 安卓手机不能访问相机.IOS直接访问相机 的问题 打开 webuploader.js if(navigator.userAgent.indexOf('Android ...

  4. Android中多线程编程(三)Handler更新UI的方式

    Handler更新UI的方式和原因以及遇到的问题 1.方式: 仅仅能通过Handler来更新UI. 代码例如以下: package com.chengdong.su.handlerdemo; impo ...

  5. ppm\pgm格式

    PGM 是便携式灰度图像格式(portable graymap file format),在黑白超声图像系统中经常使用PGM格式的图像.文件的后缀名为".pgm". PGM格式图像 ...

  6. freemarker 开始时间与当前时间进行比较

    <#if startTime?datetime lt .now?datetime>:年月日时分秒比较 <#if startTime?date lt .now?date>:年月日 ...

  7. iOS SDWebImage加载大图导致内存崩溃解决方案

    static BOOL SDImageCacheOldShouldDecompressImages = YES; static BOOL SDImagedownloderOldShouldDecomp ...

  8. VMware Mac OS补丁安装

    安装了VMware9.0在新建虚拟系统的时候,没有Appel MAC OS系统的选项,上网查了一下是需要打一个VMware Mac OS补丁就可以了.下面我来演示一下VMware Mac OS补丁怎么 ...

  9. win10正式版开始菜单无法打开,右边的网络连接、操作中心也打不开

    问题描述: 开机后电脑键盘的win键无响应,鼠标点击菜单栏中的这几个按键也都无响应,但是点击自己固定的应用程序却没有问题,在网上查找尝试了许多资料,终于找到了一个合适的解决方案.现记录如下 解决方案: ...

  10. RecyclerView 必知必会(转)

    [腾讯Bugly干货分享]RecyclerView 必知必会 本文来自于腾讯Bugly公众号(weixinBugly),未经作者同意,请勿转载,原文地址:http://mp.weixin.qq.com ...