【CXX-Qt】2.3 类型

CXX-Qt 支持大多数 CXX 支持的类型。这些类型可以用于属性、可调用方法和信号中。

cxx-qt-lib 类型

cxx-qt-lib crate 提供了常见 Qt 类型的 CXX 绑定。

使用 cxx-qt-lib 文档 来探索可用的类型。

容器类型

cxx-qt-lib crate 提供了容器类型,例如 QSet。

要使用这些类型,请在 CXX 桥接中定义一个模板化类型,但请注意,类型名称必须为 QSet_T,因为这需要与 C++ 代码中的名称匹配。

例如,对于 QSet,类型名称应为 QSet_i32。

rust 复制代码
unsafe extern "C++" {
    include!("cxx-qt-lib/qset.h");
    type QSet_i32 = cxx_qt_lib::QSet<i32>;
}

对于基于键值的容器类型(如 QHash<K, V>),需要在 Rust 端定义一个中间类型,以便为键值组合实现 trait。

与其他容器类型一样,类型名称必须为 QHash_K_V,因为这需要与 C++ 代码中的名称匹配。

例如,对于 QHash<QString, QVariant>,定义一个名为 QHashPair_QString_QVariant 的中间类型。然后使用类型名称 QHash_QString_QVariant 来匹配 C++ 端。

rust 复制代码
unsafe extern "C++" {
    include!("cxx-qt-lib/qhash.h");
    type QHash_QString_QVariant = cxx_qt_lib::QHash<cxx_qt_lib::QHashPair_QString_QVariant>;
}

请注意,可以通过在 Rust 中使用匹配的类型(例如 QMap<QString, QVariant>)来使用类型别名(如 QVariantMap)。

定义自定义类型

任何有效的 CXX 类型都应该可以与 CXX-Qt 一起使用。

请注意,适用与 CXX 相同的规则,因此类型必须是可平凡传递的。如果它们是不透明类型,则必须使用引用或指针。

有关如何包装 Qt 对象的示例,请参阅 cxx-qt-lib 源代码。

在容器或 QVariant 中使用自定义类型

要在容器中使用自定义类型,请找到容器使用的 trait。例如,对于 QSet,有一个 QSetElement trait;对于 QHash<K, V>,有一个 QHashPair trait。

为你的自定义类型实现相应的 trait,然后就可以像上面描述的那样使用容器。

要在 QVariant 中使用自定义类型,请为你的自定义类型实现 QVariantValue trait,如下所示,然后就可以正常使用了。

rust 复制代码
impl cxx_qt_lib::QVariantValue for ffi::CustomStruct {
    fn can_convert(variant: &cxx_qt_lib::QVariant) -> bool {
        ffi::qvariant_can_convert_custom_type(variant)
    }

    fn construct(value: &Self) -> cxx_qt_lib::QVariant {
        ffi::qvariant_construct_custom_type(value)
    }

    fn value_or_default(variant: &cxx_qt_lib::QVariant) -> Self {
        ffi::qvariant_value_or_default_custom_type(variant)
    }
}

在 qml_features 类型示例 中展示了如何使用 QVariant 实现自定义结构体的完整示例。

此外,任何 C++ 中的自定义类型或别名都应使用 qRegisterMetaType("TYPE") 在 Qt 中注册,以确保它们可以与 QML 一起使用。

相关推荐
kk哥889910 分钟前
C++ 对象 核心介绍
java·jvm·c++
helloworddm11 分钟前
WinUI3 主线程不要执行耗时操作的原因
c++
无能者狂怒1 小时前
YOLO C++ Onnx Opencv项目配置指南
c++·opencv·yolo
集智飞行1 小时前
c++函数传参的几种推荐方式
开发语言·c++
点云SLAM3 小时前
C++ Template(模板)解读和模板报错如何“逆向阅读”定位
c++·c++20·c++模版·c++高级应用·c++模版报错定位
明洞日记3 小时前
【数据结构手册008】STL容器完全参考指南
开发语言·数据结构·c++
农夫山泉2号4 小时前
【c++】——c++编译的so中函数有额外的字符
java·服务器·c++
水煎包V:YEDIYYDS8884 小时前
QT QML 实现的摇杆按钮,类似王者荣耀 左边方向导航键
qt·qml·摇杆按钮·导航键
仰泳的熊猫4 小时前
1077 Kuchiguse
数据结构·c++·算法·pat考试
WolfGang0073215 小时前
代码随想录算法训练营Day48 | 108.冗余连接、109.冗余连接II
数据结构·c++·算法