Change View in a Window

Subviews can be added to a custom view to display contents from other view controllers inside a window. In this example, a subview is a .xib file which acts as the view of an NSViewController object.

To get started, drag a Custom View to the window from the object library in Interface Builder. Don’t forget to set the size and layout contraints of the view.

Next, create a view by adding a new file and selecting View in the User Interface section. This view appears in the Xcode project as a XIB file. After adding the view, create a view controller by adding a new Cocoa Class file to the project; it is a subclass of NSViewController.

Back in Interface Builder, select the File’s Owner for the XIB and add the view controller as the Custom Class object. In the Connections Inspector for the File’s Owner, make sure the view of the XIB is connected to the view controller along with other connections such as outlets and actions.

// ViewControllerA.swift

import Cocoa

class ViewControllerA: NSViewController {
    @IBOutlet weak var textField: NSTextField!

    @IBAction func showText(_ sender: NSTextField) {
        let x = sender.stringValue
        textField.stringValue = x

Finally, in the main view controller (shown below) create properties to each subview view controller. The nibName is the name of the XIB file that represents the view associated with the view controller. Create an outlet to the custom view which contains the subviews. For this particular example, a button action adds the view to the custom view.

// ViewController.swift

import Cocoa

class ViewController: NSViewController {
    let vcA = ViewControllerA(nibName: "ViewA", bundle: nil)
    let vcB = ViewControllerB(nibName: "ViewB", bundle: nil)

    @IBOutlet weak var CustomView: NSView!
    @IBAction func showViewA(_ sender: NSButton) {
    @IBAction func showViewB(_ sender: NSButton) {

Source code

Example code for this article is available in the change-view repository on GitHub. Comments and other feedback can be submitted on the Issues page.