Qt快速入门之三:Qt项目建立、编译、运行和源码详解

时间:2024-03-05 09:30:40

一、Qt 项目建立、编译、运行

Hello World 程序就是让应用程序显示 “Hello World” 字符串。这是最简单的应用,但却包含了一个应用程序的基本要素,所以一般使用它来演示程序的创建过程。本节要讲的就是在 Qt Creator 中创建一个图形用户界面的项目,来生成一个可以显示 “Hello World” 字符串的程序。

1.1 步骤一:新建项目

(1)运行 QtCreator,打开 “文件 -> 新建文件或项目” 菜单项,弹出一个对话框,我们选择 Application 项目中的 Qt Widgets Application。然后单击 “Choose” 按钮。

Qt_newProject_A.png


(2)输入项目名称:helloworld,然后点击 “浏览” 按钮来选择源码存放路径,比如我这里是 E:\codeTest\qtCreator_2,如果选中了 “设为默认的项目路径”,那么今后创建的项目都将存放在这里。单击“下一步”。注意:项目所在路径中不能有中文,否则程序会运行报错。

Qt_newProject_B1.png


(3)选择构建套件:DeskTop Qt 5.6.7.1 MinGw 32bit,点击详情按钮可以看到默认为 Debug 版本和 Release 版本分别设置了不同的目录,都保持默认即可。单击“下一步”。

Qt_newProject_C.png


(4)自定义类名:设定类名为 HelloDialog, 基类选择 QDialog,表明该类继承自 QDialog 类,使用这个类可以生成一个对话框界面。这时下面的头文件、源文件和界面文件都会自动生成,保持默认即可。然后单击“下一步”。

Qt_newProject_D.png


(5)设置项目管理:在这里可以看到这个项目的汇总信息,还可以使用版本控制系统,这里不会涉及,直接单击 ”完成“ 即可。

Qt_newProject_F.png


(6)右击项目文件列表中的任一文件,点击 ”在Explorer中打开“,就可以转到项目文件夹,让我们来看看项目目录中的各个文件说明

Qt_newProject_F.png


1.2 步骤二:界面设计

(1)在 Qt Creator 编辑模式下双击项目文件列表中界面文件分类下的 hellodialog.ui 文件,便会进入设计模式。

(2)关于设计模式的界面介绍这里就不再赘述,可以翻看《Qt Creator快速入门》第二章查看。

Qt_newProject_G.png


(3)在控件区寻找一个 ”Label“ 标签部件,将它拖拽到主设计区的界面上,双击进入它进入部件进入编辑状态后输入 ”Hello World!我是Qter!“字符串。还可以再拖拽一个 ”PushButton“ 按钮部件到标签下方,编辑按钮上文本为 ”OK",如下图所示:

Qt_newProject_H.png


1.3 步骤三:编译并运行程序

(1)Ctrl+R 组合键相当于左下角第一个绿色三角按钮(编译运行),按下后程序开始编译,右下角还有一个可视的进度条。

Qt_newProject_I.png


(2)如果前面操作没有错误,那么这时我们制作的 helloWorld 应用程序已经运行起来了,而 Qt Creator 下方弹出了“应用程序输出”框,在这里有一个红色的方块按钮可以终止程序运行,也可以直接关掉 HelloWorld 窗口。

Qt_newProject_J.png

二、helloWorld程序源码详解

第一步,新建空项目。打开 Qt Creator,并新建项目,项目名称为 _helloworld。

第二步,往项目中添加 main.cpp 文件。

第三步,编写源代码。在 main.cpp 中添加如下代码:

#include <QApplication>
#include <QDialog>
#include <QLabel>
int main(int argc, char * argv[])
{
    QApplication a(argc, argv);
    QDialog w;
    QLabel label(&w);
    label.setText(QObject::tr("Hello World!我是Qter!"));
    w. show();
    return a. exec();
}
  • 前 3 行代码是头文件包含。在 Qt 中每一个类都有一个与其同名的头文件,因为后面用到了 QApplication、QDialog 和 QLabel 这 3 个类,所以这里要包含这些类的定义。
  • 第 4 行就是在 C++ 中最常见到的 main() 函数,它有两个参数,用来接收命令行参数
  • 第 6 行新建了 QApplication 类对象,用于管理应用程序的资源,任何一个 Qt GUI 程序都要有一个 QApplication 对象。因为 Qt 程序可以接收命令行参数,所以它需要 argc 和 argv 两个参数。
  • 第 7 行新建了一个 QDialog 对象, QDialog 类用来实现一个对话框界面。
  • 第 8 行新建了一个 QLabel 对象,并将 QDialog 对象作为参数,表明了对话框是它的父窗口,也就是说这个标签放在对话框窗口中。
  • 第 9 行给标签设置要显示的字符。
  • 第 10 行让对话框显示出来。
  • 第 11 行让 QApplication 对象进入事件循环,这样当 Qt 应用程序在运行时便可以接收产生的事件,例如单击和键盘按下等事件。

编译运行程序,效果跟上面类似。


下面介绍两个实用功能:

  • 第一个是快速查看。将鼠标指针放到一个类名或函数上,便会出现一个提示框显示其简单的介绍,而此时按下 F1 键就可以快速打开其帮助文档。
  • 第二个是快速跳转。按下 Ctrl 的同时,将鼠标指针放到一个头文件类名或函数上,可以实现“跳转”功能。

三、[补充]项目模式和项目文件介绍

3.1 项目模式介绍

按下快捷键 Ctrl + 5 ,或者单击“项目”图标,都可以进人项目模式。项目模式分为 “构建设置’、“Active Project”、“Build & Run”、“Project Settings” 这几个页面。在构建设置页面可以设置要构建的版本,如 Debug 版或是 Release 版本,还可以设置所使用的 Qt 版本。这里有一个 Shadow build 选项,作用是将项目的源码和编译生成的文件分别存放。将编译输出与源代码分别存放是个很好的习惯,尤其是在使用多个 Qt 版本进行编译时更是如此。


3.2 项目文件介绍

下面来看一下上面建立的 helloWorld 项目的 helloWorld.pro 文件的内容:

1 #----------------------------------------------------------------------	
2 #
3 # Project created by QtCreator 2018-12-13T16:37:02
4 #
5 #----------------------------------------------------------------------		
6
7	QT	+ = core gui
8
9   greaterThan(QT_MAJOR_VERSION, 4): QT += widgets
10
11	TARGET = helloworld	
12	TEMPLATE = app
13
14  DEFINES += QT_DEPRECATED_WARNINGS
15
16  CONFIG += c++11
17
18	SOURCES + = main. cpp\
19	                    hellodialog.cpp
20
21	HEADERS	+ = hellodialog.h
22		
23	FORMS	+ = hellodialog.ui
24		
25	RC_FILE	+ = myico. rc
  • 第1〜5行是注释信息,说明这个文件生成的时间。
  • 第7行表明了这个项目使用的模块。core模块包含了 Qt 非图形用户界面的核心功能,其他所有模块都依赖于这个模块;而gui模块扩展了 core 模块的图形界面功能。也就是说,如果不需要设计图形界面的程序,那么只需要core模块就可以了,但是如果涉及图形界面,那么就必须包含 gui 模块。其实所谓的模块,就是很多相关类的集合,比如所有与图形界面有关的类都在gui模块中,读者可以在 Qt 帮助中査看 QtCore Module 和 QtGui Module 关键字。
  • 第9行这行代码的意思是,如果QT主版本大于4(也就是说当前使用的是Qt5或者更高版本),则需要添加widgets模块。也可以直接用“QT+=widgets”,但这样可以保持与QT4的兼容性,因为QT4用的是QtGui模块,而Qt5里不再用QtGui模块,而是使用QtWidgets模块。
  • 第11行是生成的目标文件的名称,就是生成的exe文件的名字,默认的是工程的名字, 当然也可以在这里改为别的名字。
  • 第12行使用app模板,表明这是个应用程序。
  • 第14行表明,如果使用已被标记为已弃用的Qt的任何功能,则会使您的编译器发出警告。
  • 第16行表明,使工程支持C++11标准。
  • 第18、21和23行分别是工程中包含的源文件、头文件和界面文件。
  • 第25行就是添加的应用程序图标的文件。这里这些文件都使用了相对路径,因为都在项目目录中,所以只写了文件名。

这里还要提一下那个在项目文件夹中与 .pro 文件一起生成的 .pro. user 文件,它包含了本地构建信息,包含 Qt 版本和构建目录等。可以用记事本或者写字板将这个文件打开査看其内容。


参考:

《Qt Creator快速入门》第二章

Qt入门之基础篇 ( 二 ) :Qt项目建立、编译、运行和发布过程解析