美文网首页Xcode 布局
关于iOS autolayout(自动布局)的简单了解

关于iOS autolayout(自动布局)的简单了解

作者: 顺其自然2017 | 来源:发表于2017-08-26 22:57 被阅读12次

    1.UI布局

            iOS移动客户端的开发,界面布局必不可少,刚开始主要是通过frame来实现布局,这种方法十分清楚明了,只是需要自己设计好每个视图的位置大小比例,稍微复杂一点,并且对不同屏幕尺寸的适用性不高,因此,在iOS6之后,苹果推出了AutoLayout相对布局方式,用于实现适配不同操作系统版本与屏幕尺寸,并逐渐被程序员青睐。

    2.AutoLayout自动布局的代码实例及解释

    使用AutoLayout添加约束,iOS6中新加入了一个类.

    创建约束

    NSLayoutConstraint *view_1TopToSuperViewTop = [NSLayoutConstraint constraintWithItem:v1     // 用于约束的视图                                                                 attribute:NSLayoutAttributeTop      //想要约束的属性(宽,高,左,右,上,下)                     relatedBy:NSLayoutRelationEqual      //约束关系(等于,大于,小于)                                     toItem:self.view               //参考视图                                                               attribute:NSLayoutAttributeTop        //参考视图参考属性                                                             multiplier:1          //倍率关系                                                                                                         constant:30];         //额外距离正加负减

    添加约束

     - (void)addConstraint:(NSLayoutConstraint *)constraint //添加单个约束                                      - (void)addConstraints:(NSArray *)constraints //添加约束数组

    刷新约束

    可以通过-setNeedsUpdateConstraints和-layoutIfNeeded两个方法来刷新约束的改变,使UIView重新布局。

    代码实例:

    UIView*v1=[[UIViewalloc]initWithFrame:CGRectZero];

    v1.translatesAutoresizingMaskIntoConstraints=NO;//关闭AutoresizingMask布局

    v1.backgroundColor=[UIColorblueColor];

    [self.viewaddSubview:v1];

    UIView*v2=[[UIViewalloc]initWithFrame:CGRectZero];

    v2.translatesAutoresizingMaskIntoConstraints=NO;//关闭AutoresizingMask布局

    v2.backgroundColor=[UIColorredColor];

    [self.viewaddSubview:v2];

    设置v1视图的宽度为self.view的宽度,高度为self.view的高度的一半

    [self.viewaddConstraint:[NSLayoutConstraintconstraintWithItem:v1attribute:NSLayoutAttributeWidthrelatedBy:NSLayoutRelationEqualtoItem:self.viewattribute:NSLayoutAttributeWidthmultiplier:1.0constant:0]];

    [self.viewaddConstraint:[NSLayoutConstraintconstraintWithItem:v1attribute:NSLayoutAttributeHeightrelatedBy:NSLayoutRelationEqualtoItem:self.viewattribute:NSLayoutAttributeHeightmultiplier:0.5constant:0]];

    设置v2与v1的高度宽度相同,即宽度为self.view的宽度,高度为self.view的高度的一半

    [self.viewaddConstraint:[NSLayoutConstraintconstraintWithItem:v2attribute:NSLayoutAttributeHeightrelatedBy:NSLayoutRelationEqualtoItem:v1attribute:NSLayoutAttributeHeightmultiplier:1constant:0]];

    [self.viewaddConstraint:[NSLayoutConstraintconstraintWithItem:v2attribute:NSLayoutAttributeWidthrelatedBy:NSLayoutRelationEqualtoItem:v1attribute:NSLayoutAttributeWidthmultiplier:1constant:0]];

    设置v2视图底部与self.view底部位置相同,如果不设置,则默认视图位置从父视图左上角(0,0)处开始

    [self.viewaddConstraint:[NSLayoutConstraintconstraintWithItem:v2attribute:NSLayoutAttributeBottomrelatedBy:NSLayoutRelationEqualtoItem:self.viewattribute:NSLayoutAttributeBottommultiplier:1constant:0]];

    运行结果如图

    可以看到,为了实现简单的两个视图的布局,AutoLayout代码复杂,下面使用VFL约束来做一下,代码就比较简洁了。

    首先是关于constraintsWithVisualFormat:函数的介绍:

    constraintsWithVisualFormat:参数为NSString型,指定Contsraint的属性

    options:字典类型的值;这里的值一般在系统定义的一个enum里面选取

    metrics:nil;一般为nil ,参数类型为NSDictionary,衡量标准

    views:就是上面所加入到NSDictionary中的绑定的View

    VFL约束使用规则

    |: 表示父视图

    -:表示距离

    V::表示垂直

    H::表示水平

    >= :表示视图间距/宽度/高度必须大于或等于某个值

    <= :表示视图间距/宽度/高度必须小宇或等于某个值

    == :表示视图间距/宽度/高度必须等于某个值

    @:限制间距/宽度/高度最大为某个值

    NSDictionary*views =NSDictionaryOfVariableBindings(v1,v2);

    [self.viewaddConstraints:[NSLayoutConstraintconstraintsWithVisualFormat:@"H:|[v1]|"options:0metrics:nilviews:views]];//设置v1宽度

    [self.viewaddConstraints:[NSLayoutConstraintconstraintsWithVisualFormat:@"H:|[v2]|"options:0metrics:nilviews:views]];//设置v2宽度

    [self.viewaddConstraints:[NSLayoutConstraintconstraintsWithVisualFormat:@"V:|[v1][v2(==v1)]|"options:0metrics:nilviews:views]];//设置v1与v2高度相同

    [self.viewaddConstraints:[NSLayoutConstraintconstraintsWithVisualFormat:@"V:|-0-[v1]-0-[v2]-0-|"options:0metrics:nilviews:views]];//设置v1与v2无间距且各自距父视图顶部与底部无间距且高度和为父视图高度。

    虽然VFL已经比较简洁了,但在我看来,如果子视图过多,又由于约束需要添加到最近公共父视图,或者是较高层次父视图,视图间的相对关系也比较复杂,AutoLayout代码会更加复杂。然而frame虽然计算麻烦,但是归根结底都是子视图在父视图中的位置大小,思路相对更加清晰明了。所以具体如何实现布局,还需要实际考虑。

    相关文章

      网友评论

        本文标题:关于iOS autolayout(自动布局)的简单了解

        本文链接:https://www.haomeiwen.com/subject/rhtpdxtx.html