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.ui

0 directories, 6 files

  1. helloworld.pro:

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

    示例内容:

    TEMPLATE = app
    TARGET = helloworld
    QT += widgets
    
    SOURCES += main.cpp \
               mainwindow.cpp
    
    HEADERS += mainwindow.h
    
    FORMS += 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_OBJECT
    
    public:
        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_OBJECT

public:
    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
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值