在UIView中嵌入UIViewController

时间:2017-03-31 22:01:49

标签: swift uiview

我想在UIView中嵌入一个UIViewController。我想以编程方式创建它。我在故事板中创建了UIViewController。

我的代码创建一个空的UIView:

let myNewView=UIView(frame: CGRect(x: (0 + screenHeight / 2), y: leftView.frame.origin.y, width: screenHeight / 2, height: leftView.frame.height))
myNewView.backgroundColor=UIColor.lightGray

self.view.addSubview(myNewView)

将UIViewController附加到视图的代码:

let storyboard = UIStoryboard(name: "Main", bundle: nil)
var controller: UIViewController = storyboard.instantiateViewController(withIdentifier: "testView") as UIViewController
myNewView.addSubview(controller.view)

这会在我的UIView中显示视图,但不会以正确的方式显示。 UIView在这种情况下是512像素宽。虽然(嵌入式)UIViewcontroller认为它是1024像素宽(全屏宽度)。

如何解决嵌入视图从其父级(UIView)获取宽度和高度的问题?

3 个答案:

答案 0 :(得分:27)

正如其他人所说,您无法在视图中嵌入视图控制器视图。 你可以做的是将viewcontroller嵌入到另一个viewcontroller中作为childviewcontroller。

尝试使用以下命令替换newView代码:

let storyboard = UIStoryboard(name: "Main", bundle: nil)
var controller: UIViewController = storyboard.instantiateViewController(withIdentifier: "testView") as UIViewController

//add as a childviewcontroller
 addChildViewController(controller)

 // Add the child's View as a subview
 self.view.addSubview(controller.view)
 controller.view.frame = view.bounds
 controller.view.autoresizingMask = [.flexibleWidth, .flexibleHeight]

 // tell the childviewcontroller it's contained in it's parent
  controller.didMove(toParentViewController: self)

编辑: 要更改childviewcontroller的显示方式和位置,只需更新其框架即可。 例如,使其高度的一半,并锚定到底部:

controller.view.frame = CGRect(x: 0, y: view.center.y, width: view.size.width, height: view.size.height * 0.5) 

答案 1 :(得分:0)

您可以使用通用方法,例如:

func embed(_ viewController:UIViewController, inParent controller:UIViewController, inView view:UIView){
   viewController.willMove(toParent: controller)
   viewController.view.frame = view.bounds
   view.addSubview(viewController.view)
   controller.addChild(viewController)
   viewController.didMove(toParent: controller)
}

希望有帮助

答案 2 :(得分:0)

已更新为最新版本,并使用了UIViewController类的扩展:

extension UIViewController {
    func embed(_ viewController:UIViewController, inView view:UIView){
        viewController.willMove(toParentViewController: self)
        viewController.view.frame = view.bounds
        view.addSubview(viewController.view)
        self.addChildViewController(viewController)
        viewController.didMove(toParentViewController: self)
    }
}