在 NSViewControllerRepresentable 中将 SwiftUI 协调器与 NSTableView 结合使用?

问题描述 投票:0回答:1

我在 SwiftUI 中开发了一个 macOS 个人理财应用程序,它通过 SwiftUI 和 AppKit 之间的

NSViewControllerRepresentable
接口使用 NSTableViews 和 NSOutlineViews。

我发现 AppKit 视图功能远远优于我使用 SwiftUI 列表创建的任何东西,而且它们运行速度更快并支持 TypeSelect。将数据传递到 Appkit ViewControllers 很简单,但获取信息似乎没那么简单。

Apple 开发人员文档建议我应该使用

Coordinator
类,我尝试这样做但无济于事。我需要的委托方法 (
func tableViewSelectionDidChange(_ notification: Notification)
) 无法运行(从我的
Coordinator
类中)。

目前,我正在使用

NotificationCenter.default
交换数据和操作,效果很好,但我热衷于使用“官方”方法。我找到了一个成功使用 Coordinator 的 macOS 应用程序(在 https://www.markusbodner.com/til/2021/02/08/multi-line-text-field-with-swiftui-on-macos/),但是我无法让我的
Coordinator
类作为
NSTableViewDelegate
工作,即使它构建和运行没有错误(Xcode 12.4)。

我一开始想要做的就是获得一个包含

NSViewController
NSTableView
,只要用户在 NSTableView 中选择一个新行,就可以通过
NSTableView.selectedRow
Coordinator
传递到其父 SwiftUI 视图中。谁能帮忙(如果可能的话,请提供一些示例代码)?

macos swiftui nstableview coordinator-pattern nsviewcontrollerrepresentable
1个回答
0
投票

我似乎找到了解决我自己问题的方法。我一直在

NSTableViewDelegate
功能中将我的
makeNSViewController
分配给协调员。但是,在填充我的
NSTableView
NSTableView
内容的代码运行之前(在
NSTableViewDataSource
函数中),我的
updateNSViewController
似乎没有被实例化。结果没有
NSTableViewDelegate
分配。

tableVC.tableView?.delegate = context.coordinator
移动到
updateNSViewController
函数中,按照填充我的
NSTableViewDataSource
内容的代码,使我的
NSTableViewDelegate
按预期工作,并且
tableView.selectedRow
值现在通过
func tableViewSelectionDidChange(_ notification: Notification)
传递到我的父 SwiftUI 视图成功地。欢呼!

注意到我在

NSTableView
中使用 Cocoa 绑定可能很有用,并且发现有必要在 ViewController(文件所有者)并将这些函数的副本(当然是用代码填充)放在我的 Coordinator 类中,以使它们的代码按预期执行。
生成的整体代码比我的旧代码简洁得多,它使用通知在 SwiftUI 和 AppKit 之间传递操作和数据 - 所以“官方”方法看起来是最好的。

最新问题
© www.soinside.com 2019 - 2024. All rights reserved.