在3.5“和4”显示屏上均匀排列UIButtons

时间:2013-02-24 18:08:26

标签: ios interface-builder alignment autolayout

我现在已经花了很多时间搞清楚 - 自动布局以及如何使用它,但还没有找到解决这个问题的答案。

我的问题是我要调整,例如5个垂直放置的UIButtons均匀地放在iPhone 5和之前的显示器上,但有没有办法使用Interface Builder来完成它,或者是应该在代码中完成的事情。当我希望按钮之间的垂直距离与屏幕分辨率(3.5“和4”显示)均匀时。

我尝试在按钮之间添加垂直约束,但如果选择4“显示,这只会在布局的顶部或底部添加间隙。

我当然错过了一些简单的东西,但无法理解。

1 个答案:

答案 0 :(得分:1)

我实现这一点的唯一方法是在边缘之间和按钮之间放置标签(没有标题,因此它们是不可见的),这样按钮和标签就会占据所有垂直空间。屏幕。按钮具有固有尺寸,但标签没有,因此它们会扩展或收缩以正确填充空间。

-(void)viewDidLoad {
    [super viewDidLoad];

    NSMutableDictionary *viewsDict = [NSMutableDictionary dictionary];
    NSArray *titles = @[@"Button 1",@"Button 2",@"Button 3",@"Button 4",@"Button 5"];
    for (int i=1; i<6; i++) {
        UIButton *b = [UIButton buttonWithType:1];
        [b setTitle:titles[i-1] forState:UIControlStateNormal];
        [b setTranslatesAutoresizingMaskIntoConstraints:NO];
        [viewsDict setObject:b forKey:[NSString stringWithFormat:@"b%d",i]];
    }

    for (int i=1; i<7; i++) { // labels for spacing
        UILabel *l = [[UILabel alloc ]init];
        [l setTranslatesAutoresizingMaskIntoConstraints:NO];
        [viewsDict setObject:l forKey:[NSString stringWithFormat:@"l%d",i]];
    }

    for (id obj in viewsDict.allKeys) 
        [self.view addSubview:viewsDict[obj]];

    NSArray *constraints = [NSLayoutConstraint constraintsWithVisualFormat:@"V:|[l1][b1][l2(==l1)][b2][l3(==l1)][b3][l4(==l1)][b4][l5(==l1)][b5][l6(==l1)]|"
                                                                   options:NSLayoutFormatAlignAllLeading
                                                                   metrics:nil
                                                                     views:viewsDict];


    NSArray *constraints2 = [NSLayoutConstraint constraintsWithVisualFormat:@"|-100-[b1]"
                                                                   options:NSLayoutFormatAlignAllLeading
                                                                   metrics:nil
                                                                  views:viewsDict];


    [self.view addConstraints:constraints];
    [self.view addConstraints:constraints2];
}

这使所有按钮与左边缘对齐100个点,按钮之间的间距相等。这将根据屏幕尺寸和旋转进行调整。