当我在iPhone 6+上旋转时,为什么导航栏会从我的拆分视图中消失?

时间:2015-09-13 21:46:00

标签: ios iphone swift

问题

我的拆分视图有问题。它在iPhone和iPad模拟器上运行良好,但在iPhone 6+上,我在旋转设备后丢失了导航栏。以下是6+模拟器上发生的事情:

  • 我启动了应用程序,它在导航栏中显示一个+按钮。我点按此按钮。
  • 它在现有视图上加载视图控制器。正如预期的那样,使用后退按钮可以看到导航栏。
  • 我水平转动设备。按照预期,新控制器出现在主控部分中,右侧有一个空的详细信息部分。不幸的是导航栏消失了。
  • 当我垂直转动设备时,导航栏不会重新出现。

事实上,当我水平转动设备时,似乎导航控制器已从堆栈中移除(我已经通过输出splitViewContoller.viewControllers的内容观察到了这一点。)

我的代码

测试应用程序只是Master Detail模板,只有一些修改。

我添加了一个新的"添加项目"控制器,然后从主视图中创建一个show segue" +"按钮。 "添加项目"控制器是空白的,只是一个蓝色背景。

DetailViewController有一个timerStarted布尔值,在使用详细信息视图时为true,如果不是则为false。主视图在使用细节时隐藏,在不使用时显示。

这里是相关的代码(在AppDelegate中没有什么有趣的,因为它不再是分割视图委托,而MasterViewController没有交互,因为按钮通过故事板工作)

DetailViewController

import UIKit

class DetailViewController: UIViewController, UISplitViewControllerDelegate {
    @IBOutlet weak var detailDescriptionLabel: UILabel!
    var collapseDetailViewController = true


    var detailItem: AnyObject? {
        didSet {
            self.configureView()
        }
    }

    var timerStarted: Bool = false {
        didSet {
            self.changeTimerStatus()
        }
    }

    func configureView() {
        if let detail: AnyObject = self.detailItem {
            if let label = self.detailDescriptionLabel {
                label.text = detail.description
                self.timerStarted = true
            }
        }
    }

    func changeTimerStatus() {
        if self.timerStarted {
            if splitViewController!.collapsed == false {
                UIView.animateWithDuration(0.3, animations: {
                    self.splitViewController?.preferredDisplayMode = UISplitViewControllerDisplayMode.PrimaryHidden
                })
            }
            collapseDetailViewController = false
        } else {
            if splitViewController!.collapsed {
                self.splitViewController?.viewControllers[0].popToRootViewControllerAnimated(true)
            } else {
                UIView.animateWithDuration(0.3, animations: {
                    self.splitViewController?.preferredDisplayMode = UISplitViewControllerDisplayMode.AllVisible
                })
            }
            collapseDetailViewController = true
        }
    }

    override func viewDidLoad() {
        super.viewDidLoad()
        splitViewController?.delegate = self
        self.disabledScreen.hidden = false
        self.view.bringSubviewToFront(disabledScreen)
        self.configureView()
    }

    override func viewWillAppear(animated: Bool) {
        if splitViewController!.collapsed == false && self.timerStarted == false {
            splitViewController?.preferredDisplayMode = UISplitViewControllerDisplayMode.AllVisible
        }
    }

    @IBAction func closeButton(sender: AnyObject) {
        self.timerStarted = false
    }

    func primaryViewControllerForExpandingSplitViewController(splitViewController: UISplitViewController) -> UIViewController? {
        if timerStarted == true {
            splitViewController.preferredDisplayMode = UISplitViewControllerDisplayMode.PrimaryHidden
        } else {
            splitViewController.preferredDisplayMode = UISplitViewControllerDisplayMode.AllVisible
        }
        return nil
    }

    func splitViewController(splitViewController: UISplitViewController, collapseSecondaryViewController secondaryViewController: UIViewController!, ontoPrimaryViewController primaryViewController: UIViewController!) -> Bool {
        return collapseDetailViewController
    }
}

AddItemViewController

import UIKit

class AddItemViewController: UIViewController, UISplitViewControllerDelegate {
    var collapseDetailViewController = false

    override func viewDidLoad() {
        super.viewDidLoad()
        self.splitViewController?.delegate = self
    }

    override func didReceiveMemoryWarning() {
        super.didReceiveMemoryWarning()
    }

    override func viewDidAppear(animated: Bool) {
        self.splitViewController?.delegate = self
        self.collapseDetailViewController = false
    }

    override func viewWillDisappear(animated: Bool) {
        self.splitViewController?.delegate = nil
        self.collapseDetailViewController = true
    }

    func primaryViewControllerForExpandingSplitViewController(splitViewController: UISplitViewController) -> UIViewController? {
        return self
    }

    func primaryViewControllerForCollapsingSplitViewController(splitViewController: UISplitViewController) -> UIViewController? {
        return nil
    }

    func splitViewController(splitViewController: UISplitViewController, collapseSecondaryViewController secondaryViewController: UIViewController!, ontoPrimaryViewController primaryViewController: UIViewController!) -> Bool {
        return collapseDetailViewController
    }
}

我很感激任何建议。

1 个答案:

答案 0 :(得分:0)

我找到了答案。我读了一篇我最初错过的文章,因为它侧重于改变细节视图而不是主视图。事实证明,如果我只是管理细节,那么拆分视图效果会更好,然后主人会照顾好自己。由于我从不想更改细节,我可以简单地将以下内容添加到我的拆分视图委托:

func splitViewController(splitViewController: UISplitViewController, separateSecondaryViewControllerFromPrimaryViewController primaryViewController: UIViewController!) -> UIViewController? {
    return (UIStoryboard(name: "Main", bundle: nil).instantiateViewControllerWithIdentifier("detailView") as! UIViewController)
}

完成后,我不再丢失导航栏。