Относительно: Методы NSMenuDelegate, не вызываемые для контекстного меню мой делегат для представления не вызывается, когда он становится видимым.
newWindowMenuItem
Заголовок, который я хочу динамически переключатьв зависимости от ключевого модификатора.
func menuWillOpen(_ menu: NSMenu) {
guard newWindowMenuItem.title != "close" else {
return
}
newWindowMenuItem.title = (appDelegate.shiftKeyDown) ? "Tab" : "Window"
menu.update()
}
func menuDidClose(_ menu: NSMenu) {
if menu == newWindowMenuItem.menu {
newWindowMenuItem.title = "closed"
}
}
func menu(_ menu: NSMenu, willHighlight item: NSMenuItem?) {
if let currentEvent = NSApp.currentEvent, item == newWindowMenuItem {
let flags = currentEvent.modifierFlags
newWindowMenuItem.title = (flags.contains(.command)) ? "Tab" : "Window"
menu.update()
Swift.print("title \(newWindowMenuItem.title)")
}
}
Зарегистрирован в viewDidLoad () как
NotificationCenter.default.addObserver(
self,
selector: #selector(WebViewController.shiftKeyDown(_:)),
name: NSNotification.Name(rawValue: "shiftKeyDown"),
object: nil)
Я пытаюсь позволить пользователю динамически изменять пункты меню - в основном заголовки, когда модификаторнажата.Поскольку это происходит после отрисовки меню, использование menuWillOpen () не представляется целесообразным, так как в противном случае они могли бы нажать модификатор - кроме CTRL до его отрисовки.
Я думал вообще пропустить делегат -так как я не читаю подходящий метод для изменения ключевых модификаторов для своих нужд, и вместо этого, чтобы монитор изменений воздействовал на изменения:
internal func shiftKeyDown(_ notification : Notification) {
let shiftKeyDown : NSNumber = notification.object as! NSNumber
Swift.print(String(format: "shift %@", shiftKeyDown.boolValue ? "v" : "^"))
guard webView.menu != nil else {
return
}
newWindowMenuItem.title = shiftKeyDown.boolValue ? "Tab" : "Window"
newWindowMenuItem.menu?.update()
}
, но это никогда не вызывается, или ключевое событие, отображение пост-менюпредположить, что мой подход неверен?