用代码进行自动布局(VFL)

前言
在进行app开发的时候,界面布局是非常重要的一项,比如如果没有布局好界面 并且没有用storyboard进行布局,那么切换横竖屏或是换机型的时候 界面就会变得非常的乱。所以用代码进行自动布局就非常必要了。

VFL语言的简单介绍

VFL:可视化格式语言 Visual Format Language

H:水平方向

V:垂直方向

[视图的名字] 其他视图

|:表示父视图

-本身表示一段距离

-距离-:表示一段距离

[字符串表示的视图] 参照视图

[字符串表示的视图(视图的宽高 或者最小最大的宽高、相对宽高))]
注意:()千万不要丢掉

使用代码自动布局步骤:

1.禁用

使用自动布局(autolayout )frame 就会失效 -> 不需要再去设置视图的frame
使用代码自动布局的时候需要禁用translatesAutoresizingMaskIntoConstraints属性(设置为NO)

2.绑定视图与字符串

3.添加约束

部分示例:

UIView *view = [[UIView  alloc]init];
   view.backgroundColor = [UIColor cyanColor];
   
   //1.禁用
   view.translatesAutoresizingMaskIntoConstraints = NO;
   [self.view addSubview:view];
  
   //2.绑定视图和字符串
   NSDictionary *views = NSDictionaryOfVariableBindings(view);
   
    //3.添加约束
   /**
    *VisualFormat:VFL 语句
    *options:基于哪一个选项 (基于哪个方向去计算布局)
    *metrics:绑定数值(NSNumber)与字符串
    *views:绑定视图与字符串的
    */
   /*
    中国语言:
    横向:距离父视图左侧100 视图本身的宽度最小是100 距离父视图右侧是100
    竖向:距离父视图顶部150 视图本身高度是40
    
    可视化语言:
    H:|-100-[view(>=100)]-100-|
    V:|-150-[view(40)]
    
    */
   [self.view addConstraints:[NSLayoutConstraint constraintsWithVisualFormat:@"H:|-100-[view(>=100)]-100-|" options:NSLayoutFormatAlignAllLeft metrics:nil views:views]];
   [self.view addConstraints:[NSLayoutConstraint constraintsWithVisualFormat:@"V:|-150-[view1(40)]" options:NSLayoutFormatAlignAllLeft metrics:nil views:views]];

全部示例

注意:调用不同的demo方法会实现相同的效果,但是实现方法不同,具体的里面有注释


#import "ViewController.h"

@interface ViewController ()

@end

@implementation ViewController

- (void)viewDidLoad {
    [super viewDidLoad];
    
        [self demo5];

}
//metrics使用
/*
 用来绑定参数和字符串的方法
 */
- (void)demo5{
    UIView *view1 = [self createView:@"UIView" addToView:self.view];
    view1.backgroundColor = [UIColor orangeColor];
    UIView *view2 = [self createView:@"UIView" addToView:self.view];
    view2.backgroundColor = [UIColor redColor];
    //2.绑定
    NSDictionary *views = NSDictionaryOfVariableBindings(view1,view2);
    NSNumber *leftSpace = @100;
    NSNumber *rightSpace = @100;
    NSNumber *view1TopSpace = @150;
    NSNumber *view1MinWidth = @100;
    NSNumber *view1Height = @40;
    
    NSNumber *view2TopSpace = @50;
    NSDictionary *metrics = NSDictionaryOfVariableBindings(leftSpace,rightSpace,view1TopSpace,view1MinWidth,view1Height,view2TopSpace);
    
    //所有约束的VFL数组
    NSArray *constrains = @[@"H:|-leftSpace-[view1(>=view1MinWidth)]-rightSpace-|",@"H:|-leftSpace-[view2(view1)]-rightSpace-|",@"V:|-view1TopSpace-[view1(view1Height)]-view2TopSpace-[view2(view1)]"];
    for (int i = 0;i<constrains.count; i++) {
        [self.view addConstraints:[NSLayoutConstraint constraintsWithVisualFormat:constrains[i] options:NSLayoutFormatAlignAllLeft metrics:metrics views:views]];
        
    }

}
//利用数组简化代码
- (void)demo4{

    UIView *view1 = [self createView:@"UIView" addToView:self.view];
    view1.backgroundColor = [UIColor orangeColor];
    UIView *view2 = [self createView:@"UIView" addToView:self.view];
    view2.backgroundColor = [UIColor redColor];
    //2.绑定
    NSDictionary *views = NSDictionaryOfVariableBindings(view1,view2);
    //3.添加约束
    //所有约束的VFL数组
    NSArray *constrains = @[@"H:|-100-[view1(>=100)]-100-|",@"H:|-100-[view2(>=100)]-100-|",@"V:|-150-[view1(40)]-50-[view2(view1)]"];
  
    for (int i = 0;i<constrains.count; i++) {
        [self.view addConstraints:[NSLayoutConstraint constraintsWithVisualFormat:constrains[i] options:NSLayoutFormatAlignAllLeft metrics:nil views:views]];

    }
}

//合并有交集的竖向 简化代码
- (void)demo3{
    /*
     研究发现:
     两个视图竖向是有交集的   -> 尝试把两个竖向的约束 放到一起
     view1:
     V:|-150-[view1(40)]
     
     view2:
     V:[view1]-50-[view2(view1)]
     
     放到一起:
     V:|-150-[view1(40)]-50-[view2(view1)]
     
     */

    UIView *view1 = [self createView:@"UIView" addToView:self.view];
    view1.backgroundColor = [UIColor orangeColor];
    UIView *view2 = [self createView:@"UIView" addToView:self.view];
    view2.backgroundColor = [UIColor redColor];
    //2.绑定
    NSDictionary *views = NSDictionaryOfVariableBindings(view1,view2);
    //3.添加约束
    /*
     view1:
     中国语言
     横向:距离父视图左侧100 view1宽度最小是100 距离父视图右侧是100
     竖向:距离父视图顶部150 view1的高度是40
     
     可视化语言
     H:|-100-[view1(>=100)]-100-|
     V:|-150-[view1(40)]
     
     view2:
     中国语言
     横向:距离父视图左侧100 view1宽度最小是100 距离父视图右侧是100
     竖向:距离view1 50 view2的高度和view1相同
     可视化语言:
     H:|-100-[view1(>=100)]-100-|
     V:[view1]-50-[view2(view1)]
     */
    //view1
    [self.view addConstraints:[NSLayoutConstraint constraintsWithVisualFormat:@"H:|-100-[view1(>=100)]-100-|" options:NSLayoutFormatAlignAllLeft metrics:nil views:views]];
    
    //view2
    [self.view addConstraints:[NSLayoutConstraint constraintsWithVisualFormat:@"H:|-100-[view2(>=100)]-100-|" options:NSLayoutFormatAlignAllLeft metrics:nil views:views]];
    [self.view addConstraints:[NSLayoutConstraint constraintsWithVisualFormat:@"V:|-150-[view1(40)]-50-[view2(view1)]" options:NSLayoutFormatAlignAllLeft metrics:nil views:views]];

}

//利用封装好的创建视图的方法添加约束
- (void)demo2{
    UIView *view1 = [self createView:@"UIView" addToView:self.view];
    view1.backgroundColor = [UIColor orangeColor];
    UIView *view2 = [self createView:@"UIView" addToView:self.view];
    view2.backgroundColor = [UIColor redColor];
//2.绑定
    NSDictionary *views = NSDictionaryOfVariableBindings(view1,view2);
//3.添加约束
    /*
     view1:
     中国语言
     横向:距离父视图左侧100 view1宽度最小是100 距离父视图右侧是100
     竖向:距离父视图顶部150 view1的高度是40
     
     可视化语言
     H:|-100-[view1(>=100)]-100-|
     V:|-150-[view1(40)]
     
     view2:
     中国语言
     横向:距离父视图左侧100 view1宽度最小是100 距离父视图右侧是100
     竖向:距离view1 50 view2的高度和view1相同
     可视化语言:
     H:|-100-[view1(>=100)]-100-|
     V:[view1]-50-[view2(view1)]
     */
    //view1
    [self.view addConstraints:[NSLayoutConstraint constraintsWithVisualFormat:@"H:|-100-[view1(>=100)]-100-|" options:NSLayoutFormatAlignAllLeft metrics:nil views:views]];
    [self.view addConstraints:[NSLayoutConstraint constraintsWithVisualFormat:@"V:|-150-[view1(40)]" options:NSLayoutFormatAlignAllLeft metrics:nil views:views]];
    //view2
    [self.view addConstraints:[NSLayoutConstraint constraintsWithVisualFormat:@"H:|-100-[view2(>=100)]-100-|" options:NSLayoutFormatAlignAllLeft metrics:nil views:views]];
    [self.view addConstraints:[NSLayoutConstraint constraintsWithVisualFormat:@"V:[view1]-50-[view2(view1)]" options:NSLayoutFormatAlignAllLeft metrics:nil views:views]];
    }
/**
 * 创建视图的方法
 *
 *  @param view  需要创建视图的类名字符串
 *  @param sView 添加到的目标父视图
 *
 *  @return 创建好并添加到父视图上的视图
 */
- (UIView *)createView:(NSString *)view addToView:(UIView *)sView{
    UIView *myView = [[NSClassFromString(view) alloc]init];
    myView.translatesAutoresizingMaskIntoConstraints= NO;
    [sView addSubview:myView];

    return myView;
}

//普通的添加约束
- (void)demo1{

    UIView *view = [[UIView  alloc]init];
    view.backgroundColor = [UIColor cyanColor];
    //1.禁用
    view.translatesAutoresizingMaskIntoConstraints = NO;
    [self.view addSubview:view];
    //2.绑定视图和字符串
    NSDictionary *views = NSDictionaryOfVariableBindings(view);
    //3.添加约束
    /**
     *VisualFormat:VFL 语句
     *options:基于哪一个选项 (基于哪个方向去计算布局)
     *metrics:绑定数值(NSNumber)与字符串
     *views:绑定视图与字符串的
     */
    /*
     中国语言:
     横向:距离父视图左侧100 视图本身的宽度最小是100 距离父视图右侧是100
     竖向:距离父视图顶部150 视图本身高度是40
     
     可视化语言:
     H:|-100-[view(>=100)]-100-|
     V:|-150-[view(40)]
     
     */
    [self.view addConstraints:[NSLayoutConstraint constraintsWithVisualFormat:@"H:|-100-[view(>=100)]-100-|" options:NSLayoutFormatAlignAllLeft metrics:nil views:views]];
    [self.view addConstraints:[NSLayoutConstraint constraintsWithVisualFormat:@"V:|-150-[view1(40)]" options:NSLayoutFormatAlignAllLeft metrics:nil views:views]];

}

@end

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 213,335评论 6 492
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 90,895评论 3 387
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 158,766评论 0 348
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 56,918评论 1 285
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,042评论 6 385
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,169评论 1 291
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,219评论 3 412
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 37,976评论 0 268
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,393评论 1 304
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,711评论 2 328
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 38,876评论 1 341
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,562评论 4 336
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,193评论 3 317
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,903评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,142评论 1 267
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,699评论 2 362
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,764评论 2 351

推荐阅读更多精彩内容