Qt c++ (一)创建一个APP

安装和第一个helloworld实例什么的的就不讲了,网上很多例子。我们直接就从界面开始将吧,因为也是自己摸索,有错误麻烦指正。

一、创建一个APP


1、build system

在 Qt Creator 中创建项目时,Build system 的选择通常由你使用的项目类型决定。Qt Creator 默认提供了几种构建系统选项,选择哪种构建系统取决于你的项目规模和复杂性。

主要构建系统选项

qmake: Qt 自带的构建系统。它通过 .pro 文件来描述项目,使用 qmake 命令生成可用于不同构建工具(如 Make,Ninja)的构建文件。 通常是 Qt C++ 项目的默认构建系统,对于小型到中型项目来说是不错的选择。 qmake 具有跨平台支持,能处理相对简单的依赖关系。

CMake: 一个流行且强大的跨平台构建系统生成器。它允许使用声明式方法来描述构建过程,生成各种构建工具(如 Make、Ninja、Visual Studio)的构建文件。 CMake 非常适合大型项目,因为它可以处理复杂的依赖关系、多平台支持、以及不同编译器选项。 对于需要在不同平台上构建、或有大量依赖项的项目,CMake 是一个很好的选择。

如何选择

小型或中等规模的 Qt 项目: 通常情况下,qmake 就足够了。它易于上手,并且对于大多数简单项目来说性能良好。

大型项目,跨平台支持,或复杂的依赖关系: 选择 CMake。CMake 可以更好地管理大型项目中的复杂依赖关系,并且提供了强大的跨平台支持。

Qt Creator 中的构建系统选择:

当你在 Qt Creator 中创建新的 Qt 项目时,通常会自动选择合适的构建系统。 如果你想更改默认构建系统,你可以在 .pro 文件中进行配置,或者在项目设置中选择相应的构建系统。

2 Kit Selection

Qt C++ 创建项目时,Kit Selection (工具链选择) 是一个非常重要的步骤,它决定了你的项目将会使用哪个编译器、哪个 Qt 版本以及其他编译选项。 正确选择 Kit 对于项目的构建和运行至关重要。

Kit Selection 的作用

1、指定编译器: 选择 Kit 时,你需要选择一个编译器 (例如,MinGW、MSVC、clang)。不同的编译器有不同的特性和支持的标准,选择不当可能会导致编译错误。

2、指定 Qt 版本: Kit 会关联一个特定的 Qt 版本。 这意味着你的项目将使用该 Qt 版本提供的库和类。 选择错误的 Qt 版本可能会导致你的代码无法运行。

3、指定编译选项: Kit 还会包含一些编译选项,例如优化级别、调试信息等。

4、确保跨平台兼容性: 一个好的 Kit 应该能够在目标平台上正确配置编译器和库,从而确保你的项目在不同的平台上能正确编译和运行。

如何选择合适的 Kit

考虑你的目标平台: 如果你想在 Windows 上构建,则需要选择包含 Windows 编译器的 Kit;macOS 需要选择包含 Xcode 的 Kit;Linux 需要选择包含 GCC 或其他编译器的 Kit。

1、考虑你的 Qt 版本: 确保选择的 Kit 中的 Qt 版本与你的项目兼容。

2、考虑编译器选项: 如果需要特定编译器选项(例如,优化级别),请选择包含这些选项的 Kit。

3、检查 Kit 的兼容性: 在选择 Kit 之前,最好检查该 Kit 是否与你的项目代码中的库、类和其他依赖关系兼容。

4、考虑调试工具: 有些 Kit 会包含调试器,这有助于你调试你的项目。

5、实际运行测试: 选择 Kit 后,最好进行简单的测试构建和运行,以确保一切正常。

这俩个都可以单独拉出来细细讲一讲,这里大致了解下。

如果没有选择Kit ,这时候Qt Creator 界面如下

点击扳手选择对应的Kit,然后点击Configure Project开始我们的界面编辑之旅。

这里,我们创建了一个interFace项目,Qt Creator 自动帮我们生成了一个interFace.pro文件,一个main.cpp,一个mainwindow类以及一个mainwindow.ui文件

Qt C++ 的 .pro 文件是项目的构建描述文件,Qt Creator 使用它来编译你的项目。

interFace.pro
bash 复制代码
# 指定项目需要使用的 Qt 模块。 core 是 Qt 的核心模块,gui 是图形用户界面模块。 你需要根据项目
# 实际需求添加其他模块。
QT       += core gui

# greaterThan(QT_MAJOR_VERSION, 4): 这是一个条件表达式,检查当前 Qt 版本的主版本号是否大于 4。
# QT_MAJOR_VERSION 是一个预定义变量,保存了 Qt 安装的主版本号。
# QT += widgets: 这是在条件为真(即 Qt 版本主版本号大于 4)时执行的操作,它将 widgets 
# 模块添加到项目需要的 Qt 模块列表中。 widgets 模块包含与图形用户界面相关的类和函数。
greaterThan(QT_MAJOR_VERSION, 4): QT += widgets

# 指定了c++的版本 
# Qt 中有很多 CONFIG 选项。 例如 debug, release, warn_on, warn_all, release, profile. 了解这些选项会帮助你更好地控制编译过程。
CONFIG += c++11

# The following define makes your compiler emit warnings if you use
# any Qt feature that has been marked deprecated (the exact warnings
# depend on your compiler). Please consult the documentation of the
# deprecated API in order to know how to port your code away from it.
# 定义预处理器宏 QT_DEPRECATED_WARNINGS,它会过滤并警告你代码中使用到的过时 Qt 函数或类。
DEFINES += QT_DEPRECATED_WARNINGS

# You can also make your code fail to compile if it uses deprecated APIs.
# In order to do so, uncomment the following line.
# You can also select to disable deprecated APIs only up to a certain version of Qt.
#DEFINES += QT_DISABLE_DEPRECATED_BEFORE=0x060000    # disables all the APIs deprecated before Qt 6.0.0

# 列出源文件(.cpp)
SOURCES += \
    main.cpp \
    mainwindow.cpp

# 列出头文件(.h)。
HEADERS += \
    mainwindow.h

# 将 mainwindow.ui 这个 Qt Designer 设计的 UI 文件添加到项目中。
FORMS += \
    mainwindow.ui

# Default rules for deployment.
# 如果目标是在 QNX 操作系统上构建的,则将目标的安装路径设置为 /tmp/$${TARGET}/bin。
# $${TARGET} 是一个变量,包含你的目标名称。 例如,如果你的目标是 myApp,路径将是 /tmp/myApp/bin
# 如果前面的条件 (qnx) 为假(意味着它不是 QNX 系统),并且 它是一个类 Unix 系统
#(不是 Android),则安装路径设置为 /opt/$${TARGET}/bin。 这确保了在不同操作系统下使用不
# 同的安装目录,保持组织性
qnx: target.path = /tmp/$${TARGET}/bin
else: unix:!android: target.path = /opt/$${TARGET}/bin
#!isEmpty(target.path): INSTALLS += target: 这部分是关键。它检查 target.path 变量是否为空
#(表示没有分配路径)。如果成功确定了一个路径,则将目标添加到应该被安装的列表中。 这确保了在构建
# 过程中,目标(可执行文件或库)被安装到指定的路径。
!isEmpty(target.path): INSTALLS += target
main.cpp

main.cpp C++ 程序的入口点

cpp 复制代码
#include "mainwindow.h"
/*QApplication 是 Qt 框架中的一个类,它是 Qt 应用程序的基石,因为它:

管理应用程序的主事件循环: 这对于处理用户输入(鼠标点击、键盘按键等),在屏幕上绘制,以及响应
各种事件至关重要。

提供对应用程序范围资源的访问: 它用于应用程序与窗口系统(例如 Linux 上的 X11 或 Windows API)
的交互,管理显示器等资源,并提供与其他 Qt 对象通信的方式。

处理应用程序的初始化和清理: 它管理应用程序的初始化和终止。

简而言之,没有 QApplication,Qt 应用程序无法运行。你需要包含它才能使用 Qt 的 GUI 功能。*/
#include <QApplication>

int main(int argc, char *argv[])
{
    QApplication a(argc, argv);
    //系统给你创建的窗口类
    MainWindow w;
    w.show();
    /*这是最重要的一部分。a 应该是一个 QApplication 对象(在你的程序中更早创建)。a.exec() 
    启动了 Qt 事件循环。事件循环是 Qt 应用程序的关键部分。它负责处理应用程序中的所有事件,
    例如用户输入(鼠标点击、按键),窗口重绘等等。return 语句返回 a.exec() 的结果,该结果
    指示应用程序退出的方式。

	总之,这段代码创建了一个主窗口,使其可见,然后进入 Qt 事件循环以处理发生的事件。事件循环保持
	应用程序响应且运行,直到用户关闭窗口或应用程序以其他方式终止。没有 a.exec(),主窗口将短暂出
	现然后消失。*/
    return a.exec();
}
mainwindow主窗口类
cpp 复制代码
//mainwindow.h
#ifndef MAINWINDOW_H
#define MAINWINDOW_H

#include <QMainWindow>

//QT_BEGIN_NAMESPACE 和 QT_END_NAMESPACE 这两个预处理器指令在 Qt 头文件中用于正确地限定 
//Ui 命名空间
//QT_BEGIN_NAMESPACE/QT_END_NAMESPACE 确保在访问ui时拥有正确的作用域
QT_BEGIN_NAMESPACE
namespace Ui { class MainWindow; }
QT_END_NAMESPACE

class MainWindow : public QMainWindow
{
	//Q_OBJECT 是 Qt 中的一个宏,对于任何需要与 Qt 元对象系统交互的类来说都是至关重要的。它是 Qt 
	//	的信号槽机制、属性系统以及其他依赖于反射功能的关键部分。
	//没有 Q_OBJECT,Qt 的信号槽机制、属性以及元对象功能对于该类来说将无法工作。在你的代码中使用 
	//  Qt 的信号槽机制或属性时,你的应用程序很可能会出现故障或崩溃。
    Q_OBJECT

public:
    MainWindow(QWidget *parent = nullptr);
    ~MainWindow();

private:
	//Ui::MainWindow *ui; 声明的是一个指向 Qt Designer 生成的 MainWindow 界面类对象的指针。 
	//  通过 ui 指针,你可以在你的 C++ 代码中访问和操作设计好的界面元素。
    Ui::MainWindow *ui;
};
#endif // MAINWINDOW_H

//mainwindow.cpp
#include "mainwindow.h"
#include "ui_mainwindow.h"

MainWindow::MainWindow(QWidget *parent)
    : QMainWindow(parent)
    , ui(new Ui::MainWindow)
{
	//它负责将 Qt Designer 设计的界面与 C++ 代码连接起来
	/*setupUi 函数做的事情包括:

		创建界面元素 (例如按钮、标签) 的实例。
		将界面元素放置到合适的容器中 (例如 centralWidget 或其他布局)。
		将界面元素的属性 (例如文本、位置、大小) 设置为设计器中的值。
		将界面元素的成员变量与 ui 指针指向的 Ui::MainWindow 类的相应成员变量连接起来。
	*/
    ui->setupUi(this);
}

MainWindow::~MainWindow()
{
    delete ui;
}
mainwindow.ui

双击界面:

文本编辑UI内容

xml 复制代码
<?xml version="1.0" encoding="UTF-8"?>
<ui version="4.0">
 <class>MainWindow</class>
 <widget class="QMainWindow" name="MainWindow">
  <!-- 窗口的几何尺寸 -->
  <property name="geometry">
   <rect>
    <x>0</x>  <!-- 窗口左上角 x 坐标 -->
    <y>0</y>  <!-- 窗口左上角 y 坐标 -->
    <width>800</width>  <!-- 窗口宽度 -->
    <height>600</height> <!-- 窗口高度 -->
   </rect>
  </property>
  <property name="windowTitle">
   <string>MainWindow</string>  <!-- 窗口标题 -->
  </property>
  <widget class="QWidget" name="centralwidget">
    <!-- centralwidget 是主窗口的中心区域,一般在此区域放置布局和控件 -->
  </widget>
  <widget class="QMenuBar" name="menubar">
    <!-- 菜单栏,一般用于文件、编辑等功能 -->
  </widget>
  <widget class="QStatusBar" name="statusbar">
    <!-- 状态栏,用于显示程序状态或信息 -->
  </widget>
 </widget>
 <resources/>
 <connections/>
</ui>

不知道有没有使用过UI界面库或者html的,是不是感觉这个xml内容很熟悉。

相关推荐
old_power18 分钟前
【PCL】Segmentation 模块—— 基于图割算法的点云分割(Min-Cut Based Segmentation)
c++·算法·计算机视觉·3d
涛ing34 分钟前
21. C语言 `typedef`:类型重命名
linux·c语言·开发语言·c++·vscode·算法·visual studio
PaLu-LI2 小时前
ORB-SLAM2源码学习:Initializer.cc⑧: Initializer::CheckRT检验三角化结果
c++·人工智能·opencv·学习·ubuntu·计算机视觉
攻城狮7号3 小时前
【10.2】队列-设计循环队列
数据结构·c++·算法
JANG10243 小时前
【Qt】窗口
开发语言·qt
_DCG_4 小时前
c++常见设计模式之装饰器模式
c++·设计模式·装饰器模式
w(゚Д゚)w吓洗宝宝了4 小时前
设计模式概述 - 设计模式的重要性
c++·设计模式
7yewh4 小时前
嵌入式知识点总结 C/C++ 专题提升(七)-位操作
c语言·c++·stm32·单片机·mcu·物联网·位操作
w(゚Д゚)w吓洗宝宝了4 小时前
装饰器模式 - 装饰器模式的实现
开发语言·c++·算法
fadtes5 小时前
C++ initializer_list 列表初始化(八股总结)
c++·游戏