我创建了一个带有许多彩色按钮的 Touch Bar。用户通常会使用按钮更改颜色。当一个按钮被按下时,当前窗口的一些图形元素会随着按钮的颜色而改变。我希望在按钮之间滑动手指,元素会改变它们的颜色,而不必等待“内部修饰”事件。
有没有快速的方法来做到这一点?
编辑:我认为这样做的一种方法是使用类型为 momentaryPushIn 的按钮或创建一个子类化按钮并处理类似“触摸内部”事件的类。
我更喜欢第一种方法,但我发现文档很差。
我创建了一个带有许多彩色按钮的 Touch Bar。用户通常会使用按钮更改颜色。当一个按钮被按下时,当前窗口的一些图形元素会随着按钮的颜色而改变。我希望在按钮之间滑动手指,元素会改变它们的颜色,而不必等待“内部修饰”事件。
有没有快速的方法来做到这一点?
编辑:我认为这样做的一种方法是使用类型为 momentaryPushIn 的按钮或创建一个子类化按钮并处理类似“触摸内部”事件的类。
我更喜欢第一种方法,但我发现文档很差。
由于您在这里批准了 Scrubber 解决方案,因此它是:
首先,您需要创建 NSScrubber 实例并将其插入到您的触摸栏中。确保选择模式是固定的。
yourScrubber.mode = .fixed
然后为了突出显示(只是为了看到轮廓是眼睛,没有这个轮廓显示一切都会正常工作)将选择叠加样式设置为 .outlineOverlay。
youtScrubber.mode = .selectionBackgroundStyle = .outlineOverlay
接下来为数据源和选择事件设置委托。
yourScrubber.delegate = self
yourScrubber.dataSource = self
然后在洗涤器中返回项目数量
public func numberOfItems(for scrubber: NSScrubber) -> Int {
return 8
}
现在您需要插入项目(NSScrubberItemView)。也可以填充NSScrubberImageItemView或NSScrubberTextItemView甚至你的自定义 NSView。
有很多方法可以填充 Scrubber 的内容,为了方便您提供图像,它看起来像这样:
public func scrubber(_ scrubber: NSScrubber, viewForItemAt index: Int) -> NSScrubberItemView {
let itemView = scrubber.makeItem(withIdentifier: "colorIdentifier", owner: nil) as! NSScrubberImageItemView
itemView.image = yourImage
return itemView
}
现在您应该能够看到类似这样的内容:(我使用随机图像作为我的洗涤器)
好的,现在最重要的部分,如何获得您想要的效果:(使用委托协议方法)
public func scrubber(_ scrubber: NSScrubber, didHighlightItemAt highlightedIndex: Int) {
print("highlight = \(highlightedIndex)")
//your code here
}
您还可以在定义单元格宽度的单元格之间添加间距:
func scrubber(_ scrubber: NSScrubber, layout: NSScrubberFlowLayout, sizeForItemAt itemIndex: Int) -> NSSize {
return NSSize(width: yourWidth, height: 30)
}
也许你会发现用于:
optional public func scrubber(_ scrubber: NSScrubber, didSelectItemAt selectedIndex: Int)