1

我有一个上面UIView有三个UILabels的。我有一个title,subtitlesubtitleDescription, 所有UILabel属性。我希望我的标题在左上角,标题下方的字幕没有间隙,并且 subtitleDescription 到字幕的右侧没有间隙,将基线与字幕基线对齐。如果是视图,我想要省略号,或者在 subtitle/subtitleDescription 的情况下需要视图。我想以编程方式使用自动布局。

与此类似:

  _________________________________
 |[title]                         | 
 |[subtitle][subtitleDescription] |
 |________________________________|

我希望标签转到左上角而不是居中。在我现在的代码中,它都是居中的,所有的标签都在彼此之上。

我只是调用sizeToFit所有的UILabel,除此之外我根本不调整框架。当然,这段代码是在我分配和初始化标签并设置文本之后。这是我的代码:

 - (void)setup
 {
[self.title sizeToFit];
[self.subtitle sizeToFit];
[self.subtitleDescription sizeToFit];

[self addConstraints:[NSLayoutConstraint constraintsWithVisualFormat:@"|[title]-(>=0)-|"
                                                            options:kNilOptions
                                                           metrics:nil
                                                             views:@{ @"title" : self.title }]];

[self addConstraints:[NSLayoutConstraint constraintsWithVisualFormat:@"|[subtitle]-5-[subdesc]-(>=0)-|"
                                                             options:NSLayoutFormatDirectionLeftToRight
                                                             metrics:nil
                                                               views:@{ @"subtitle" : self.subtitle,
                                                                        @"subdesc"  : self.subtitleDescription }]];

// compR > compR
[self setContentCompressionResistancePriority:900 forAxis:UILayoutConstraintAxisHorizontal];
[self setContentCompressionResistancePriority:500 forAxis:UILayoutConstraintAxisHorizontal];

[self addConstraints:[NSLayoutConstraint constraintsWithVisualFormat:@"V:|[title]-5-[subtitle]|"
                                                             options:kNilOptions
                                                             metrics:nil
                                                               views:@{ @"title"    : self.title,
                                                                        @"subtitle" : self.subtitle }]];

[self addConstraint:[NSLayoutConstraint constraintWithItem:self.subtitleDescription
                                                 attribute:NSLayoutAttributeBaseline
                                                 relatedBy:NSLayoutRelationEqual
                                                    toItem:self.subtitle
                                                 attribute:NSLayoutAttributeBaseline
                                                multiplier:1.0
                                                  constant:0]];
 }

谢谢!!!

这是视图的屏幕截图:

在此处输入图像描述

更新

正如 jrturton 向我指出的那样,看起来我的所有约束都被约束异常所打破。我想弄清楚为什么它们坏了。给出的消息是“无法同时满足约束”。

4

1 回答 1

3

首先,确保您的标签通过设置启用自动布局translatesAutoResizingMaskIntoConstraints = NO

你不需要任何sizeToFit电话。在添加约束时,它们是没有意义的。标签将在布局点使用其固有大小。

为防止居中,只需不要固定到超级视图的两侧。所以代替这个:

"|[title]-(>=0)-|"

做这个:

"|[title]"

或者确实是这样:

"|[title]|"

并在标签上设置左对齐。

对于一行中的多个标签,您需要这样:

"|[subtitle]-5-[subdesc]|"

传递NSLayoutFormatAlignAllBaseline选项。如果需要,您可以|将选项或 ( ) 一起使用。同样,您不需要不等式间距。左对齐标签将占用尽可能多的空间。您可能希望在两个标签上设置压缩阻力/拥抱优先级,这样如果没有足够的空间来显示这两个值,您就有规则截断哪个标签。

您正在视图本身上设置内容压缩阻力,如果视图本身也不受自动布局的影响,这将毫无意义。您还将两次设置为两个不同的值,我不确定您希望通过它实现什么。

如果超级视图具有固定大小,您当前的垂直约束将导致一个或其他标签被拉伸以填充剩余大小,这将使文本垂直居中,这就是标签太高时所做的事情。

您可以通过不固定到底部来克服这个问题:

"V:[title]-5-[subtitle]"

我在这里写了大量关于 VFL 和自动布局文章,并附有其他与自动布局相关的文章的链接。

于 2013-10-29T16:34:52.240 回答