说到iOS自动布局,有很多的解决办法。有的人使用xib/storyboard自动布局,也有人使用frame来适配。对于前者,笔者并不喜欢,也不支持。对于后者,更是麻烦,到处计算高度、宽度等,千万大量代码的冗余,对维护和开发的效率都很低。
笔者在这里介绍纯代码自动布局的第三方库:Masonry。这个库使用率相当高,在全世界都有大量的开发者在使用,其star数量也是相当高的。
效果图
本节详解Masonry的以动画的形式更新约束的基本用法,先看看效果图:
我们这里初始按钮是一个很小的按钮,点击就不断放大,最大就放大到全屏幕。
核心代码
看下代码:
|
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
|
>
;
;
@end
TableViewController
{
;
;
;
;
;
;
{
;
;
{
;
;
;
;
}
;
}
{
{
;
}
;
}
#pragma mark - UITableViewDataSource
{
;
}
{
;
;
{
;
}
;
{
;
;
;
;
;
}
{
;
;
}
@end
|
讲解
我们来看看这个计算行高的代码,看起来是不是很像配置数据的代理方法呢?
|
1
2
3
4
5
6
7
|
{
;
;
}
|
我们看看TestCell的声明,提供了一个计算行高的类方法:
|
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
|
;
: UITableViewCell
;
;
;
;
;
;
@end
|
我们看一下计算行高的实现:
|
1
2
3
4
5
6
7
8
9
10
11
|
{
;
;
;
;
;
}
|
我们只是创建了一个cell然后配置数据,然后调用layoutIfNeeded更新约束,以便获取到frame。当我们获取到以后,我们就可以计算出最后的cell真正的高度了。