Podejście 1:
Odbywa się to poprzez dodanie akcesorium paska tytułu. Udało mi się to zrobić, modyfikując plik AppDelegate.swift. Musiałem zastosować jakieś dziwne wypełnienie, aby wyglądało dobrze.
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(""))
}
}
Wynik:
Podejście 2 (metoda alternatywna):
Chodzi o to, aby zrobić część paska narzędzi za pomocą scenorysu, a resztę aplikacji za pomocą SwiftUI. Odbywa się to poprzez utworzenie nowej aplikacji z storyboardem jako interfejsem użytkownika. Następnie przejdź do scenorysu i usuń domyślny kontroler widoku i dodaj nowy NSHostingController
. Połącz nowo dodany kontroler hostingu z głównym oknem, ustawiając jego relację. Dodaj pasek narzędzi do okna za pomocą konstruktora interfejsów.
Dołącz niestandardową klasę do NSHostingController
i załaduj do niej swój widok SwiftUI.
Przykładowy kod poniżej:
import Cocoa
import SwiftUI
class HostingController: NSHostingController<SwiftUIView> {
@objc required dynamic init?(coder: NSCoder) {
super.init(coder: coder, rootView: SwiftUIView())
}
}
Korzystanie z tego podejścia daje również możliwość dostosowania paska narzędzi.