Qt QML 模块及其函数详解

Qt CoreQt Widgets 不同,QML 是一种声明式语言 ,主要关注 UI 的外观和行为,而不是传统的 C++ 代码流。因此,在 Qt QML 模块中,我们讨论的"函数"分为两个主要部分:

  1. C++ 端的核心类和函数: 这些函数负责加载、执行 QML 代码并实现 C++ 和 QML 之间的通信。
  2. QML 语言内部的函数和方法: 这些是 QML 元素本身提供的方法(Methods)和 JavaScript 函数。

🌟 I. C++ 端:Qt Qml 模块的核心类和函数

这些类属于 <QtQml> 模块,是 QML 引擎在 C++ 端的工作基础。

核心类 (Class) 功能描述 常用函数 (Function) 及作用
QQmlEngine QML 执行环境的核心。 管理组件缓存、网络访问、以及 QML 脚本的执行。 QQmlEngine::load(const QUrl &url) : 加载 QML 文件并创建根组件。返回 QObject 指针。 QQmlEngine::rootContext() : 返回 QQmlContext 对象,用于在 C++ 中设置全局变量 供 QML 访问。 QQmlEngine::trimComponentCache(): 清理已加载的组件缓存,释放内存。
QQmlComponent QML 组件的封装。 用于将 QML 文件编译成可实例化的对象。 QQmlComponent::create() : 实例化 已加载的 QML 组件,返回 QObject 指针。 QQmlComponent::loadUrl(): 异步加载 QML 源文件。
QQmlContext QML 上下文环境。 用于将 C++ 数据模型、对象和值暴露给 QML。 QQmlContext::setContextProperty(const QString &name, QObject *value) : 将 C++ 对象(或 QVariant)暴露给 QML,QML 中可通过 name 访问。 QQmlContext::parentContext(): 获取父级上下文。
QQmlApplicationEngine Qt Quick 应用程序的入口。 继承自 QQmlEngine,并简化了主 QML 文件的加载。 QQmlApplicationEngine::load(const QUrl &url): 简化加载 QML 文件为应用程序的根组件,自动设置上下文。
QQuickView 在 C++ 窗口中显示 QML 场景。 (属于 Qt Quick 模块,但与 QML 引擎紧密相关)。 QQuickView::setSource(const QUrl &url) : 设置要显示的 QML 文件路径。 QQuickView::show(): 显示包含 QML 场景的窗口。

🚀 II. QML 语言内部的函数和方法 (QML Methods)

在 QML 内部,"函数"通常是特定 QML 元素提供的 方法 (Methods) ,或是 QML 中直接编写的 JavaScript 函数

A. 基础元素方法 (Qt Quick Module)

这些方法是 QML 的基石,用于控制 UI 元素的行为。

QML 元素 核心方法 (Method) 作用描述
Item Item::x, Item::y : 属性,设置位置。 Item::width, Item::height : 属性,设置大小。 Item::parent: 属性,访问父元素。
State State::changes : 属性,定义在进入此状态时属性如何变化。 State::onEntry / onExit: JavaScript 块,在进入/退出状态时执行代码。
Component Component::createObject(parent, properties): 动态创建组件实例的方法。
MouseArea 信号 clicked() : 鼠标点击时发射。 MouseArea::contains(point): 检查给定点是否在区域内。
Timer Timer::start() / stop() : 启动和停止定时器。 信号 triggered(): 定时器到期时发射。

B. 高级功能模块方法 (Qt Quick Controls, etc.)

QML 元素 核心方法 (Method) 作用描述
Loader Loader::setSource(url) : 运行时动态加载另一个 QML 文件。 Loader::item : 属性,访问加载的组件实例(QObject*)。
ListView / GridView ListView::positionViewAt(index, mode) : 滚动视图,将指定索引的项定位到特定位置。 ListView::positionViewToBeginning(): 滚动到列表开头。
StackView StackView::push(url) : 将新页面推入栈顶,通常伴随动画。 StackView::pop(): 弹出栈顶页面,返回到上一个页面。
Connections on<SignalName>: 专用槽,用于连接到非父子关系对象的信号。

C. JavaScript 内建函数和 QML 全局函数

在 QML 的属性绑定或信号处理块中,可以直接使用标准 JavaScript 函数或 QML 提供的全局函数。

函数名 描述 作用
qsTr(string) 翻译函数。 用于标记字符串进行翻译(使用 Qt Linguist)。 text: qsTr("Hello")
console.log() 调试输出。 在 C++ 端输出调试信息(等同于 qDebug())。 onClicked: console.log("Button clicked")
Date() JavaScript 内建。 用于创建和操作日期/时间对象。 var d = new Date()
Math.random() / Math.round() JavaScript 内建。 用于数学计算。 N/A

💡 总结:QML 编程的核心模式

QML 模块中的"函数"重点在于实现 C++ 和 QML 之间的桥梁 以及 QML 内部的交互逻辑

  1. C++ 调用 QML: C++ 使用 QQmlEngine 加载 QML 文件,然后通过 QObject::findChild() 获取 QML 对象,并调用其方法。
  2. QML 调用 C++: C++ 通过 QQmlContext::setContextProperty() 将 C++ 对象暴露给 QML,QML 直接调用该 C++ 对象的公共槽函数或方法。
  3. QML 内部交互: QML 元素之间通过属性绑定、状态机和信号/槽机制进行通信,核心逻辑常在 onClicked 等信号处理块中以 JavaScript 函数的形式实现。
相关推荐
知远同学11 小时前
Anaconda的安装使用(为python管理虚拟环境)
开发语言·python
小徐Chao努力11 小时前
【Langchain4j-Java AI开发】09-Agent智能体工作流
java·开发语言·人工智能
CoderCodingNo12 小时前
【GESP】C++五级真题(贪心和剪枝思想) luogu-B3930 [GESP202312 五级] 烹饪问题
开发语言·c++·剪枝
kylezhao201912 小时前
第1章:第一节 开发环境搭建(工控场景最优配置)
开发语言·c#
啃火龙果的兔子12 小时前
JavaScript 中的 Symbol 特性详解
开发语言·javascript·ecmascript
热爱专研AI的学妹12 小时前
数眼搜索API与博查技术特性深度对比:实时性与数据完整性的核心差异
大数据·开发语言·数据库·人工智能·python
Mr_Chenph13 小时前
Miniconda3在Windows11上和本地Python共生
开发语言·python·miniconda3
阿狸远翔13 小时前
Protobuf 和 protoc-gen-go 详解
开发语言·后端·golang
永远前进不waiting13 小时前
C复习——1
c语言·开发语言
伯明翰java13 小时前
Java数据类型与变量
java·开发语言