1

我使用 Xcode 10.1(我相信是 Swift 4.2)开发了这个应用程序,工具栏看起来不错:

在此处输入图像描述

但是我移植到我的 Xcode 11.6(我相信是 Swift 5.2),现在工具栏上最右边的项目不再位于最右边:

在此处输入图像描述

在移植之前,我添加了加号按钮 - 复选框(显示隐藏)是第一个项目之一,此后从未更改过。按钮也按预期工作 - 他们的动作可以触发。注意:这个应用程序不使用故事板或 IB 的东西。

由于我的代码拆分为多个文件(包含许多不相关的代码),因此我将进行概述。

class ToolbarController: NSObject, NSToolbarDelegate {

let toolbar = NSToolbar(identifier: NSToolbar.Identifier("toolbar"))
lazy var toolbarItem1: NSToolbarItem = {
    let toolbarItem = NSToolbarItem(itemIdentifier: NSToolbarItem.Identifier(rawValue: "Btn1"))
    let button = NSButton(frame: NSRect(x: 0, y: 0, width: 40, height: 1))
    button.target = self
   ...
    toolbarItem.view = button
    return toolbarItem
}() // defined as "lazy" to allow "self"
var toolbarItemSpace: NSToolbarItem = {
    let toolbarItem = NSToolbarItem(itemIdentifier: NSToolbarItem.Identifier.space)
    return toolbarItem
}()
 ...
var toolbarItemFlexSpace: NSToolbarItem = {
    let toolbarItem = NSToolbarItem(itemIdentifier: NSToolbarItem.Identifier.flexibleSpace)
    return toolbarItem
}()
lazy var toolbarItemShowHidden: NSToolbarItem = {
    let toolbarItem = NSToolbarItem(itemIdentifier: NSToolbarItem.Identifier(rawValue: "Checkbox"))
    let box = NSBox(frame: NSRect(x: 0, y: 0, width: 120, height: 40))
    let button = NSButton() // put in NSBox to use isolated action
  ...
    button.target = self
    box.contentView = button
    box.sizeToFit() // tightly fit the contents (button)
    toolbarItem.view = box
    return toolbarItem
}()
lazy var tbItems: [NSToolbarItem] = [toolbarItem1, ...]

该类定义工具栏、添加项目、实现所有这些工具栏(委托)方法并使其成为委托。然后我的 NSWindowController 将其设置为应用程序工具栏。

任何人都可以看到导致上述问题的我的代码问题吗?否则,这是一个错误吗?

4

2 回答 2

1

与 Swift 5.0 有同样的问题......即使文档说 minSize 和 maxSize 已被弃用,我解决了这个问题:

let toolbarItem = NSToolbarItem(itemIdentifier: NSToolbarItem.Identifier.flexibleSpace)
toolbarItem.minSize = NSSize(width: 1, height: 1)
toolbarItem.maxSize = NSSize(width: 1000, height: 1) //just some large value
return toolbarItem

也许这也适用于 Swift 5.2

于 2021-07-06T07:14:45.390 回答
1

找到了一种无需警告且不使用已弃用属性的方法。

我们预先为 NASToolbarItem 创建了一个带有最小/最大约束的透明子视图,因此系统可以自行计算最小和最大尺寸。

let toolbarItem = NSToolbarItem(itemIdentifier: NSToolbarItem.Identifier.flexibleSpace)

// view to be hosted in the flexible space toolbar item
let view = NSView(frame: CGRect(origin: .zero, size: CGSize(width: MIN_TOOLBAR_ITEM_W, height: MIN_TOOLBAR_H)))
view.widthAnchor.constraint(lessThanOrEqualToConstant: MAX_TOOLBAR_ITEM_W).isActive = true
view.widthAnchor.constraint(greaterThanOrEqualToConstant: MIN_TOOLBAR_ITEM_W).isActive = true

// set the view and return
toolbarItem?.view = view
return toolbarItem
于 2021-12-13T12:34:33.203 回答