Abordagem 1:
Isso é feito adicionando um acessório da barra de título. Consegui fazer isso modificando o arquivo AppDelegate.swift. Eu tive que aplicar algum preenchimento estranho para fazer com que parecesse certo.
AppDelegate.swift
func applicationDidFinishLaunching(_ aNotification: Notification) {
// Create the SwiftUI view that provides the window contents.
let contentView = ContentView()
// Create the titlebar accessory
let titlebarAccessoryView = TitlebarAccessory().padding([.top, .leading, .trailing], 16.0).padding(.bottom,-8.0).edgesIgnoringSafeArea(.top)
let accessoryHostingView = NSHostingView(rootView:titlebarAccessoryView)
accessoryHostingView.frame.size = accessoryHostingView.fittingSize
let titlebarAccessory = NSTitlebarAccessoryViewController()
titlebarAccessory.view = accessoryHostingView
// Create the window and set the content view.
window = NSWindow(
contentRect: NSRect(x: 0, y: 0, width: 480, height: 300),
styleMask: [.titled, .closable, .miniaturizable, .resizable, .fullSizeContentView],
backing: .buffered, defer: false)
window.center()
window.setFrameAutosaveName("Main Window")
// Add the titlebar accessory
window.addTitlebarAccessoryViewController(titlebarAccessory)
window.contentView = NSHostingView(rootView: contentView)
window.makeKeyAndOrderFront(nil)
}
TitlebarAccessory.swift
import SwiftUI
struct TitlebarAccessory: View {
var body: some View {
TextField("Placeholder", text: .constant(""))
}
}
Resultado:
Abordagem 2 (método alternativo):
A idéia aqui é fazer a parte da barra de ferramentas usando o storyboard e o restante do aplicativo usando o SwiftUI. Isso é feito criando um novo aplicativo com o storyboard como interface do usuário. Em seguida, vá para o storyboard, exclua o View Controller padrão e adicione um novo NSHostingController
. Conecte o Hosting Controller recém-adicionado à janela principal, definindo seu relacionamento. Adicione sua barra de ferramentas à janela usando o construtor de interfaces.
Anexe uma classe personalizada à sua NSHostingController
e carregue sua visualização SwiftUI nela.
Exemplo de código abaixo:
import Cocoa
import SwiftUI
class HostingController: NSHostingController<SwiftUIView> {
@objc required dynamic init?(coder: NSCoder) {
super.init(coder: coder, rootView: SwiftUIView())
}
}
O uso dessa abordagem também permite personalizar a barra de ferramentas.