【QT】1.QT 基础入门

目录

一、新建项目

[1. 新建项目](#1. 新建项目)

二、生成代码

[1. main.cpp](#1. main.cpp)

[2. widget.h / widget.cpp](#2. widget.h / widget.cpp)

[3. widget.ui](#3. widget.ui)

[4. .pro 文件](#4. .pro 文件)

[5. 运行后生成的文件](#5. 运行后生成的文件)

三、创建控件

[1. Label(标签)](#1. Label(标签))

[2. 编辑框](#2. 编辑框)

[3. 一个简单的交互程序:点击按钮切换文字](#3. 一个简单的交互程序:点击按钮切换文字)

四、乱码问题与文字输出

[1. 编码问题](#1. 编码问题)

[2. qDebug 输出](#2. qDebug 输出)

五、坐标系统


一、新建项目

1. 新建项目

  1. 启动 :在 QT 的安装文件夹中,找到并运行 QT Creator,然后在左上角的"文件"菜单中点击"新建"。

  2. 选择模板 :由于 QT 支持 Python 等多种语言开发,QT Quick 是 QT 自己的一套声明式语言和开发方式。我们使用 C++,因此选择默认的 Widgets Application 模板即可。

  3. 设置项目路径和名字:路径和名称不能包含中文。

  4. 构建系统选择 :选择 qmake,这是 QT 的经典构建工具。CMake 也被部分开源项目使用,而 Qbs 已停止维护。​​​​​​​

  5. UI 文件(Formfile)

    • 在 QT 中创建图形界面的方式有两种:使用 C++ 代码创建,或使用 Formfile 图形界面创建。

    • 我们选用图形化方式快速编辑。​​​​​​​

    • 基类选择 QWidget。​​​​​​​

  6. 其他选项:编译器选择等保持默认即可。

二、生成代码

1. main.cpp

cpp 复制代码
#include "widget.h"
#include <QApplication>
int main(int argc, char *argv[]) {
    QApplication a(argc, argv);
    Widget w;
    w.show();
    return a.exec();
}

创建 QT 项目后,会自动生成这些代码。

  1. main 函数的形参即为命令行参数。

  2. QApplication:是编写 QT 应用程序时必须的类,管理应用程序的控制流和主要设置。

  3. show 方法

    • Widget w;

    • w.show();

    • Widget 是创建项目时输入的类名。

    • .show() 用于显示窗口控件,改为 .hide() 则为隐藏。

  4. exec 方法 :与 Linux 的 exec 不同,这是启动应用程序的事件循环,让程序运行起来。

2. widget.h / widget.cpp

  1. 继承关系class Widget : public QWidget,即继承了创建项目时选择的基类 QWidget

  2. Q_OBJECT:QT 内置的宏,展开后会生成一些代码,是 QT 信号和槽机制的核心所需。

  3. 构造函数和析构函数 :​​​​​​​

  4. Ui::Widget *ui; :这个指针与 .ui 文件(Formfile)密切相关,用于访问界面上的控件。

3. widget.ui

  • 双击该文件会调用 QT Designer,打开图形化编辑器,可以从左侧拖拽控件到界面上。

  • 返回代码编辑区可以看到其格式,本质上是 XML 文件。​​​​​​​

  • 这个区域已经被封装好了,我们只需运行程序即可看到界面。

4. .pro 文件

  • 这是 QT 的工程文件。
  1. QT += core gui:指定项目需要引入的 QT 模块。

  2. SOURCESHEADERSFORMS:这些部分列出了项目中的源文件、头文件和界面文件。通常不需要手动修改,QT Creator 会自动维护。

5. 运行后生成的文件

  • 运行项目后,会生成一个 build- 开头的文件夹。

  • ui_widget.h 是由 widget.cpp 里的 setupUi 调用(ui->setupUi(this);)所创建的。

  • 它根据 .ui 文件生成了具体的界面设置代码。

三、创建控件

1. Label(标签)

  1. 图形化创建

    • widget.ui 中拖拽 Label 到界面上即可。​​​​​​​

    • 此时,在 widget.ui 文件里就会有一个 QLabel 标签。​​​​​​​

  2. 代码创建

    • widget.cpp 的构造函数中创建。

    • main 函数中有 Widget w; 这一行,创建 Widget 对象时就会调用构造函数,从而创建出画面。

    • 添加头文件:#include <QLabel> (QT 历史较早,有 .h 和没有 .h 的头文件都存在,两者都可以)。

    • 创建对象并指定父对象:

      cpp 复制代码
      QLabel* q1 = new QLabel(this); // this 就是 Widget w,给这个标签指定父对象
      q1->setText("Hello World");
    • QT 有自己封装的字符串类 QString。开发时 std::stringQString 都可以用,但 QString 在处理编码(尤其是中文)时更友好。

    • 注意:这里没有 delete 不会造成内存泄露。

      • 原因 :QT 使用对象树 机制,当父对象(Widget)被销毁时,会自动销毁其所有子对象(如这里的 q1)。
    • 如果将 QLabel 对象创建在栈上(如 QLabel q1(this);),在构造函数结束时它就会立即销毁,导致无法显示。​​​​​​​

2. 编辑框

  • 单行编辑框QLineEdit

  • 多行编辑框QTextEdit

  • 图形化实现 :拖拽 Line Edit 控件到界面上即可。

  • 代码实现

    cpp

    复制代码
    QLineEdit* q = new QLineEdit(this);
    q->setText("hello world");

3. 一个简单的交互程序:点击按钮切换文字

  1. 图形界面实现

    • 拖拽一个 Push Button 到界面上。

    • 使用 connect 函数连接信号与槽:

      cpp

      复制代码
      connect(ui->pushButton, &QPushButton::clicked, this, &Widget::changeText);
      • ui->pushButton 代表按钮的对象名(可以在界面右侧的属性编辑器中修改)。​​​​​​​

      • &QPushButton::clicked 表示接收按钮的"被点击"信号。

      • this 代表接收信号的对象(当前 Widget)。

      • &Widget::changeText 代表接收到信号后要执行的操作(槽函数),需要在 Widget 类中实现。

    • 实现槽函数 changeText

      cpp

      复制代码
      void Widget::changeText() {
          if (ui->pushButton->text() == QString("hello world"))
              ui->pushButton->setText("hello qt");
          else
              ui->pushButton->setText("hello world");
      }
  2. 使用 Lambda 表达式一步搞定

    cpp 复制代码
    connect(ui->pushButton, &QPushButton::clicked, this, [this]() {
        if (ui->pushButton->text() == QString("hello world"))
            ui->pushButton->setText("hello qt");
        else
            ui->pushButton->setText("hello world");
    });
  3. 纯代码实现

    • 首先,在 widget.hWidget 类中添加成员变量:QPushButton* pushButton;

    • widget.cpp 的构造函数中创建并连接:

      cpp 复制代码
      pushButton = new QPushButton(this);
      connect(pushButton, &QPushButton::clicked, this, &Widget::changeText);
    • 实现 changeText 槽函数(与图形化实现中的函数体类似,只是将 ui->pushButton 换成 pushButton)。

四、乱码问题与文字输出

1. 编码问题

  • 计算机中汉字占用的字节数取决于编码格式:GBK 为 2 字节,UTF-8 为 3 字节。

  • Windows 系统默认使用 GBK 编码,Linux 系统默认使用 UTF-8 编码。

  • QT 默认使用 UTF-8 编码。如果源文件编码不一致,可能会导致中文显示乱码。

2. qDebug 输出

  • qDebug() 可以自动处理编码问题,方便地输出调试信息。

    复制代码
    qDebug() << "你好" << '\n';
  • 此外,qDebug 还可以通过宏定义等方式统一关闭所有调试信息的打印,便于发布。

五、坐标系统

  • QT 使用左手系坐标:Y 轴向下为正方向,X 轴向右为正方向。

  • QWidget 设置位置(如使用 move 函数)时,坐标是相对于其父控件(父窗口)的,(0, 0) 点就是父窗口的左上角。

相关推荐
2301_818732062 小时前
前端一直获取不到后端的值,和数据库字段设置有关 Oracle
前端·数据库·sql·oracle
皙然2 小时前
MyBatis 执行流程源码级深度解析:从 Mapper 接口到 SQL 执行的全链路逻辑
数据库·sql·mybatis
BXCQ_xuan2 小时前
解决飞牛nas更新后挂载硬盘提示“数据库读写失败”
数据库·飞牛nas
栗子叶2 小时前
阅读MySQL实战45讲专栏总结
数据库·mysql·innodb·主从同步·数据库原理
一只鹿鹿鹿2 小时前
springboot集成工作流教程(全面集成以及源码)
大数据·运维·数据库·人工智能·web安全
Coder_Boy_2 小时前
基于SpringAI的在线考试系统-数据库设计关联关系设计
服务器·网络·数据库
李慕婉学姐2 小时前
Springboot七彩花都线上鲜花订购平台rzb8b4z2(程序+源码+数据库+调试部署+开发环境)带论文文档1万字以上,文末可获取,系统界面在最后面。
数据库·spring boot·后端
码农阿豪2 小时前
时序数据爆发增长,企业如何破解存储与分析困局?
数据库·mysql·金仓
定偶2 小时前
用MySQL玩转数据可视化的技术
数据库·mysql·信息可视化