从 children UIViewControllers 访问 parent UIViewController

Accessing a parent UIViewController from its children UIViewControllers

我有一个叫 ContainerUIViewController,里面还有另外两个 child UIViewControllersMasterDetail

我的问题是试图从其 child 控制器之一访问 Container

应用程序委托代码:

@UIApplicationMain
class AppDelegate: UIResponder, UIApplicationDelegate {
    var window: UIWindow?
    var container: Container?

    func application(application: UIApplication, didFinishLaunchingWithOptions launchOptions: [NSObject: AnyObject]?) -> Bool {
        window = UIWindow(frame: UIScreen.mainScreen().bounds)
        container = Container(nibName: "Container", bundle: nil)
        window?.rootViewController = Container()
        window?.makeKeyAndVisible()
        return true
    }

    func appShowDetailView(vc:UIViewController){
        container!.showDetailView(vc)
    }
}

容器代码:

import UIKit

class Container: UIViewController {

    var masterView:UIViewController?
    var detailView:UIViewController?
    var masterViewFrame = CGRectMake(0, 0, 0, 0)
    var detailViewFrame = CGRectMake(0, 0, 0, 0)
    var detailOnScreenFrame = CGRectMake(0, 0, 0, 0)
    var detailOffScreenFrame = CGRectMake(0, 0, 0, 0)
    var masterViewHeight:CGFloat = 50

    override func viewDidLoad() {
        super.viewDidLoad()
        masterView = MenuViewController(nibName: "MenuViewController", bundle: nil)
        detailView = RootViewController(nibName: "RootViewController", bundle: nil)
        masterViewFrame = CGRectMake(0, 0, self.view.frame.width, masterViewHeight)
        detailViewFrame = CGRectMake(0, masterViewHeight, self.view.frame.width, self.view.frame.height - masterViewHeight)
        detailOffScreenFrame = CGRectMake(detailViewFrame.origin.x, detailViewFrame.origin.y + detailViewFrame.height, detailViewFrame.width, detailViewFrame.height)
        detailOnScreenFrame = detailViewFrame
        self.addChildViewController(masterView!)
        self.addChildViewController(detailView!)
        masterView!.view.frame = masterViewFrame
        detailView!.view.frame = detailViewFrame
        self.view.addSubview(masterView!.view)
        self.view.addSubview(detailView!.view)
    }

    func cycleDetailView(from:UIViewController, toView to:UIViewController){
        from.willMoveToParentViewController(nil)
        self.addChildViewController(to)
        to.view.frame = self.detailOffScreenFrame
        self.detailView = to
        self.transitionFromViewController(from, toViewController: to, duration: 0.25, options: UIViewAnimationOptions.allZeros,
            animations: {() -> Void in

                // send the new view controller in, and the old one out
                to.view.frame = self.detailOnScreenFrame
                from.view.frame = self.detailOffScreenFrame
            }, completion: {success -> Void in

                // tells the view controllers cycling has ended
                from.removeFromParentViewController()
                to.didMoveToParentViewController(self)
            }
        )
    }

    func showDetailView(vc: UIViewController){
        if let oldView = detailView {
            cycleDetailView(oldView, toView: vc)
        }else{
            detailView = self.childViewControllers[1] as? UIViewController
            if let oldView = detailView {
                cycleDetailView(oldView, toView: vc)
            }else{

            }
        }
    }
}

问题出在showDetailView()。当它被这样一段代码调用时:

    let appDelegate = UIApplication.sharedApplication().delegate as? AppDelegate
    if let delegateUnwrapped = appDelegate {
        delegateUnwrapped.appShowDetailView(aViewController)
    }

...Container 函数 showDetailView() 只能为 detailView 获取 nil 值,而 self.childViewControllers 是一个空数组。

这让我觉得我正在以错误的方式访问 child 视图控制器。

谁能告诉我哪里错了?

TIA。

我认为您的问题出在应用委托中的这一行,

 window?.rootViewController = Container()

这将创建一个新的 Container 实例,而不是您分配给容器的实例 属性。将该行更改为,

window?.rootViewController = container