iOS UITableView+FDTemplateLayoutCell 配合AutoLayout分分钟教你实现类似微信朋友圈的动态高度自适应

11.30日更新,实现了简单的微信朋友圈,点赞,评论,图片,高度自适应,下拉展开等各种效果Demo

点击打开链接

11.10更新

这种高度自适应的Label切记一定要加上这个属性

preferredMaxLayoutWidth

不然你会死的很难看

11.4日更新  用这个库实现了类似微信朋友圈的简单排版点击打开链接

这里我没这么考虑性能,只是简单先做了这个功能,tableViewcell里面嵌套了collectionView来进行图片的布局,效果如下,咱们先不考虑性能,这种情况下切记不能调用带有缓存的方法cacheByIndex的方法,由于内部是动态的,一定要用(只能牺牲性能了)

[objc]view plaincopy

return[tableViewfd_heightForCellWithIdentifier:identifyconfiguration:^(ConsultDetailTableViewCell*cell) {

[selfconfigCell:cellindexpath:indexPath];

}];

UITableView里面的Cell固定高度那是基本不可能了,很多功能和界面都会涉及到高度自适应,而且电商类的尤其普遍,之前都是自己算啊算,代码写的非常多,逻辑还没写,光这布局UI和高度计算都能接近1000了,写完之后关键出点Bug整个人都不好了

当时的是这样的:

突然在github上看到UITableView+FDTemplateLayoutCell这个库

传送门:点击打开链接

刚看到的时候是这样的:

能  用   么 ??? 真  的  这  么 叼 ???

第一次用的时候是这样的:

哥们,你是在逗我么,这什么鬼,从来没见过这样的场面,当时我就懵逼了。。。。。。

用了几次之后就出效果了,是这样的:

哎呦,不错呦。。。。。。感觉真的有点叼啊

OK 看下基本流程

由于咱们还是用IB来布局,操作NSConstraintLayout类来进行计算,所以先把官网上给出的布局案例贴出来,如下

注:

a fullyself-satisfiedcell is constrainted by auto layout and each edge("top", "left", "bottom", "right") has at least one layout constraint against it

一个自适应高度的cell用Autolayout来进行约束,内部所有控件的约束整合起来,距离Cell四个边的(top left bottom right)至少要各出现一次,不然就是bad one

如下图所示:

箭头所指的方向必须出现至少一次才是一套完整的约束

1.首先新建个工程,造一个TableView出来,设置好代理,布局好基本框架

2.然后弄一个Cell,布局玩之后把关键箭头所指的两个约束拖出来,以后要用,先看下主要布局,Demo最后给

3.我自己找了几个数据源出来,我个人遇到的是,如果每个cell有图片,或者没图片,而且图片的高度不等,那么服务器也要求返回具体的图片宽和高,利于我们直接拿来进行等比例计算,然后在下面这个代理方法布局的时候进行操作

[objc]view plaincopy

-(UITableViewCell*)tableView:(UITableView*)tableViewcellForRowAtIndexPath:(NSIndexPath*)indexPath

{

MKJTableViewCell*cell = [tableViewdequeueReusableCellWithIdentifier:identifyforIndexPath:indexPath];

[selfconfigCell:cellindexpath:indexPath];//!< 该方法等下也会用到

returncell;

}

[objc]view plaincopy

最关键的方法

[objc]view plaincopy

- (void)configCell:(MKJTableViewCell*)cellindexpath:(NSIndexPath*)index

{

// 获取模型

MKJModel*model =self.dataSource[index.row];

__weak typeof(cell) weakCell = cell;

// 配置用户头像的的图片,以下操作是让图片0-1的渐现的动画

[cell.headImageViewsd_setImageWithURL:[NSURLURLWithString:model.headImageURL]completed:^(UIImage*image,NSError*error, SDImageCacheType cacheType,NSURL*imageURL) {

if(image && cacheType == SDImageCacheTypeNone) {

weakCell.headImageView.alpha=0;

[UIViewanimateWithDuration:1.0animations:^{

weakCell.headImageView.alpha=1.0;

}];

}

else

{

weakCell.headImageView.alpha=1.0;

}

}];

// 用户名

cell.userName.text= model.userName;

// 用户描述

cell.descLabel.text= model.desc;

// 当图片存在的时候

if(![model.mainImageURLisEqualToString:@""])

{

// 图片不隐藏

cell.mainImageView.hidden=NO;

// 配置主图的方法,同头像

[cell.mainImageViewsd_setImageWithURL:[NSURLURLWithString:model.mainImageURL]completed:^(UIImage*image,NSError*error, SDImageCacheType cacheType,NSURL*imageURL) {

if(image && cacheType == SDImageCacheTypeNone) {

weakCell.mainImageView.alpha=0;

[UIViewanimateWithDuration:1.0animations:^{

weakCell.mainImageView.alpha=1.0;

}];

}

else

{

weakCell.mainImageView.alpha=1.0;

}

}];

// 我们进行等比例计算出刚才那个主图高度的约束

cell.mainHeightConstraint.constant= (model.mainHeight*375) / model.mainWidth;

// 底部描述具体图片底部的约束固定为19

cell.descTopConstraint.constant=19;

}

// 图片没有的时候,只显示描述

{

// 主要图片隐藏

cell.mainImageView.hidden=YES;

// 主图的高度越是为0  其实也代表了隐藏了

cell.mainHeightConstraint.constant=0;

// 底部如果约束还是19的话,会拉的太长,所以咱们让他为0

cell.descTopConstraint.constant=0;

}

}

4.那么见证奇迹的时刻到了,按官方说法是这样的:

[objc]view plaincopy

#import 

- (CGFloat)tableView:(UITableView*)tableViewheightForRowAtIndexPath:(NSIndexPath*)indexPath {

return[tableViewfd_heightForCellWithIdentifier:@"identifer"cacheByIndexPath:indexPathconfiguration:^(idcell) {

// 配置 cell 的数据源,和 "cellForRow" 干的事一致,比如:

[selfconfigCell:(UITableViewCell*)cellindexPath:(NSIndexPath*)indexPath];

}];

}

人家都说了,一句话搞定,反正我是这样的:

[objc]view plaincopy

- (CGFloat)tableView:(UITableView*)tableViewheightForRowAtIndexPath:(NSIndexPath*)indexPath

{

return[tableViewfd_heightForCellWithIdentifier:identifycacheByIndexPath:indexPathconfiguration:^(MKJTableViewCell*cell)

{

[selfconfigCell:cellindexpath:indexPath];

}];

}

我觉得挺好用的,还是要感谢下有那么牛B的作者!

行注目礼!!!作者一生平安!!!

让我们轻松愉快,不用再纠结于算Frame了,简单效果如下

本次展示Demo的Github地址:Demo地址,需要的点我各位有啥意见就告诉我,虚心求教

Over~~~~~~~~~~~~~~~~~~

转载地址:http://blog.csdn.net/deft_mkjing/article/details/51569605

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 199,519评论 5 468
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 83,842评论 2 376
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 146,544评论 0 330
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 53,742评论 1 271
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 62,646评论 5 359
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,027评论 1 275
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 37,513评论 3 390
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,169评论 0 254
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,324评论 1 294
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,268评论 2 317
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,299评论 1 329
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 32,996评论 3 315
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 38,591评论 3 303
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,667评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 30,911评论 1 255
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 42,288评论 2 345
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 41,871评论 2 341

推荐阅读更多精彩内容