寻找 C++ 到 WPF/Cocoa 互操作性的跨平台、端到端示例

Posted

技术标签:

【中文标题】寻找 C++ 到 WPF/Cocoa 互操作性的跨平台、端到端示例【英文标题】:Looking for a cross-platform, end-to-end example of C++ to WPF/Cocoa interoperability 【发布时间】:2012-07-03 02:29:11 【问题描述】:

首先,一些背景:

我决定开始一个新项目,该项目从头开始设计,可在多个平台(Windows、ios、OSX、Linux、android)上运行。由于我的背景主要是 C++,因此我打算使用 C++11 编写核心功能。话虽如此,在每个平台上,我都需要编写一个特定于平台的 UI,它可以与 C++ 核心进行互操作。

我定位的第一个平台是 Windows(第二个是 iOS)。我将存储在 SQLite 数据库中的数据以及将使用 WPF DataGrid 输入的用户提供的数据(插入行、操作现有数据等)。这是我第一次使用 WPF(尽管我使用过 Windows 窗体),也是我第一次在托管环境中使用 C++。我打算把它做成一个 MVC 风格的架构,所以我认为 SQLite 是模型,WPF 是视图,C++ 代码是控制器。

我的问题是这样的:

是否有任何示例说明如何从 C++ 接口获取数据并使用 C# 和 WPF 显示它而不破坏/修改 C++ 代码本身(因为它必须在多个平台上工作)?我已经阅读了一些关于 P/Invoke(乏味,但有效)和混合程序集(有效,但会破坏我的 C++?)的内容,但在具体示例(尤其是那些涉及填充 WPF 控件的示例)方面,Google 并没有提供帮助通过 C++ DLL 获得的数据)。

谢谢!

编辑:在寻找解决这个问题的方法时,我遇到了 CXXI。我对它不是很熟悉,但似乎它可能是解决我问题的简单方法。有什么想法吗?我对所有这些概念的掌握有限。

【问题讨论】:

我没有任何 WPF 经验,但我可以告诉你,你正在做的事情会有些困难。当您使用 OS X 应用程序时(我相信 iOS 也是如此),您将不得不编写大量的 Objective-C 代码。我认为这在很大程度上取决于您正在制作的应用程序的性质,但您基本上必须为每个平台重新编写大部分内容。 感谢您的意见哈桑。我知道我有很多工作要做,但我的目标是为每个平台本地编写 UI。我觉得这提供了最好的用户体验和最好的学习体验:) 你说得对,它确实提供了最好的用户体验。如果 UI 中最难的部分是表格,那么我会说你的状态很好。我希望现在有人真的回答... 我认为是。无论如何,我相信我可以在大多数平台上使用现有的小部件。如果您也对答案感兴趣,请随时投票;-) 我还在玩弄东西。当我有有用的东西时,我会回帖。 :) 【参考方案1】:

在使用过 XAML 和 WinForms 之后,我认为您不会觉得 WPF 比您的 WinForms 体验更“原生”。在这两种情况下,一切都由 .Net 抽象。但是如果你想学习 WPF,那就去吧。

P\invoke 和 COM 一样工作得很好。至于将数据从 C++ 获取到其他语言的其他方法,请考虑将其视为 IPC 问题而不是语言问题。将一个进程作为另一个进程的子进程运行,并查看sockets 和诸如0mq/clrzmq (see this for 0mq on iPhone--this for Android) 和Thrift 之类的库,以使C++ 与另一个进程对话。

使用 sockets/0mq,您可以使用 xml/json/Protobuf/Protobuf-net 将对象从一种语言序列化和反序列化到另一种语言。使用 Protobuf,您只需要创建一组 json-esque 数据对象并使用特定于语言的工具来生成代码。这将跨平台和语言处理您的数据对象,让您专注于有趣的事情。序列化也可以很好地与 sql 一起使用。所有这些技术都易于实现,并且每种技术都有一定的语言实现,使得将事物连接到您的下一个 GUI 变得很简单。

关于示例,这完全取决于您希望如何在运行时之间移动数据。

【讨论】:

您是否建议 WinForms 可能更容易?我只是假设 WPF DataGrid 最容易使用。我真的很喜欢使用 IPC 的想法,但对于这个项目,我认为它过于复杂和矫枉过正。不过谢谢你。很有意思。在这一点上,我仍然想找到一个不依赖外部代码的示例(至少在运行时)。 CXXI 看起来很有趣。 Winforms 比 WPF 容易得多。老实说,我认为最好将 Mono 用于桌面 GUI,但这是你的决定。 如果是我,我会选择 Mono 或其他一些跨平台的 GUI 抽象层,但这主要是因为我不喜欢 UI 工作;)。就是说,我很欣赏您通过了解跨平台的工作方式来尝试做的事情。也许您需要澄清“原生”的含义——您最有兴趣尝试不同的技术,还是最有兴趣深入了解每个操作系统的具体细节? 我只看了CXXI——看起来很棒。我已经有一段时间没有使用 Mono 了,它真的很受欢迎。 我还没有决定我将为这个项目采取哪条路线,但我会说这种方法在另一个项目上对我来说非常有效。 Protobuf 巧妙地解决了序列化问题,并且如您所述,C++ 和 C# 都有自动生成器。

以上是关于寻找 C++ 到 WPF/Cocoa 互操作性的跨平台、端到端示例的主要内容,如果未能解决你的问题,请参考以下文章

通过互操作将字符串数组从 C# 传递到 C++

Delphi 如何与 Detours 库互操作?

字符串数组 C# 与 C++ dll 的互操作性;从 C# 到 C++ dll 的字符串数组,它设置数据并将其发送回 c#

Swift 与 C++ 互操作性讨论

互操作性 java 和 c++ [关闭]

互操作性 java 和 c++ [关闭]