QT跨平台应用程序开发框架(1)—— 环境搭建

目录

一,关于QT

 二,关于应用程序框架

三,环境搭建

3.1 预备

3.2 下载Qt SDK

3.3 安装Qt SDK

 3.4 配置环境变量

3.5 认识一些重要工具

四,Qt Creator 的基本使用

4.1 创建项目 

4.2 代码解释


一,关于QT

  • 互联网核心岗位大致分为四种:开发,测试,运维,产品经理;开发又分为后端开发,前端开发,算法工程师,游戏开发等,前端开发还可以细分,比如网页端开发,桌面应用开发,移动应用开发
  • QT是用于进行客户端开发的,属于前端开发的桌面应用开发,又叫客户端开发
  • 准确来说,QT特指用来进行桌面应用开发所涉及到的一套计数,并且QT无法开发网页前端,也不能开发移动应用(目前官方也支持移动应用开发了,但是目前还没有知名的商用移动应用程序是QT开发的,就是不知道有没有人用)
  • 客户端开发的主要任务,就是编写和用户交互的界面,目前我们接触到的交互页面主要是两种:①命令行终端页面,比如cmd    ②图形化界面;前者适合专业人员用,后者适合普通用户,QT是用来编写桌面GUI程序的一套框架
  • 其实在Windows上编写GUI程序,也有很多解决方案,QT只是其中一种

 Windows下还有哪些方案可以开发GUI?

  • Windows API:windows提供原生 API来进行GUI开发,但是开发起开非常繁琐也非常原始,是最早期开发图形化界面的方式
  • MFC:是上世纪九十年代具有非常大影响力的一种GUI开发方法,与VC 6.0 一起极大促进了开发方式由原始到便捷的转变
  • QT也是在1991年左右诞生,和MFC不同,MFC早就停止更新了(寄了),QT直到现在仍在不停地更新和维护,仍然非常有生命力,并且能够跨平台,属于“六边形战士”
  • Windows Forms:微软给自家开发的 C# 量身定制地一套GUI开发体系
  • Electron:本质上是把 HTML 这样的网页,打包成 Windows 上运行的客户端程序,是最近几年比较热门的一种技术,最初是用来开发 “atom” 文本编辑器的(GitHub开发的,但是后来atom寄了,被微软的VSCode挤下去了);但是这个也有缺点,就是开发出来的程序,运行效率比较堪忧,比上面的都低很多

 二,关于应用程序框架

“框架”这个词在java中很常见,但是在C/C++中涉及的并不多,下面来介绍下什么是框架:

  • 框架本质是一群大佬发明出来方便底层程序员写代码的,一个东西越“自由”越“灵活”,就越容易出错,特别是对于我们程序猿来说,代码出错是最难受的了
  • 所以框架目的是为了限制程序员的自由,但是这并不是坏处,可以类比下没有红绿灯和有红绿灯的十字路口,框架能够减少程序员写代码出错的情况
  • 库和框架都是属于大佬们给全世界程序员的福利,库是被程序员调用的,框架则是“调用”程序员的,二者的主体地位不同,一般程序员配合框架,完善填充框架中流出的一些细节
  • 隔壁的 Java 更加依赖框架,比如Spring;而C/C++在代码编写上就比较自由

三,环境搭建

3.1 预备

QT开发环境,需要安装三个部分:

  • ①C++编译器(是编译器不是IDE,比如gcc,cl.exe等)
  • ②Qt SDK:SDK我们一般叫做软件开发工具包,里面包含了我们 进行 Qt 开发时要用到的各种工具,一般的Qt SDK 里面一般会内置C++编译器,一般建议用这个,如果要用曾经装VS时装的编译器可能还需要一些额外的配置,比较麻烦也容易出错
  • 需要有一个Qt的IDE,有很多,比如官方推荐的Qt Creator,是最容易入门也最容易上手的方式,并且不需要任何额外的配置(虽然这个IDE使用过程中有很多bug,但是整体来说还是挺方便的,适合初学者)
  • Visual Studio也可以进行Qt开发, 虽然功能更强但是需要更多额外的配置,上手较难,有些公司开发商业 Qt 程序的时候,可能会用到VS
  • Eclipse:本身是一个IDE平台,可以搭配不同的插件构成不同的IDE,也可以开发Qt,但是目前Eclipse市场份额受到的冲击很大,有更多的重量级(JetBrains)和轻量级工具(VSCode)来代替了

其实说是安装三个东西,其实只要安装一个Qt SDK,其它两个都有了 

3.2 下载Qt SDK

下载的官网网址为:https://download.qt.io/archive/qt/

 

 如果因为“众所周知”的原因导致上面的网站打不开或者下载很慢,需要 fq,并且不要做 wf 的行为哦,如果实在不行,可以尝试国内的镜像源:Index of /qt/archive/qt/ | 清华大学开源软件镜像站 | Tsinghua Open Source Mirror

3.3 安装Qt SDK

安装的第一步点击next即可,然后会出现这个页面:

之后一路点击下一步即可,就是安装路径不要带中文,不要带特殊符号和空格

之后一路确认然后安装即可

 3.4 配置环境变量

先找到我们前面安装Qt时的目录,找到如下bin文件夹,复制路径添加到环境变量中即可:

配环境变量是为了:

  • 让OS或者Qt Creator 工具能够找到Qt SDK 中提供的 exe
  • 让Qt 程序运行的时候,能够找到对应的. dll 动态库 

3.5 认识一些重要工具

可以在开始菜单下找到这个:

都是自带的一些工具程序,也是我们在开发中需要关注的:

①Qt官方文档 

 

  • 我们后面在写一些Qt代码时,可以在这里查某个类某个API,支持直接搜索(是英文的,但是也有中文文档,但是是非官方的,可以自行搜索)
  • 然后后面使用的话,我们一般也不会去开始菜单再找,Qt Creator 里面有快捷方式,后面再介绍

②图形化界面设计工具

  •  Qt 设计师可以通过拖拽控件的方式来快速生成界面,后面会经常使用,搭配Qt Creator 来使用

③国际化工具 

 

  • 国际化就是:有时候我们写的程序是要和国际接轨,比如我们在国内设计时是中文的,但是到了国外需要变成英文等其它语言
  • 允许我们单独创建一个语言配置文件,把界面上需要用到的各种文字,都配置到文件中,并且提前把各种语言的翻译都搞进去,这样就可以起到“一键切换语言”的功能

 ④命令行工具

 

  • 目前绝大多数开发工具都有命令行程序,因为这算是“传统” 

⑤Qt IDE 

 

  • 这个就是我们后面学习和使用Qt的主要工具

四,Qt Creator 的基本使用

4.1 创建项目 

①首先是新建项目:

②然后选择应用程序模板:

③然后是项目路径和名称

④然后是选择构建项目系统:

  •  通过Qt写的程序,涉及到一系列的“元编程”技术,就是通过代码来生成代码
  • Qt框架会在编译的时候会自动调用一系列的生成工具,基于我们自己写的代码,生成一系列的其它C++代码,最终编译的代码,也是最后生成的这些代码
  • 我们选择qmake,是一个老牌的Qt构建工具;CMake并非Qt专属,很多开源项目都会使用CMake,我们Linux系列博客有过介绍;Qbs是新一代构建工具,但是实际上用的人不多,目前已不在维护

⑤下一步就是对部分文件名的编辑:

 

我们介绍下这个Base class:

 

  • 我们使用Qt Creator 创建项目,会自动生成一些代码出来,生成的代码就包含一个类
  • 此处就是要选择这个自动生成的类的父类是哪个,有三个常见选项
  • QMainWindow:是一个完整的应用程序窗口,包含菜单栏工具栏状态栏等
  • QWidget:表示一个控件,表示窗口上的一个具体的元素,比如输入框,按钮,下拉框等
  • QDialog:表示一个对话框
  • 我们最开始学的话选择第二个,这个属于最简单的那个,容易入手;然后后面的文件名我们目前用它默认的(这里生成的文件名是和类名关联的,这种关联不强制,但是推荐大家搞成一样的)

我们再介绍下form file:

  • Qt 中创建图形化界面的程序有两种方式:①直接通过 C++ 代码的方式创建界面    ②通过form file,以图形化的方式来创建界面
  • 如果勾选了这个选框,就可以使用Qt Designe 或者直接使用 Qt Creator 来编辑这个 UI 文件,从而以图形化的方式快速方便地生成图形界面

⑥然后是选择翻译文件

 

  • 这个我们暂时不管,因为这个是和国际化相关地,直接点下一步

⑦选择编译器 

  • 就是选择基于哪个编译器的 Qt SDK 来构建后续代码,这个和我们前面安装时有关,直接下一步  

⑧工程管理工具 

  •  这个功能就是字面意思,比如我们可以选择git,添加到码云上,选择none即可,无影响

上面这些步骤全部完成后点击完成,就把项目创建好了,里面会有一些预备代码,直接点击左下角绿色箭头,就可以先来感受下运行结果了:

4.2 代码解释

创建好项目后会预先生成一些代码,我们来讲解一下这些代码做了什么

main.cpp 

  • main函数参数不多说了,Linux用过很多了,作用是读取命令行参数
  • 编写一个Qt的图形化界面程序,一定需要有 QApplication 对象
  • 然后就是widget对象,这个就是我们前面在创建项目的时候,填写的生成的类名;Widget 的父类就是QWidget
  • 所以上面代码的作用就是“创建一个控件对象,并显示出来”,这里的控件对象就是一个窗口
  •  后面的exec() 表示让程序执行起来,这个exec和Linux的那一系列exec函数不一样,Linux哪个表示“进程程序替换”,可以参考往期博客:Linux系统编程——进程控制_linux maincrtstartup-CSDN博客

widget.h 

 widget.cpp

widget.ui 

双击会直接切换到Qt Designer,然后打开ui文件,就会看到图形化的界面编辑器:

xxx.pro

 

然后,在这个目录的上级目录,有一个和我们项目目录并列的目录: