VFL :Visual Format language
写法:
功能 表达式
水平方向 H:
垂直方向 V:
Views [view]
SuperView |
关系 >=,==,<=
空间,间隙 -
优先级 @value
需要注意的是,在用代码创建的UIView在,一定要加上下面这句代码
XXX.translatesAutoresizingMaskIntoConstraints=NO;
如果没有上面这一行,你的约束将不生效,控制台会输出一连串的错误.
具体上代码:
// 1.添加控件
UIView *blueView = [[UIView alloc] init];
blueView.backgroundColor = [UIColor blueColor];
blueView.translatesAutoresizingMaskIntoConstraints = NO;
[self.view addSubview:blueView];
UIView *redView = [[UIView alloc] init];
redView.backgroundColor = [UIColor redColor];
redView.translatesAutoresizingMaskIntoConstraints = NO;
[self.view addSubview:redView];
// 2.VFL生成约束
NSDictionary *mertrics = @{@"margin" : @20}; // 参数数值
NSDictionary *views = NSDictionaryOfVariableBindings(blueView, redView);
NSArray *conts = [NSLayoutConstraint constraintsWithVisualFormat:@"H:|-margin-[blueView]-margin-[redView(==blueView)]-margin-|" options:NSLayoutFormatAlignAllTop | NSLayoutFormatAlignAllBottom metrics:mertrics views:views];
NSArray *conts2 = [NSLayoutConstraint constraintsWithVisualFormat:@"V:[blueView(==blueHeight)]-margin-|" options:0 metrics:@{@"blueHeight" : @40, @"margin" : @20} views:views];
[self.view addConstraints:conts];
[self.view addConstraints:conts2];
UIButton *button=[[UIButton alloc]init];
button=[UIButton buttonWithType:UIButtonTypeSystem];
[button setTitle:@"VFL" forState:UIControlStateNormal];
button.translatesAutoresizingMaskIntoConstraints=NO;
[button setBackgroundColor:[UIColor blackColor]];
[self.view addSubview:button];
NSArray *Hconstraint =[NSLayoutConstraint constraintsWithVisualFormat:@"H:|-20-[button]-200-|" options:0 metrics:nil views:@{@"button":button}];
NSArray *Vconstraint = [NSLayoutConstraint constraintsWithVisualFormat:@"V:|-300-[button]-200-|" options:0 metrics:nil views:@{@"button":button}];
[self.view addConstraints:Hconstraint];
[self.view addConstraints:Vconstraint];