当前位置: 首页 > article >正文

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

  1. 打开 Qt Creator。
  2. 选择 “New Project”。
  3. 选择 “Application” > “Qt Widgets Application”。
  4. 输入项目名称和位置,然后点击 “Next”。
  5. 选择合适的构建工具(例如, 默认的 Qt 版本),然后点击 “Next”。
  6. 点击 “Finish” 完成项目创建。
  7. 修改代码,mainwindow.cpp
  8. 选择菜单中的 “Build” > “Build Project” 来构建项目。
  9. 然后选择 “Run” > “Run Project” 来运行程序。
  10. 当你运行程序时,会看到一个窗口,窗口中央显示 “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
  1. helloworld.pro:

    • 这是 Qt 项目的项目文件,使用 Qt 的 qmake 工具进行构建。它包含了项目的配置信息,例如:
      • 项目名称
      • 需要的 Qt 模块(如 core, gui, widgets 等)
      • 源文件和头文件的列表
      • 资源文件的路径
      • 其他编译选项
    • 该文件是用纯文本格式编写的,通常可以用任何文本编辑器打开和编辑。

    示例内容:

    TEMPLATE = app
    TARGET = helloworld
    QT += widgetsSOURCES += main.cpp \mainwindow.cppHEADERS += mainwindow.hFORMS += mainwindow.ui
    
  2. helloworld.pro.user:

    • 这是 Qt Creator 自动生成的用户配置文件,包含了用户的本地设置,如打开的文件、窗口位置等。通常不需要手动编辑或关注这个文件,它的内容是特定于用户的。
  3. 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();
    }
    
  4. 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;
    }
    
  5. 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
    
  6. 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 是一个全局指针,指向当前的应用程序对象。它是 QApplicationQGuiApplication 的一个实例。通过 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
http://www.lryc.cn/news/2397570.html

相关文章:

  • 数据结构:递归(Recursion)
  • Cesium快速入门到精通系列教程一:打造第一个Cesium应用
  • 力扣题解106:从中序与后序遍历序列构造二叉树
  • Vue传参Props还是Pinia
  • 学习STC51单片机25(芯片为STC89C52RCRC)
  • 宁夏农业科技:创新引领,赋能现代农业新篇章
  • Accelerate 2025北亚巡展正式启航!AI智御全球·引领安全新时代
  • 005学生心理咨询评估系统技术解析:搭建科学心理评估平台
  • azure devops 系列 - 常用的task
  • 贪心算法应用:多重背包启发式问题详解
  • 【保姆级教程】PDF批量转图文笔记
  • Pytest Fixture 是什么?
  • Spring Boot 基础知识全面解析:快速构建企业级应用的核心指南
  • 数据库系统概论(十一)SQL 集合查询 超详细讲解(附带例题表格对比带你一步步掌握)
  • [mcu]系统频率
  • clickhouse如何查看操作记录,从日志来查看写入是否成功
  • 5G-A:开启通信与行业变革的新时代
  • 鸿蒙OS在UniApp中集成Three.js:打造跨平台3D可视化应用#三方框架 #Uniapp
  • Vue 3 组件化设计实践:构建可扩展、高内聚的前端体系
  • 腾讯云 Python3.12.8 通过yum安装 并设置为默认版本
  • 鸿蒙OSUniApp页面切换动效实战:打造流畅精致的转场体验#三方框架 #Uniapp
  • React 泛型组件:用TS来打造灵活的组件。
  • TDengine 集群运行监控
  • 图像任务中的并发处理:线程池、Ray、Celery 和 asyncio 的比较
  • DeepSeek 赋能智能物流:解锁仓储机器人调度的无限可能
  • C#上传图片后压缩
  • uniapp路由跳转toolbar页面
  • 【linux】知识梳理
  • PostgreSQL 内置扩展列表
  • NodeMediaEdge快速上手