// // ViewController.m // Masonry自动布局 // // Created by 王木木 on 15/11/18. // Copyright © 2015年 王木木. All rights reserved. //学习自http://www.cocoachina.com/ios/20141219/10702.html /* @property (nonatomic, strong, readonly) MASConstraint *left; 左侧 @property (nonatomic, strong, readonly) MASConstraint *top; 上侧 @property (nonatomic, strong, readonly) MASConstraint *right; 右侧 @property (nonatomic, strong, readonly) MASConstraint *bottom; 下侧 @property (nonatomic, strong, readonly) MASConstraint *leading; 首部 @property (nonatomic, strong, readonly) MASConstraint *trailing; 尾部 @property (nonatomic, strong, readonly) MASConstraint *width; 宽 @property (nonatomic, strong, readonly) MASConstraint *height; 高 @property (nonatomic, strong, readonly) MASConstraint *centerX; 横向中点 @property (nonatomic, strong, readonly) MASConstraint *centerY; 纵向中点 @property (nonatomic, strong, readonly) MASConstraint *baseline; 文本基线 */ /* 首先在Masonry中能够添加autolayout约束有三个函数 - (NSArray *)mas_makeConstraints:(void(^)(MASConstraintMaker *make))block; - (NSArray *)mas_updateConstraints:(void(^)(MASConstraintMaker *make))block; - (NSArray *)mas_remakeConstraints:(void(^)(MASConstraintMaker *make))block; mas_makeConstraints 只负责新增约束 Autolayout不能同时存在两条针对于同一对象的约束 否则会报错 mas_updateConstraints 针对上面的情况 会更新在block中出现的约束 不会导致出现两个相同约束的情况 mas_remakeConstraints 则会清除之前的所有约束 仅保留最新的约束 三种函数善加利用 就可以应对各种情况了 */ #import "ViewController.h" #import "View+MASAdditions.h" #import "View+MASShorthandAdditions.h" @interface ViewController () @end @implementation ViewController - (void)viewDidLoad { [super viewDidLoad]; // Do any additional setup after loading the view, typically from a nib. // 设置约束前 [self view1]; } //1. [基础] 居中显示一个view -(void)view1{ UIView *view = [UIView new]; view.backgroundColor = [UIColor blackColor]; [self.view addSubview:view]; [view mas_makeConstraints:^(MASConstraintMaker *make) { make.center.equalTo(self.view); make.size.mas_equalTo(CGSizeMake(300, 300)); }]; } //2让一个view略小于其superView(边距为10) -(void)view2{ UIView *view = [UIView new]; view.backgroundColor = [UIColor blackColor]; //在做autoLayout之前 一定要先将view添加到superview上 否则会报错 [self.view addSubview:view]; //mas_makeConstraints就是Masonry的autolayout添加函数 将所需的约束添加到block中行了 [view mas_makeConstraints:^(MASConstraintMaker *make) { //将sv居中 make.center.equalTo(self.view); //将size设置成(300,300) make.size.mas_equalTo(CGSizeMake(300, 300)); }]; UIView *view1 = [UIView new]; view1.backgroundColor = [UIColor redColor]; [view addSubview:view1]; [view1 mas_makeConstraints:^(MASConstraintMaker *make) { // make.edges.equalTo(view).width.insets(UIEdgeInsetsMake(10, 10, 10, 10)); /**********************************************************************/ /* 这里有意思的地方是and和with 其实这两个函数什么事情都没做 - (MASConstraint *)with { return self; } - (MASConstraint *)and { return self; } 但是用在这种链式语法中 就非常的巧妙和易懂 不得不佩服作者的心思(虽然我现在基本都会省略) */ make.top.equalTo(view.mas_top).with.offset(20); make.left.equalTo(view).with.offset(20); make.bottom.equalTo(view).with.offset(-20); make.right.equalTo(view).with.offset(-20); /**********************************************************************/ // make.top.left.bottom.and.right.equalTo(view).with.insets(UIEdgeInsetsMake(30, 30, 30, 30)); /**********************************************************************上面三种效果一样*/ }]; } //3. [初级] 让两个高度为150的view垂直居中且等宽且等间隔排列 间隔为10(自动计算其宽度) -(void)view3{ //括号里面是数字或定值时用 mas_equalTo 括号里面是量词 对象的时候用equalTo int padd = 10; UIView *view = [UIView new]; view.backgroundColor = [UIColor blackColor]; UIView *view1 = [UIView new]; view1.backgroundColor = [UIColor yellowColor]; UIView *view2 = [UIView new]; view2.backgroundColor = [UIColor yellowColor]; [self.view addSubview:view]; [view addSubview:view1]; [view addSubview:view2]; [view mas_makeConstraints:^(MASConstraintMaker *make) { make.center.equalTo(self.view); make.size.mas_equalTo(CGSizeMake(300, 300)); }]; [view1 mas_makeConstraints:^(MASConstraintMaker *make) { make.centerY.mas_equalTo(view.mas_centerY); make.left.equalTo(view.mas_left).with.offset(padd); make.right.equalTo(view2.mas_left).with.offset(-padd); make.height.mas_equalTo(@150); make.width.equalTo(view2); }]; [view2 mas_makeConstraints:^(MASConstraintMaker *make) { make.centerY.mas_equalTo(view.mas_centerY); make.left.equalTo(view1.mas_right).with.offset(padd); make.right.equalTo(view.mas_right).with.offset(-padd); make.height.mas_equalTo(@150); make.width.mas_equalTo(view1.mas_width); }]; } //4. [中级] 在UIScrollView顺序排列一些view并自动计算contentSize -(void)view4{ UIView *view = [UIView new]; view.backgroundColor = [UIColor blackColor]; UIScrollView *scroll = [UIScrollView new]; scroll.backgroundColor = [UIColor purpleColor]; [self.view addSubview:view]; [view addSubview:scroll]; [view mas_makeConstraints:^(MASConstraintMaker *make) { make.center.equalTo(self.view); make.size.mas_equalTo(CGSizeMake(300, 300)); }]; [scroll mas_makeConstraints:^(MASConstraintMaker *make) { make.edges.equalTo(view).width.insets(UIEdgeInsetsMake(5, 5, 5, 5)); }]; } -(void)view5{ UITextField *pwdTextField = [UITextField new]; pwdTextField.backgroundColor = [UIColor blackColor]; [self.view addSubview:pwdTextField]; UITextField *twopwdTextField = [UITextField new]; twopwdTextField.backgroundColor = [UIColor yellowColor]; [self.view addSubview:twopwdTextField]; twopwdTextField.placeholder = @"请再次输入密码"; twopwdTextField.layer.masksToBounds = YES; twopwdTextField.layer.cornerRadius = 5; [pwdTextField mas_makeConstraints:^(MASConstraintMaker *make) { make.center.equalTo(self.view); make.size.mas_equalTo(CGSizeMake(300, 300)); }]; [twopwdTextField mas_makeConstraints:^(MASConstraintMaker *make) { // make.center.equalTo(self.view); make.top.equalTo(pwdTextField.mas_bottom).with.offset(20); // make.centerY.mas_equalTo(pwdTextField.mas_centerY); make.left.mas_equalTo(pwdTextField.mas_left); make.right.mas_equalTo(pwdTextField.mas_right); make.width.mas_equalTo(pwdTextField.mas_width); make.height.mas_equalTo(pwdTextField.mas_height); }]; } - (void)didReceiveMemoryWarning { [super didReceiveMemoryWarning]; // Dispose of any resources that can be recreated. } @end