Masonry布局过程剖解

自动布局的核心公式:obj1.attr = mutiplier * obj2.attr + constant (默认mutiplier = 1)

第一阶段:创建约束创建者,收集约束试图、约束属性、参考试图、参考属性、约束关系、偏移量。

1、创建MASConstraintMaker,初始化的时候传入当前试图作为约束试图。

Masonry布局过程剖解_第1张图片

2、收集约束属性:通过调用约束创建者left、right、top、bottom等。

Masonry布局过程剖解_第2张图片

3、收集参考试图和参考属性:通过调用约束的equalTo,同时收集关系。

Masonry布局过程剖解_第3张图片

4、偏移量:通过约束的offset。

Masonry布局过程剖解_第4张图片

第二阶段:安装约束

1、移除旧的约束:底层调用UIView的removeConstraint。

2、安装约束:

(1)取出之前收集的约束视图、约束属性、参考试图、参考属性、约束关系和偏移量。

Masonry布局过程剖解_第5张图片

(2)调用NSLayoutConstraint的约束方法创建约束。

Masonry布局过程剖解_第6张图片

(3)接下来就是寻找安装约束的视图,分三种情况:一是有参考试图,那么安装试图取最近的共同父试图;二是设置尺寸属性,安装试图取本身;三是默认取父试图。

Masonry布局过程剖解_第7张图片

(4)开始设置约束:分两种情况,一是更新当前约束,二是安装新约束。

Masonry布局过程剖解_第8张图片

你可能感兴趣的:(Masonry布局过程剖解)