IOS开发入门iOS_autoLayout(VFL)
白羽 2019-04-16 来源 :网络 阅读 613 评论 0

摘要:本文将带你了解IOS开发入门iOS_autoLayout(VFL),希望本文对大家学IOS有所帮助。

    本文将带你了解IOS开发入门iOS_autoLayout(VFL),希望本文对大家学IOS有所帮助。


IOS开发入门iOS_autoLayout(VFL)


SLayoutConstraint的第二个类方法
   
    + (NSArray *)constraintsWithVisualFormat:(NSString *)format
                                       options:(NSLayoutFormatOptions)opts
                                       metrics:(NSDictionary *)metrics
                                         views:(NSDictionary *)views;
    其中format就是VFL字符串,比如@"H:|-10-[view]-20-|",一会详细说明。opts是枚举参数,默认是0。  
      ?1234567891011121314151617181920typedef   NS_OPTIONS(NSUInteger, NSLayoutFormatOptions)   {  

 NSLayoutFormatAlignAllLeft =

(1 <<  NSLayoutAttributeLeft),   

NSLayoutFormatAlignAllRight =  

(1 << 

NSLayoutAttributeRight),   

NSLayoutFormatAlignAllTop

=  (1<< NSLayoutAttributeTop),  

 NSLayoutFormatAlignAllBottom 

= (1 <<   NSLayoutAttributeBottom),   

NSLayoutFormatAlignAllLeading  

= (1 <<  

NSLayoutAttributeLeading),   

NSLayoutFormatAlignAllTrailing  

= (1 <<

NSLayoutAttributeTrailing),   

NSLayoutFormatAlignAllCenterX 

= (1 <<   NSLayoutAttributeCenterX),   

NSLayoutFormatAlignAllCenterY 

= (1 <<   NSLayoutAttributeCenterY),   

NSLayoutFormatAlignAllBaseline 

= (1 << NSLayoutAttributeBaseline),   

NSLayoutFormatAlignAllLastBaseline  

=   NSLayoutFormatAlignAllBaseline,   

NSLayoutFormatAlignAllFirstBaseline  

NS_ENUM_AVAILABLE_IOS(8_0)

= (1 << NSLayoutAttributeFirstBaseline),   

NSLayoutFormatAlignmentMask  

= 0xFFFF,   

/* choose only one of these   t

hree    

*/   

NSLayoutFormatDirectionLeadingToTrailing  

= 0 << 16, // default   

NSLayoutFormatDirectionLeftToRight 

= 1 << 16,   

NSLayoutFormatDirectionRightToLeft

=   2 << 16,     

NSLayoutFormatDirectionMask

=   0x3 << 16,  };
    metrics是自定义的一个字典,这个字典里面的key可以写在format字串中。编译器解析时,自动替换为metrics字典中的value。比如:  
      ?12NSDictionary   * metrics =   @{@"left":@5,@"right":@5,@"height":@150.0};     NSString * format =   @"|-left-[view]-right-|";
    这个一看就明白的,不用这个,设置为nil。views是设置约束所有view的字典。比如:
      ?1NSDictionary   *viewsDictionary =   NSDictionaryOfVariableBindings(view);
    这个宏的作用是把view映射成字典[NSDictionary dictionaryWithObjectsAndKeys:view,   @"view", nil];
    VFL
    苹果开发团队可能觉得添加单个constraint的API比较长,于是就有了VFL(Visual format language)。
    上面提到的@"H:|-10-[view]-20-|",意思就是view距离superview的左边10点,右边20点,这样是不是就可以确定了这个view的宽度了?
    其中H:表示横向,|表示父视图边缘,-10-表示10点距离,[view]表示子视图。
    下面详细说明:
    V:表示纵向
    H:表示横向
    |表示父视图边缘
    -表示距离
    >=表示视图间距、宽度或高度必须大于或等于某个值
    <=表示视图间距、宽度或高度必须小宇或等于某个值
    ==表示视图间距、宽度或高度必须等于某个值
    @表示>=、<=、==限制,最大为1000
    示例:
   
       |-[view]-|视图处在父视图的左右边缘内|-[view]视图处在父视图的左边缘|[view]视图和父视图左边对齐-[view]-设置视图的宽度高度|-30.0-[view]-30.0-|表示离父视图   左右间距30[view(200.0)]表示视图宽度为200.0|-[view(view1)]-[view1]-|表示视图宽度一样,并且在父视图左右边缘内V:|-[view(50.0)]视图高度为50V:|-(==padding)-[imageView]->=0-[button]-(==padding)-|表示离父视图的距离
       为Padding,这两个视图间距必须大于或等于0并且距离底部父视图为padding。[wideView(>=60@700)]视图的宽度为至少为60不能超过   700如果没有声明方向默认为水平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]];   


本文由职坐标整理并发布,希望对同学们有所帮助。了解更多详情请关注职坐标移动开发之IOS频道!

本文由 @白羽 发布于职坐标。未经许可,禁止转载。
喜欢 | 0 不喜欢 | 0
看完这篇文章有何感觉?已经有0人表态,0%的人喜欢 快给朋友分享吧~
评论(0)
后参与评论

您输入的评论内容中包含违禁敏感词

我知道了

助您圆梦职场 匹配合适岗位
验证码手机号,获得海同独家IT培训资料
选择就业方向:
人工智能物联网
大数据开发/分析
人工智能Python
Java全栈开发
WEB前端+H5

请输入正确的手机号码

请输入正确的验证码

获取验证码

您今天的短信下发次数太多了,明天再试试吧!

提交

我们会在第一时间安排职业规划师联系您!

您也可以联系我们的职业规划师咨询:

小职老师的微信号:z_zhizuobiao
小职老师的微信号:z_zhizuobiao

版权所有 职坐标-一站式IT培训就业服务领导者 沪ICP备13042190号-4
上海海同信息科技有限公司 Copyright ©2015 www.zhizuobiao.com,All Rights Reserved.
 沪公网安备 31011502005948号    

©2015 www.zhizuobiao.com All Rights Reserved

208小时内训课程