Masonry tableviewCell布局

Posted 西贝了爷

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Masonry tableviewCell布局相关的知识,希望对你有一定的参考价值。

前言

说到ios自动布局,有很多的解决办法。有的人使用xib/storyboard自动布局,也有人使用frame来适配。对于前者,笔者并不喜欢,也不支持。对于后者,更是麻烦,到处计算高度、宽度等,千万大量代码的冗余,对维护和开发的效率都很低。

笔者在这里介绍纯代码自动布局的第三方库:Masonry。这个库使用率相当高,在全世界都有大量的开发者在使用,其star数量也是相当高的。

效果图

本节详解Masonry的以动画的形式更新约束的基本用法,先看看效果图:

技术分享

我们这里初始按钮是一个很小的按钮,点击就不断放大,最大就放大到全屏幕。

核心代码

看下代码:

 

讲解


我们来看看这个计算行高的代码,看起来是不是很像配置数据的代理方法呢?

我们看看TestCell的声明,提供了一个计算行高的类方法:

我们看一下计算行高的实现:

我们只是创建了一个cell然后配置数据,然后调用layoutIfNeeded更新约束,以便获取到frame。当我们获取到以后,我们就可以计算出最后的cell真正的高度了。

 

以上是关于Masonry tableviewCell布局的主要内容,如果未能解决你的问题,请参考以下文章

第三方框架-纯代码布局:Masonry的简单使用

Masonry自动布局:复合约束

Masonry scrollview循环布局

Masonry复杂ScrollView布局

代码适配Masonry使用的详细介绍

代码适配Masonry使用的详细介绍