【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 一起使用。

相关推荐
墨韵流芳28 分钟前
CCF-CSP第41次认证第三题——进程通信
c++·人工智能·算法·机器学习·csp·ccf
hz_zhangrl34 分钟前
CCF-GESP 等级考试 2026年3月认证C++五级真题解析
c++·青少年编程·程序设计·gesp·c++五级·gesp2026年3月·gesp c++五级
Σίσυφος190036 分钟前
C++ 多肽经典面试题
开发语言·c++·面试
crescent_悦2 小时前
C++:The Largest Generation
java·开发语言·c++
paeamecium3 小时前
【PAT甲级真题】- Student List for Course (25)
数据结构·c++·算法·list·pat考试
cpp_learners4 小时前
银河麒麟V10+飞腾FT-2000/4处理器+QT源码静态编译5.14.2指南
开发语言·qt
十里平湖满秋霜5 小时前
RUST基础语法--数据类型
rust
GIS阵地5 小时前
QgsProviderMetadata 详解(基于 QGIS 3.40.13 API)
数据库·qt·arcgis·oracle·gis·开源软件·qgis
c++逐梦人5 小时前
C++11——— 包装器
开发语言·c++
十年编程老舅6 小时前
Linux 多线程高并发编程:读写锁的核心原理与底层实现
linux·c++·linux内核·高并发·线程池·多线程·多进程