Qt QML

Qt QML 模块为开发应用程序和库提供框架,采用 QML 语言 。它定义并实现语言和引擎基础设施,还提供使应用程序开发人员能够采用自定义类型扩展 QML 语言和采用 JavaScript C++ 集成 QML 代码的 API。Qt QML 模块提供 QML API C++ API .

注意,虽然 Qt QML 模块为 QML 应用程序提供了语言和基础设施,但 Qt Quick 模块为构建用户界面提供了更多视觉组件、模型 视图支持、动画框架、等。

If you're new to QML and Qt Quick, see QML 应用程序 了解编写 QML 应用程序的介绍。

使用模块

QML API

模块的 QML 类型是可用的透过 QtQml 导入。要使用类型,添加以下 import 语句到 .qml 文件:

import QtQml
					

C++ API

使用 Qt 模块的 C++ API 要求直接 (或透过其它依赖) 链接到模块库。几个构建工具对此有专用支持,包括 CMake and qmake .

构建采用 CMake

使用 find_package() 命令定位所需模块组件在 Qt6 包:

find_package(Qt6 REQUIRED COMPONENTS Qml)
target_link_libraries(mytarget PRIVATE Qt6::Qml)
					

更多细节,见 构建采用 CMake 概述。

要为非 QML 库提供外来 QML 类型支持,请定位 QmlIntegration 模块如下:

find_package(Qt6 REQUIRED COMPONENTS QmlIntegration)
target_link_libraries(mytarget PRIVATE Qt6::QmlIntegration)
					

qt6_generate_foreign_qml_types 了解细节。

采用 qmake 构建

要配置采用 qmake 构建模块,添加模块作为值为 QT 变量在工程的 .pro 文件:

QT += qml
					

QML 和 QML 类型

Qt QML 模块包含 QML 框架和用于应用程序的重要 QML 类型。QML 构造的描述在 QML 参考 .

除了 QML 值类型 ,模块带有以下 QML 对象类型:

The Qt 全局对象为各种 QML 类型提供有用枚举和函数。

列表和模型

从 Qt 5.1 起,将模型类型移到子模块 QtQml.Models Qt QML Models 页面有更多信息。

QML 应用程序 JavaScript 环境

JavaScript 表达式允许 QML 代码包含应用程序逻辑。Qt QML 提供在 QML 和从 C++ 运行 JavaScript 表达式的框架。

这些章节来自 QML 参考 .

C++ 应用程序集成 QML

模块还提供运行 QML 应用程序的框架。QML 框架允许 QML 代码包含 JavaScript 表达式并允许 QML 代码与 C++ 代码进行交互。

文章和指南

教程

许可和归属

Qt QML 在商业许可下是可用的来自 Qt 公司 。此外,它在自由软件许可下也是可用的。从 Qt 5.4 起,这些自由软件许可是 GNU LGPL (次一般公共许可) 第 3 版 ,或 GNU GPL (一般公共许可) 第 2 版 。见 Qt 许可 进一步了解细节。

Furthermore Qt QML in Qt 6.5.1 may contain third party modules under following permissive licenses:

JavaScriptCore 宏汇编程序 BSD 2 条款简化许可

用于编写 QML 应用程序的进一步信息:

参考