1

我正在将 TouchBar 支持集成到我的应用程序中。我使用了 Rey Wenderlich 的方法并实现了如下所有内容:

如果self.touchBarArray被填满,则makeTouchBar()方法返回 NSTouchBar 对象。如果我打印出一些测试,则该identifiers对象已填充并且可以正常工作。

不起作用的是该makeItemForIdentifier方法没有被触发。所以项目不会被创建并且 TouchBar 仍然是空的。

奇怪的行为:如果我print(touchBar)在返回 NSTouchBar 对象之前添加一个断点,它会起作用,并且 TouchBar 会按应有的方式呈现(makeItemForIdentifier函数也会被触发)。即使它在几秒钟后消失……也很奇怪。

@available(OSX 10.12.2, *)
extension ViewController: NSTouchBarDelegate {
    override func makeTouchBar() -> NSTouchBar? {
        if(self.touchBarArray.count != 0) {
            let touchBar = NSTouchBar()
            touchBar.delegate = self
            touchBar.customizationIdentifier = NSTouchBarCustomizationIdentifier("com.TaskControl.ViewController.WorkspaceBar")
            var identifiers: [NSTouchBarItemIdentifier] = []
            for (workspaceId, _) in self.touchBarArray {
                identifiers.append(NSTouchBarItemIdentifier("com.TaskControl.ViewController.WorkspaceBar.\(workspaceId)"))
            }
            touchBar.defaultItemIdentifiers = identifiers
            touchBar.customizationAllowedItemIdentifiers = identifiers
            return touchBar
        }
        return nil
    }

    func touchBar(_ touchBar: NSTouchBar, makeItemForIdentifier identifier: NSTouchBarItemIdentifier) -> NSTouchBarItem? {
        if(self.touchBarArray.count != 0) {
            for (workspaceId, data) in self.touchBarArray {
                if(identifier == NSTouchBarItemIdentifier("com.TaskControl.ViewController.WorkspaceBar.\(workspaceId)")) {
                        let saveItem = NSCustomTouchBarItem(identifier: identifier)
                        let button = NSButton(title: data["name"] as! String, target: self, action: #selector(self.touchBarPressed))
                        button.bezelColor = NSColor(red:0.35, green:0.61, blue:0.35, alpha:1.00)
                        saveItem.view = button
                        return saveItem
                }
            }
        }
        return nil
    }
}
4

1 回答 1

1

self.view.window?.makeFirstResponder(self)viewDidLoad()确实解决了问题。

于 2019-10-24T23:00:34.640 回答