我最近下载了Xcode 5 DP,在iOS 7上测试我的应用。我注意到并确认的第一件事是,视图的边界并不总是根据状态栏和导航栏调整大小。

在viewDidLayoutSubviews中,我打印了视图的边界:

{{0, 0}, {320, 568}}

这导致我的内容出现在导航栏和状态栏的下方。

我知道我可以通过获取主屏幕的高度,减去状态栏的高度和导航栏的高度来解释高度,但这似乎是不必要的额外工作。

我该如何解决这个问题?

更新:

我已经找到了解决这个问题的方法。将导航栏的半透明属性设置为NO:

self.navigationController.navigationBar.translucent = NO;

这将修复视图被框在导航栏和状态栏下面的问题。

然而,我还没有找到一个修复的情况下,当你想导航栏是半透明的。例如,在全屏查看一张照片时,我希望导航栏是半透明的,视图被框在它下面。这是可行的,但是当我切换显示/隐藏导航栏时,我经历了更奇怪的结果。第一个子视图(一个UIScrollView)每次都会改变它的边界y原点。


当前回答

最简单的技巧是打开NIB文件并执行以下两个简单步骤:

只需切换它并将其设置为您喜欢的一个:

选择那些UIView的/UIIMageView的/…你想要下移。在我的例子中,只有徽标重叠,我已经将delta设置为+15;(如果第一步选择iOS 7,则为-15)

结果是:

其他回答

我以编程方式创建了我的视图,这最终为我工作:

- (void) viewDidLayoutSubviews {
    // only works for iOS 7+
    if ([[[UIDevice currentDevice] systemVersion] floatValue] >= 7.0) {
        CGRect viewBounds = self.view.bounds;
        CGFloat topBarOffset = self.topLayoutGuide.length;

        // snaps the view under the status bar (iOS 6 style)
        viewBounds.origin.y = topBarOffset * -1;

        // shrink the bounds of your view to compensate for the offset
        viewBounds.size.height = viewBounds.size.height + (topBarOffset * -1);
        self.view.bounds = viewBounds;
    }
}

来源(在第39页底部的topLayoutGuide部分)。

我在ipad (armv7, armv7s, amr64)上的应用程序也有同样的问题,只是通过呈现另一个UIViewController,并在驳回它们后,在状态栏下进入导航栏… 我花了很多时间来寻找解决方案。我使用故事板和在InterfaceBuilder的UIViewController,这使得糟糕的我设置从全屏->当前上下文的演示,它修复了这个问题。它在我的应用程序只适用于ipad => iOS8.0(测试与iOS8.1)和ipad与iOS 7.1不工作!!

从下拉列表中添加“基于视图控制器的状态栏外观”作为info.plist中的一行。就像这样:

斯威夫特3

override func viewWillAppear(_ animated: Bool) {
    self.edgesForExtendedLayout = []
}

Swift 4.2 - Xcode 10.0 - iOS 12.0:

if #available(iOS 11.0, *) {} else {
  self.edgesForExtendedLayout = []
  self.navigationController?.view.backgroundColor = .white
}