学无止境iOS 专注性能控件类

学习AutoLayout(VFL)

2015-03-11  本文已影响4870人  guaker

NSLayoutConstraint的第二个类方法
+ (NSArray *)constraintsWithVisualFormat:(NSString *)format
options:(NSLayoutFormatOptions)opts
metrics:(NSDictionary *)metrics
views:(NSDictionary *)views;

VFL

苹果开发团队可能觉得添加单个constraint的API比较长,于是就有了VFL(Visual format language)
上面提到的@"H:|-10-[view]-20-|",意思就是view距离superview的左边10点,右边20点,这样是不是就可以确定了这个view的宽度了?
其中H:表示横向,|表示父视图边缘,-10-表示10点距离,[view]表示子视图。
下面详细说明,参考:AutoLayout详解+手把手实战
V:表示纵向
H:表示横向
|表示父视图边缘
-表示距离
>=表示视图间距、宽度或高度必须大于或等于某个值
<=表示视图间距、宽度或高度必须小宇或等于某个值
==表示视图间距、宽度或高度必须等于某个值
@表示>=<===限制,最大为1000

示例:

  1. |-[view]-|视图处在父视图的左右边缘内
  1. |-[view]视图处在父视图的左边缘
  2. |[view]视图和父视图左边对齐
  3. -[view]-设置视图的宽度高度
  4. |-30.0-[view]-30.0-|表示离父视图 左右间距30
  5. [view(200.0)]表示视图宽度为200.0
  6. |-[view(view1)]-[view1]-|表示视图宽度一样,并且在父视图左右边缘内
  7. V:|-[view(50.0)]视图高度为50
  8. V:|-(==padding)-[imageView]->=0-[button]-(==padding)-|表示离父视图的距离
    Padding,这两个视图间距必须大于或等于0并且距离底部父视图为padding
  9. [wideView(>=60@700)]视图的宽度为至少为60不能超过 700
  10. 如果没有声明方向默认为水平H:(原文写的V:

代码

UIView *view = [[UIView alloc] init];
view.backgroundColor = [UIColor brownColor];
view.translatesAutoresizingMaskIntoConstraints = NO;
[self.view addSubview:view];

//通过宏映射成[NSDictionary dictionaryWithObjectsAndKeys:v1, @"v1", v2, @"v2", nil];
NSDictionary *viewsDictionary = NSDictionaryOfVariableBindings(view);
//约束1 横向
[self.view addConstraints:
 [NSLayoutConstraint constraintsWithVisualFormat:@"H:|-10-[view]-20-|"
                                         options:0
                                         metrics:nil
                                           views:viewsDictionary]];
//约束2 纵向
[self.view addConstraints:
 [NSLayoutConstraint constraintsWithVisualFormat:@"V:|-100-[view]-200-|"
                                         options:0
                                         metrics:nil
                                           views:viewsDictionary]];

效果图

VFL
持续更新,项目中适配遇到的问题就写出来,下篇介绍scrollView使用autoLayout
上一篇 下一篇

猜你喜欢

热点阅读