QT使用说明
QT环境准备
推荐Ubuntu平台上使用,配置简单,坑少。
Ubuntu 20.04
安装
sudo apt-get install qt5-default -y
sudo apt-get install qtcreator -y
sudo apt-get install -y libclang-common-8-dev
启动
qtcreator
HelloWorld
- 打开 Qt Creator。
- 选择 “New Project”。
- 选择 “Application” > “Qt Widgets Application”。
- 输入项目名称和位置,然后点击 “Next”。
- 选择合适的构建工具(例如, 默认的 Qt 版本),然后点击 “Next”。
- 点击 “Finish” 完成项目创建。
- 修改代码,mainwindow.cpp
- 选择菜单中的 “Build” > “Build Project” 来构建项目。
- 然后选择 “Run” > “Run Project” 来运行程序。
- 当你运行程序时,会看到一个窗口,窗口中央显示 “Hello, World!” 的文本。
文件结构
dd@dd-Virtual-Machine:~/work/workspace/helloworld$ tree
.
├── helloworld.pro
├── helloworld.pro.user
├── main.cpp
├── mainwindow.cpp
├── mainwindow.h
└── mainwindow.ui0 directories, 6 files
-
helloworld.pro:
- 这是 Qt 项目的项目文件,使用 Qt 的 qmake 工具进行构建。它包含了项目的配置信息,例如:
- 项目名称
- 需要的 Qt 模块(如
core
,gui
,widgets
等) - 源文件和头文件的列表
- 资源文件的路径
- 其他编译选项
- 该文件是用纯文本格式编写的,通常可以用任何文本编辑器打开和编辑。
示例内容:
TEMPLATE = app TARGET = helloworld QT += widgetsSOURCES += main.cpp \mainwindow.cppHEADERS += mainwindow.hFORMS += mainwindow.ui
- 这是 Qt 项目的项目文件,使用 Qt 的 qmake 工具进行构建。它包含了项目的配置信息,例如:
-
helloworld.pro.user:
- 这是 Qt Creator 自动生成的用户配置文件,包含了用户的本地设置,如打开的文件、窗口位置等。通常不需要手动编辑或关注这个文件,它的内容是特定于用户的。
-
main.cpp:
- 这是应用程序的入口点,包含
main()
函数。在此文件中,通常会创建QApplication
对象和主窗口,并启动事件循环。
示例内容:
#include <QApplication> #include "mainwindow.h"int main(int argc, char *argv[]) {QApplication a(argc, argv);MainWindow w;w.show();return a.exec(); }
- 这是应用程序的入口点,包含
-
mainwindow.cpp:
- 这个文件包含
MainWindow
类的实现代码。它通常会包括构造函数、析构函数以及其他槽函数的实现。
示例内容:
#include "mainwindow.h" #include "ui_mainwindow.h"MainWindow::MainWindow(QWidget *parent) :QMainWindow(parent),ui(new Ui::MainWindow) {ui->setupUi(this); }MainWindow::~MainWindow() {delete ui; }
- 这个文件包含
-
mainwindow.h:
- 这是
MainWindow
类的头文件,定义了类的接口,包括成员变量、构造函数、析构函数以及槽函数的声明。
示例内容:
#ifndef MAINWINDOW_H #define MAINWINDOW_H#include <QMainWindow>namespace Ui { class MainWindow; }class MainWindow : public QMainWindow {Q_OBJECTpublic:explicit MainWindow(QWidget *parent = nullptr);~MainWindow();private:Ui::MainWindow *ui; };#endif // MAINWINDOW_H
- 这是
-
mainwindow.ui:
- 这是 Qt Designer 生成的用户界面文件,采用 XML 格式,定义了应用程序的图形界面。你可以使用 Qt Designer 来可视化地创建和编辑这个文件。
- 这个文件描述了窗口中的控件(如按钮、标签、文本框等)及其属性。
示例内容(部分):
<ui version="4.0"><class>MainWindow</class><widget class="QMainWindow" name="MainWindow"><widget class="QWidget" name="centralWidget"><layout class="QVBoxLayout" name="verticalLayout"><item><widget class="QLabel" name="label"><property name="text"><string>Hello, World!</string></property></widget></item></layout></widget></widget> </ui>
快捷键
格式化代码:Ctrl+A:全选代码,Ctrl+i:格式化选中内容,Ctrl+s:保存文件,清除仅空格行
示例工程
helloworld.zip
Windows
安装
qt-unified-windows-x64-online.exe --mirror https://mirrors.ustc.edu.cn/qtproject
QT基础知识
在阅读WT智能柜QT APP过程中,收集APP中使用的QT知识,汇总到本文档内。
qApp
的含义
qApp
是一个全局指针,指向当前的应用程序对象。它是 QApplication
或 QGuiApplication
的一个实例。通过 qApp
,您可以访问应用程序的全局状态和功能。
processEvents()
的功能
processEvents()
方法的主要作用是处理事件队列中的所有待处理事件。这包括:
- 用户输入(例如,鼠标点击、键盘输入等)
- 定时器事件
- 绘图事件
- 系统事件
当您调用 qApp->processEvents();
时,Qt 会检查事件队列,如果有待处理的事件,它会执行这些事件的处理。这可以帮助保持应用程序的响应性。
使用场景,processEvents()
通常用于以下场景:
- 长时间运行的操作: 在执行耗时的操作(例如,文件处理或网络请求)时,应用程序可能会变得无响应。通过在长时间运行的操作中定期调用
processEvents()
,可以让应用程序保持响应,处理用户输入和更新界面。 - 进度更新: 在长时间操作的循环中,您可能希望更新进度条或其他 UI 元素。通过调用
processEvents()
,可以确保这些更新能够立即反映在用户界面上。
QObject
和父子关系
QObject
是 Qt 框架中的一个核心类,提供了对象的基本功能,包括信号和槽机制、事件处理等。- 在 Qt 中,父子关系用于管理对象的生命周期。当一个对象(子对象)的父对象被销毁时,所有其子对象也会被自动销毁。通过设置
parent
,可以确保内存管理的方便性和安全性。
示例:
HomeWgt::HomeWgt(QWidget *parent) :QWidget(parent),ui(new Ui::HomeWgt)
{bMange= new boxmange(this);sConfig= new SysConfig(this);
}
QTimer
的用法
QTimer
是 Qt 中非常实用的类,用于处理定时任务。通过调用 start()
方法,您可以启动或重新启动定时器,让它在指定的时间间隔内定期发射 timeout()
信号,并执行相应的槽函数。使用 QTimer
可以帮助您轻松管理时间相关的任务,保持应用程序的响应性。
1. QTimer 的基本使用方式
要使用 QTimer
,您通常需要执行以下步骤:
- 创建一个
QTimer
对象。 - 连接定时器的
timeout()
信号到一个槽(slot)函数。 - 调用
start()
方法来启动定时器。
示例代码
下面是一个简单的示例,展示了如何使用 QTimer
:
cpp#include <QApplication>
#include <QWidget>
#include <QTimer>
#include <QLabel>class MyWidget : public QWidget {Q_OBJECTpublic:MyWidget() {label = new QLabel("0", this);label->setAlignment(Qt::AlignCenter);setFixedSize(200, 100);timer = new QTimer(this);connect(timer, &QTimer::timeout, this, &MyWidget::updateLabel);timer->start(1000); // 每1000毫秒(1秒)触发一次timeout信号}private slots:void updateLabel() {count++;label->setText(QString::number(count));}private:QTimer *timer;QLabel *label;int count = 0;
};int main(int argc, char *argv[]) {QApplication app(argc, argv);MyWidget w;w.show();return app.exec();
}#include "main.moc" // 需要包含这个,以支持信号和槽的实现
2. start() 方法的作用
- 启动定时器:
start(int msec)
方法用于启动定时器,msec
参数指定了定时器的时间间隔(以毫秒为单位)。当定时器启动后,timeout()
信号将每隔指定的时间间隔发射一次。 - 重新启动定时器: 如果定时器已经在运行,调用
start()
方法会重新启动定时器,重置计时器的时间间隔。也就是说,定时器会在新的时间间隔开始计时。 - 定时器的精度:
QTimer
的精度通常是毫秒级,但具体的精度可能会受到操作系统和系统负载的影响。
3. 其他相关方法
- stop():
stop()
方法用于停止定时器。如果您希望在某个条件下停止定时器,可以调用此方法。 - isActive():
isActive()
方法可以检查定时器是否正在运行。如果定时器正在运行,返回true
;否则返回false
。