【问题标题】:Vertically center subview using Auto-Layout使用自动布局垂直居中子视图
【发布时间】:2013-09-01 15:23:29
【问题描述】:

我正在尝试弄清楚如何使用自动布局使视图垂直居中。 我是这项技术的新手,所以它给我带来了一些问题...... 这是我在 Interface Builder 中的控制器:

灰色部分是超级视图,它包含一个自定义视图(黄色)和一个标签(红色);黄色视图固定在超级视图的底部,并且具有固定的高度和宽度。红色视图也有固定的宽度和高度。

我的目标是将我的红色视图垂直居中在灰色视图的可见部分,其可见高度为superview.height - yellowView.height。 我该怎么做?
非常感谢!

【问题讨论】:

  • 您是否需要红色视图在不同尺寸的屏幕上保持输入,并在旋转时保持输入?
  • 不同的屏幕尺寸

标签: iphone ios interface-builder constraints autolayout


【解决方案1】:

最简单的方法是让灰色视图也成为主视图的子视图,然后你可以在 IB 或代码中给标签一个 centerY 约束。如果由于某种原因不能这样做,您可以在代码中更改 centerY 约束的常量值,使其值为黄色视图高度的 1/2。在 IB 中给标签一个 centerY 约束并为其创建一个 IBOutlet(在我的示例中我称之为 centerCon)。我的黄色视图的固定高度是 200。

- (void)viewDidLoad {
    [super viewDidLoad];
    self.centerCon.constant = 100;
}

【讨论】:

  • 我最终使用了您的解决方案...现在我对自动布局更有信心了!谢谢;)
  • @matteodv,我不知道你什么时候看到我的答案,但我对其进行了编辑以显示更简单的方法。
【解决方案2】:

这里最简单的解决方案之一是这样的:

redView.center = CGPointMake(superview.width/2, (superview.height - yellowView.height)/2);

【讨论】:

  • 我知道我可以这样设置它的中心,但我的问题是关于使用 Auto-Layouts 和 IB 将其居中...
猜你喜欢
  • 1970-01-01
  • 2019-03-03
  • 1970-01-01
  • 2015-01-05
  • 2017-01-18
  • 2012-09-28
  • 2014-12-08
  • 1970-01-01
  • 2012-11-23
相关资源
最近更新 更多