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

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

相关文章:

  • Spring框架学习day3--Spring数据访问层管理(IOC)
  • [mcu]系统频率
  • 深入剖析 Docker 容器化原理与实战应用,开启技术新征程!
  • RuoYi前后端分离框架集成手机短信验证码(一)之后端篇
  • openfeignFeign 客户端禁用 SSL
  • 王树森推荐系统公开课 排序06:粗排模型
  • SAP销售订单批导创建
  • LVS +Keepalived高可用群集
  • 国芯思辰| 国产四通道24位生理电采集模拟前端AFE全面替换ADS1294R,心电贴性能再飞跃
  • 【博客系统】博客系统第十一弹:部署博客系统项目到 Linux 系统
  • 前端 jQuery 简单实现一个网页格斗游戏示例
  • SQL Server 中创建链接服务器
  • python h5py 读取mat文件的<HDF5 object reference> 问题
  • TensorFlow Extended (TFX) 生产环境模型版本控制与回滚实战指南
  • 【请关注】关于VC++实现使用Redis不同方法,有效达到 Redis 性能优化、防击穿
  • Java八股-Java优缺点,跨平台,jdk、jre、jvm关系,解释和编译
  • [Vue2]判断引用组件是否注册了 $emit 对应的事件
  • 《Pytorch深度学习实践》ch1-线性模型
  • AI问答-Vue3+TS:reactive创建一个响应式数组,用一个新的数组对象来替换它,同时保持响应性
  • 003 flutter初始文件讲解(2)
  • 怎样做网站搜索推广/河池网站seo
  • 正规的佛山网站建设价格/自己建网站怎么弄
  • 做日用品的要找什么网站好/外链收录网站
  • 做网站提高淘宝店排名/如何制作网站教程
  • 学生做网站怎么收费/seo关键词优化外包公司
  • 便宜网站建设哪家好/百度指数pc版