【发布时间】:2018-02-02 21:32:55
【问题描述】:
我没有使用任何 Storyboard/NIB,而是以编程方式创建所有 UI。
这是主窗口控制器:
class MainWindowController: NSWindowController, NSToolbarDelegate {
var toolbar: NSToolbar!
var segmentedControl: NSSegmentedControl!
override func loadWindow() {
self.window = NSWindow(contentRect: .init(origin: .zero, size: .init(width: 640, height: 480)),
styleMask: NSWindow.StyleMask(rawValue: (NSWindow.StyleMask.closable.rawValue | NSWindow.StyleMask.titled.rawValue | NSWindow.StyleMask.miniaturizable.rawValue | NSWindow.StyleMask.resizable.rawValue)),
backing: .buffered, defer: true)
}
override init(window: NSWindow?) {
super.init(window: window)
loadWindow()
self.window?.center()
self.segmentedControl = NSSegmentedControl(labels: ["1", "2", "3"], trackingMode: NSSegmentedControl.SwitchTracking.selectOne, target: self, action: #selector(switchTabs))
self.segmentedControl.setSelected(true, forSegment: 0)
self.toolbar = NSToolbar(identifier: .init("MainToolbar"))
self.toolbar.delegate = self
self.toolbar.displayMode = .iconOnly
self.window?.toolbar = self.toolbar
self.window?.contentViewController = MainSplitViewController()
}
required init?(coder: NSCoder) {
fatalError("init(coder:) has not been implemented")
}
// MARK: - Selectors
@objc func switchTabs(sender: Any) {
let segmentedControl = sender as! NSSegmentedControl
let tabVC = (self.window!.contentViewController as! MainSplitViewController!).tabViewController
tabVC.tabView.selectTabViewItem(at: segmentedControl.selectedSegment)
}
// MARK: - NSToolbarDelegate
func toolbarDefaultItemIdentifiers(_ toolbar: NSToolbar) -> [NSToolbarItem.Identifier] {
return [
NSToolbarItem.Identifier.init("Add"),
NSToolbarItem.Identifier.flexibleSpace,
NSToolbarItem.Identifier.init("NSSegmentedControl"),
NSToolbarItem.Identifier.flexibleSpace,
NSToolbarItem.Identifier.init("Search")
]
}
func toolbarAllowedItemIdentifiers(_ toolbar: NSToolbar) -> [NSToolbarItem.Identifier] {
return [
NSToolbarItem.Identifier.flexibleSpace,
NSToolbarItem.Identifier.init("NSSegmentedControl"),
NSToolbarItem.Identifier.init("Search"),
NSToolbarItem.Identifier.init("Add")
]
}
func toolbar(_ toolbar: NSToolbar, itemForItemIdentifier itemIdentifier: NSToolbarItem.Identifier, willBeInsertedIntoToolbar flag: Bool) -> NSToolbarItem? {
switch itemIdentifier {
case NSToolbarItem.Identifier.flexibleSpace:
return NSToolbarItem(itemIdentifier: itemIdentifier)
case NSToolbarItem.Identifier.init("NSSegmentedControl"):
let toolbarItem = NSToolbarItem(itemIdentifier: itemIdentifier)
toolbarItem.view = self.segmentedControl
return toolbarItem
case NSToolbarItem.Identifier.init("Search"):
let toolbarItem = NSToolbarItem(itemIdentifier: itemIdentifier)
let searchField = NSSearchField(frame: NSRect(origin: .zero, size: CGSize(width: 64, height: 64 )))
toolbarItem.view = searchField
return toolbarItem
case NSToolbarItem.Identifier.init("Add"):
let toolbarItem = NSToolbarItem(itemIdentifier: itemIdentifier)
let addButton = NSButton(title: "Add", target: self, action: nil)
toolbarItem.view = addButton
return toolbarItem
default:
return nil
}
}
}
我的窗口中嵌入了三个NSViewControllers 中的NSTabViewController。我希望能够将它们连接到我的NSToolbar 中的NSSegmentedControl 选择。
但是,action 永远不会被解雇。 switchTabs 方法永远不会被调用。如果我直接调用该函数,那么它可以工作!但是当我选择 NSSegmentedCell 时什么也没有发生。
这里出了什么问题?
我是否正确地实例化了窗口?我对loadWindow 的用法正确吗?
【问题讨论】:
-
我是一个 Obj-C 人——所以这可能是完全错误的——但我首先想到的是
#selector(switchTabs)(无参数)和func switchTabs(sender: Any)(一个参数)。 -
我也是这么想的。当我使用
#selector(switchTabs)并打印动作时(就像print(segmentedControl.action!),它产生:switchTabsWithSender:。当我使用#selector(switchTabs(sender:))时,它产生:switchTabsWithSenderWithSender:。我不知道这是否是问题所在,因为它们都不起作用。
标签: swift macos cocoa selector appkit