http://www.cnblogs.com/xyzaijing/p/4049169.htmlhtml
Masonry是一個輕量級的封裝了Autolayout框架git
https://github.com/Masonry/Masonrygithub
github頁面上給出了使用Masonry和Autolayout實現一樣效果代碼量的對比app
固然了你若是學習了VFL,代碼量也不會不少框架
日常咱們使用Autolayout要設置view.translatesAutoresizingMaskIntoConstraints = NO;
less
Masonry會自動幫咱們調用這行代碼ide
結合官方的實例看幾個小時差很少就能使用Masonry了,學習
UIEdgeInsets padding = UIEdgeInsetsMake(10, 10, 10, 10);
[view1 mas_makeConstraints:^(MASConstraintMaker *make) { make.top.equalTo(superview.mas_top).with.offset(padding.top); //with is an optional semantic filler make.left.equalTo(superview.mas_left).with.offset(padding.left); make.bottom.equalTo(superview.mas_bottom).with.offset(-padding.bottom); make.right.equalTo(superview.mas_right).with.offset(-padding.right); }];
讓一個在父視圖上上下左右各縮進10個長度(請自動腦補若是使用Autolayout的代碼量)動畫
下面是效果圖this
或者你能夠用一行代碼搞定上面的效果圖
[view1 mas_makeConstraints:^(MASConstraintMaker *make) { make.edges.equalTo(superview).with.insets(padding); }];
腫麼樣,給力吧
除了可使用make.edges還可使用make.size等,直接設置size約束
Masonry還會自動識別你要設置的屬性(上,下,左,右),下面兩行代碼的效果等價
make.left.greaterThanOrEqualTo(label); make.left.greaterThanOrEqualTo(label.mas_left);
下面是寬度約束的代碼
make.width.greaterThanOrEqualTo(@200); make.width.lessThanOrEqualTo(@400)
然而,Autolayout不容許對齊元素(left ,centerX)等寫成常量 ,因此若是你寫成下面那句代碼
make.left.lessThanOrEqualTo(@10)
Masonry會自動幫你轉換爲下面的約束式(關聯superView)
view.left = view.superview.left + 10
你出了可使用NSNumber,還可使用基本類型量和結構體(最下面那句代碼是屢次設置)
make.top.mas_equalTo(42); make.height.mas_equalTo(20); make.size.mas_equalTo(CGSizeMake(50, 100)); make.edges.mas_equalTo(UIEdgeInsetsMake(10, 0, 10, 0)); make.left.mas_equalTo(view).mas_offset(UIEdgeInsetsMake(10, 0, 10, 0));
此外你還能夠添加NSArray(一組)約束
make.height.equalTo(@[view1.mas_height, view2.mas_height]); make.height.equalTo(@[view1, view2]); make.left.equalTo(@[view1, @100, view3.right]);
還能夠一次添加多個約束,使用鏈式語句或者結構體
Masonry also gives you a few convenience methods which create multiple constraints at the same time. These are called MASCompositeConstraints edges // make top, left, bottom, right equal view2 make.edges.equalTo(view2); // make top = superview.top + 5, left = superview.left + 10, // bottom = superview.bottom - 15, right = superview.right - 20 make.edges.equalTo(superview).insets(UIEdgeInsetsMake(5, 10, 15, 20)) size // make width and height greater than or equal to titleLabel make.size.greaterThanOrEqualTo(titleLabel) // make width = superview.width + 100, height = superview.height - 50 make.size.equalTo(superview).sizeOffset(CGSizeMake(100, -50)) center // make centerX and centerY = button1 make.center.equalTo(button1) // make centerX = superview.centerX - 5, centerY = superview.centerY + 10 make.center.equalTo(superview).centerOffset(CGPointMake(-5, 10)) You can chain view attributes for increased readability: // All edges but the top should equal those of the superview make.left.right.and.bottom.equalTo(superview); make.top.equalTo(otherView);
你還能夠定義約束的優先級,當約束出現衝突的時候,優先級高的約束覆蓋優先級低的約束(下面的代碼是添加優先級)
make.left.greaterThanOrEqualTo(label.mas_left).with.priorityLow(); make.top.equalTo(label.mas_top).with.priority(600);
有時候咱們須要去掉某些約束,或者修改某些約束(動畫等),這個時候腫麼辦呢?
// in public/private interface @property (nonatomic, strong) MASConstraint *topConstraint; ... // when making constraints [view1 mas_makeConstraints:^(MASConstraintMaker *make) { self.topConstraint = make.top.equalTo(superview.mas_top).with.offset(padding.top); make.left.equalTo(superview.mas_left).with.offset(padding.left); }]; ... // then later you can call [self.topConstraint uninstall];
使用一個引用,在不須要的時候,調用uninstall就能夠去掉約束了
若是你後續須要改變約束(添加動畫等),你能夠調用另一個建立約束的方法,並把約束須要的值,寫成變量(蘋果建議添加個更新約束寫在updateConstraints方法中)
// this is Apple's recommended place for adding/updating constraints // this method can get called multiple times in response to setNeedsUpdateConstraints // which can be called by UIKit internally or in your code if you need to trigger an update to your constraints - (void)updateConstraints { [self.growingButton mas_updateConstraints:^(MASConstraintMaker *make) { make.center.equalTo(self); make.width.equalTo(@(self.buttonSize.width)).priorityLow(); make.height.equalTo(@(self.buttonSize.height)).priorityLow(); make.width.lessThanOrEqualTo(self); make.height.lessThanOrEqualTo(self); }]; //according to apple super should be called at end of method [super updateConstraints]; }
有時候咱們爲了改變約束,須要有變量來引用約束,這個時候若是須要改變的約束很是多,那麼這將是一個很是蛋疼的代碼量
因此Masonry提供了一個重建約束的方法,使用這個方法,創建約束以前會把以前的約束所有清除掉,而後從新添加,這樣咱們只須要添加執行邏輯代碼就好了(判斷等)
以下
mas_updateConstraints is useful for updating a set of constraints, but doing anything beyond updating constant values can get exhausting. That's where mas_remakeConstraints comes in. mas_remakeConstraints is similar to mas_updateConstraints, but instead of updating constant values, it will remove all of its contraints before installing them again. This lets you provide different constraints without having to keep around references to ones which you want to remove. - (void)changeButtonPosition { [self.button mas_remakeConstraints:^(MASConstraintMaker *make) { make.size.equalTo(self.buttonSize); if (topLeft) { make.top.and.left.offset(10); } else { make.bottom.and.right.offset(-10); } }]; }
約束出現問題的時候控制檯打印的信息過於籠統,不容易讓人發現問題,爲此Masonry,添加了分類,重寫了約束的description方法
從而能夠給出更詳細的提示信息
Masonry adds a category to NSLayoutConstraint which overrides the default implementation of - (NSString *)description. Now you can give meaningful names to views and constraints, and also easily pick out the constraints created by Masonry.
Masonry還給出了snippets
Copy the included code snippets to ~/Library/Developer/Xcode/UserData/CodeSnippets to write your masonry blocks at lightning speed! mas_make -> [<view> mas_makeConstraints:^(MASConstraintMaker *make){<code>}]; mas_update -> [<view> mas_updateConstraints:^(MASConstraintMaker *make){<code>}]; mas_remake -> [<view> mas_remakeConstraints:^(MASConstraintMaker *make){<code>}];