1 Hello, Qt
本课时介绍如何利用简单的文本编辑器创建一个基本的 Qt 程序。
1.1 开始之前
- 完成环境准备
- 对 Qt 有个基本的了解
- 会使用 c++ 基本语法
1.2 第一个 Qt 程序
说明: 第一个 Qt 程序不使用任何继承开发工具,使用 qmake 和基本的编辑器(我使用的是 Visual Studio Code)完成。
注意:项目名和文件名,甚至路径中都不能出现中文,否则编译时会报错
第一步:编写程序(只有一个 main.cpp 文件)
1 | . |
main.cpp
1 | // The first Qt Program |
第二步:生成平台无关的项目文件
1 | $ qmake -project "QT += widgets" |
第三步:生成原生构造系统(GNU Makefile)
1 | $ qmake |
Info: creating stash file /Users/tonyearth/Projects/qt_demos
- c语言基础/l01_HelloQt/.qmake.stash
第四步:构造刻执行的程序
1 | $ make |
/Applications/Xcode.app/Contents/Developer/Toolchains/XcodeDefault.xctoolchain/usr/bin/clang++ -c -pipe -stdlib=libc++ -isysroot /Applications/Xcode
.app/Contents/Developer/Platforms/MacOSX.platform/Developer/SDKs/MacOSX10.12.sdk -mmacosx-version-min=10.9 -O2 -std=gnu++11 -Wall -W -fPIC -DQTNO
DEBUG -DQT_WIDGETS_LIB -DQT_GUI_LIB -DQT_CORE_LIB -I. -I. -I/Applications/Qt/5.8/clang_64/lib/QtWidgets.framework/Headers -I/Applications/Qt/5.8/cla
ng_64/lib/QtGui.framework/Headers -I/Applications/Qt/5.8/clang_64/lib/QtCore.framework/Headers -I. -I/Applications/Xcode.app/Contents/Developer/Plat
forms/MacOSX.platform/Developer/SDKs/MacOSX10.12.sdk/System/Library/Frameworks/OpenGL.framework/Headers -I/Applications/Xcode.app/Contents/Developer
/Platforms/MacOSX.platform/Developer/SDKs/MacOSX10.12.sdk/System/Library/Frameworks/AGL.framework/Headers -I/Applications/Qt/5.8/clang_64/mkspecs/ma
cx-clang -F/Applications/Qt/5.8/clang_64/lib -o main.o main.cpp
/Applications/Xcode.app/Contents/Developer/Toolchains/XcodeDefault.xctoolchain/usr/bin/clang++ -headerpad_max_install_names -stdlib=libc++ -Wl,-sysl
ibroot,/Applications/Xcode.app/Contents/Developer/Platforms/MacOSX.platform/Developer/SDKs/MacOSX10.12.sdk -mmacosx-version-min=10.9 -Wl,-rpath,/Ap
plications/Qt/5.8/clang_64/lib -o l01_HelloQt.app/Contents/MacOS/l01_HelloQt main.o -F/Applications/Qt/5.8/clang_64/lib -framework QtWidgets -fram
ework QtGui -framework QtCore -framework DiskArbitration -framework IOKit -framework OpenGL -framework AGL
第五步:启动应用
1 | . |
1 | $ open l01_HelloQt.app |
1.3 Qt 程序编译方式
- qmake 编译
- IDE 编译(Qt Creator)
- 第三方编译工具
1.4 了解 qmake 与 make 命令
qmake 编译步骤
qmake -project
qmake
make
Qmake 创建工程文件
1 | $ qmake -project # 创建 pro 文件 |
window 和 Linux 环境使用 qmake
基本是一样的,值的注意的一点,是 windows 版本的 Qt 提供了一个终端,自带 Qt 的环境 。
2 Qt Creator 与高效开发
本课时会讲解 Qt Creator 以及其他开发工具的使用,包括如何使用 Qt Creator 创建 Qt 工程。并讲解 Qt 工程中包括的文件以及 Qt.pro 文件中的语法。
2.1 Qt Creator 的使用
2.1.1 Hello Qt 示例(Mac Desktop 版 )
创建项目
第一步:创建哪种应用类型
第二步:项目名称和存储位置
第三步:使用哪些工具集
第四步:初始化时的项目文件名等细节
第五步:项目管理(版本管理等)
项目开发
mainwindow.cpp
1 | #include "mainwindow.h" |
运行效果
2.1.2 使用 QtDesigner
创建项目
说明: 创建项目时勾选创建界面
即可使用 QtDesigner。
项目开发
(1) 双击 .ui 文件, QtCreator 会自动进入设计模式,通过简单拖动就可以添加一些组件。
(2) 可以在代码中对 .ui 文件创建的组件进行进一步处理。
例如, mainwindow.cpp
1 | #include "mainwindow.h" |
(3) 运行
2.2 Qt 项目文件
QtCreator 会在项目源码所在目录外,创建一个新目录专门处理构建任务,从而保证源码目录的干净。
1 | . |
2.3 pro 文件语法
说明: 工程中的 .pro 文件是 qmake 的工程文件,它列举了工程中包含的源文件以及各种资源文件。
应用:由于直接使用 qmake 命令构建程序过于繁琐,因此大多数情况下会想构建相对简单的 .pro 文件,再使用 qmake 生成对应的 Makefile。
2.3.1 变量
pro 文件中一些重要的的变量 | 说明 |
---|---|
QT | 使用的 QT 模块 |
CONFIG | 决定了程序编译时,链接哪些库(默认是 qt ,而QT 变量的值会进一细化使用哪些链接库) |
TARGET | 项目名 |
TEMPLATE | 项目类型(app/lib/sudirs) |
DEFINES | 使用哪些 Qt 构造系统提供的模块 |
SOURCES | 源文件 |
HEADRES | 头文件 |
FORMS | UI 文件 |
RESOURCES | 资源文件 |
OTHER_FILES | 其它文件 |
2.3.2 操作符
操作符 | 功能 |
---|---|
+= | 扩展变量的值 |
-= | 移除值 |
*= | 扩展变量的值(该值如果已经有了则被忽略) |
~= | 增加一个符和正则的值 |
1 | QT += core gui # 使用的 Qt 模块 |
2.4 与示例程序的使用
2.4.1 Qt帮助文档
QtAssistant
说明:Qt 专门提供的一个查看帮助文档的浏览器,可以方便地定制自己程序的帮助文档,为用户提供本地文档和在线帮助。
特性:
- 快速查找
- 全文搜索
- 索引
- 书签
QtCreator 帮助
2.2 编译运行示例程序
(1)示例程序的帮助文件
(2)编译运行
3 Qt Designer 与窗口组件
本课时将演示如何使用 Qt Design 创建可供创建 C++ GUI 程序时使用的UI文件,并讲解 Qt Design 的用法并演示 Qt Design 中常用的窗口组件。
3.1 创建新的 UI 文件
注意: UI 文件本质上是一个 xml 文件,但只能在设计模式下修改。
(1)新建文件或项目
(2) 选择 Qt Designer Form
(3) Form Template
(4) Location
(5) summary
3.2 Designer
设计模式
qss 样式表
说明:
类似 css 样式表。
预览当前编辑的 UI 界面
工具提示
说明: 鼠标悬浮在组件上时的提示。
组件分组
3.2 常见组件
Buttons
Push Button
用的最多的普通按钮
,可以理解为命令按钮。
例如
Tool Button
工具按钮
。相比 Push Button,应用场景更加具体,可以用来做详细设置或命令的快速入口。
细设置或命令的快速入口。
例如
Radio Button
单选
。
注意:会自动作为一组。同一分组的 Radio Button 只能有一个被选中。
Check Box
复选
。
Command Link Button
从 windows vista 开始引入的一种新的控制按钮。类似一个单选按钮,可以用它在一个互斥的选项中选择一个,而不是直接使用这个按钮本身。
Button Box
严格说来,这个组件是一个按钮组
,不是单个按钮,包含了两个按钮,一般用在对话框。
Item Views(Model-Based)
说明:每个单元需要自己定义,自己维护,因此需要对 Model 框架比较了解。优势是可以很大程度降低数据冗余,提高效率
Item Widgets(Item-Based)
每个单元都是 Item ,相比 Item Views 更简单,可以满足大部分场景。
List Widget
列表控件
。
双击开始编辑列表控件
有两种模式可以选择
Tree Widget
树状列表
。
Table Widget
表格
。
Containers
让组件在窗体中更好地布局,更有条理,避免在内容多的时候显得凌乱。可以随意地把其它组件加到一个容器中,容器中的组件只会在范围内显示,不会超出范围。
Group Box
组件框
,带有一个标题。
Scroll Area
滚动区域
,内容溢出会出现滚动条(器它容器会隐藏)
。
Tool Box
抽屉
。
Tab Widget
带标题的选项卡
切换。选项卡中的内容都是独立的。
Stacked Widget
也是一个 选项卡
组件,不过没有选显卡标题,可以通过程序自己来维护内容的切换。
这是一个相当常用的功能,例如 OS X 的设置程序,
通过点击不同的图标,可以进入不同的设置界面。
Frame
一个边框组件
,可以用来实现不同的边框效果(比如形状和阴影)。
Widget
所有用户界面的基类,可以在一个 Widget 中嵌套另一个 Widget 。
MDIArea
提供了一个可以绘制多个窗口地区域。
添加子窗口
每个窗口都可以自由拖动,且可以很方便地切换
Dock Widget
一个比较特殊也比较实用的组件,提供了一个可以锁定在主窗口中,或者作为一个顶层组件、自由悬浮的窗口。大多数时候做为工具面板。
例如,PhotoShop、各种继承开发环境包括 QtCreator 中有用到。
Input Widgets
Combo Box
下拉列表
Font Combo Box
选择字体的下拉列表,默认使用系统的字体作为选项。
Line Edit
一个单行文本编辑框
。
输入模式
有多种输入模式可以选择
一键清除
可以显示一个一键清除的按钮
Text Edit
一个强大的,单页面,多信息文本编辑器。支持 HTML 标记,所见即所得。对大文档的显示进行了优化。
Text Edit
指针对纯文本文档。对大文档的显示进行了优化。
Plain Text Edit
Spin Box
整数输入组件。
Double Pin Box
小数输入组件。
Time Edit
可以提供激活日历选择器。
Date Edit
可以提供激活日历选择器。
Date/Time Edit
可以提供激活日历选择器。
Dial
可以做表盘或用来进行控制的旋钮。
Horizontal Scroll Bar
Vertical Scroll Bar
Horizontal Slider
Vertical Slider
Key Sequence Edit
快捷键序列编辑器。
Display Widgets
仅仅提供显示功能的组件,不能交互。
Label
Text Browser
支持 HTML 标记,所见即所得。
Graphics View
可以显示大量 2D 图像,支持旋转、缩放。
Canlendar
LCD Number
用来显示一些数字和特殊的符号,用的是一种 LCD 显示屏的风格。类似计算机。
Progress Bar
进度条。
Horizontal Line
Vertical Line
Open GL Widget
显示 3D 绘图。
QDeclarativeView
在触屏和嵌入式设备上更友好。
QQuickWidget
用来显示一个 QtQuick 的用户界面。
QWebView
QtWebKit 的主要组件,可以显示 HTML 文档(可以是本地的,也可以是一个链接)。
Layouts
使用布局可以可以方便整洁地构建一个应用界面,类似 java swing 中的布局,不过 Qt 的布局种类提供的要少一些。
Vertical Layout
纵向布局。
Horizontal Layout
横向布局。
Grid Layout
网格布局。
Form Layout
Spacers
弹簧组件,用于处理布局中的间隔。会自动根据空间大小和样式调整间隔,以及组件的高度或宽度。