一、介绍
使用Qt库开发的应用程序,一般有两种发布方式:(1)静态编译发布。这种方式使得程序在编译的时候会将Qt核心库全部编译到一个可执行文件中。其优势是简单单一,所有的依赖库都集中在一起,其缺点也很明显,可执行程序体量较大,光Qt核心库加起来就得十多兆。(2)制作安装包发布。这种方式的原理也简单,就是将可执行程序和其依赖的库文件一起打包压缩,制作成安装包发布。制作安装包的工具挺多,今天要说的是Qt官方的安装包制作框架Qt installer framework.这个框架由Qt官方出品,广泛应用于Qt library, Qt Creator等安装包产品。网上搜了一下,相关教程貌似不多。
二、配置使用
下载并安装好Qt installer framework之后,需要创建目标文件夹。所有需要打包的文件都放到这个文件夹下。我的文件夹内容如下:
然后我们需要安装如下的目录组织结构分别创建文件夹,注意的是,一定要安装这样的顺序组织文件夹哦。最简单的方法是从Qt installer framework安装目录下的examples里面复制一个出来,在此基础上进行修改:
我创建的根文件夹名称为sc.在sc下面又创建了两个子文件夹:config和packages。在config文件夹下创建一个config.xml文件,该文件用于定制安装包的UI和行为,其基本格式如下:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
|
<? xml version="1.0"?> < Installer > < Name >Some Application</ Name > < Version >1.0.0</ Version > < Title >Some Application Setup</ Title > < Publisher >Your Company</ Publisher > < ProductUrl >http://www.your-fantastic-company.com</ ProductUrl > < InstallerWindowIcon >installericon</ InstallerWindowIcon > < InstallerApplicationIcon >installericon</ InstallerApplicationIcon > < Logo >logo.png</ Logo > < Watermark >watermark.png</ Watermark > < RunProgram ></ RunProgram > < RunProgramArguments ></ RunProgramArguments > < RunProgramDescription ></ RunProgramDescription > < StartMenuDir >Some Application Entry Dir</ StartMenuDir > < UninstallerName >SDKMaintenanceTool</ UninstallerName > < AllowNonAsciiCharacters >true</ AllowNonAsciiCharacters > < Background >background.png</ Background > < TargetDir >@homeDir@/testinstall</ TargetDir > < AdminTargetDir >@rootDir@/testinstall</ AdminTargetDir > < RemoteRepositories > < Repository > < Url >http://www.your-repo-location/packages/</ Url > </ Repository > </ RemoteRepositories > </ Installer > |
其中,name和version子元素是必需的,其他子元素则是可选的,并且顺序可以任意。关于这些配置项的含义,在官方网站的链接上可以查看。
在上面的图中我们可以看到,我们创建名为org.hust.simulator的文件夹。事实上,Qt installer framework引入了组件的概念。即每一个独立模块可以单独放在一个组件component中,对于大型程序这样清晰的结构有利于工程组织,降低复杂度。例子中比较简单,只使用了一个组件,根据需要可以创建多个组件:
1
2
3
4
5
6
7
8
9
10
11
12
13
|
packages - com.vendor.root - data - meta - com.vendor.root.component1 - data - meta - com.vendor.root.component1.subcomponent1 - data - meta - com.vendor.root.component2 - data - meta |
可以注意到,在packages文件夹下每个组件都需要创建两个子文件夹meta和data。meta目录下用于存放一些配置文件,用于指定安装和部署过程。在meta文件夹中至少需要一个package.xml及所有在该文件中引用到的资源文件,如脚本文件、界面资源、翻译文件等。package.xml文件描述了一个组件的基本信息,其格式如下:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
|
<? xml version="1.0"?> < Package > < DisplayName >QtGui</ DisplayName > < Description >Qt gui libraries</ Description > < Description xml:lang="de_de">Qt GUI Bibliotheken</ Description > < Version >1.2.3</ Version > < ReleaseDate >2009-04-23</ ReleaseDate > < Name >com.vendor.root.component2</ Name > < Dependencies >com.vendor.root.component1</ Dependencies > < Virtual >false</ Virtual > < Licenses > < License name="License Agreement" file="license.txt" /> </ Licenses > < Script >installscript.qs</ Script > < UserInterfaces > < UserInterface >specialpage.ui</ UserInterface > < UserInterface >errorpage.ui</ UserInterface > </ UserInterfaces > < Translations > < Translation >sv_se.qm</ Translation > < Translation >de_de.qm</ Translation > </ Translations > < DownloadableArchives >component2.7z, component2a.7z</ DownloadableArchives > < AutoDependOn >com.vendor.root.component3</ AutoDependOn > < SortingPriority >123</ SortingPriority > < UpdateText >This changed compared to the last release</ UpdateText > < Default >false</ Default > < ForcedInstallation >false</ ForcedInstallation > < Essential >false</ Essential > < Replaces >com.vendor.root.component2old</ Replaces > </ Package > |
其中License节中指定了协议条款,file属性指定了协议条款所在的文件。UserInterfaces和Translations节分别指定了界面资源文件和翻译文件。Script节指定了脚本文件,在脚本文件中可以对安装过程进行更为详细的定制。样例中其他元素名称及值都比较容易懂,对着修改并不困难。全部选项可以上官网查看。
data文件夹中则用于存放我们实际需要打包的程序文件(*.dll, *.exe等),Qt installer framework在制作过程中用archivegen会将这些文件压缩成7zip格式。安装过程中自动从压缩包中提取出数据文件。最后我的文件组织结构如下:
为了方便,我将这个sc文件夹直接拖到了Qt installer framework的安装目录下,这样就可以在命令行下直接使用binarycreator.exe这个工具了。准备工作完成,开始生成安装包:
1
|
binarycreator.exe -c scconfigconfig.xml -p scpackages my_installer.exe -v |
命令运行完成,将在binarycreator.exe所在目录下生成my_installer.exe文件。运行起来看看:
三、小结
从上面看整个配置过程还算是挺简单的,官方手册也很齐全。不得不感叹文档健全就是好啊。以前都是使用其他的工具制作安装包,这次尝试了一下Qt installer framework制作安装包还算满意。
参考
- http://doc.qt.io/qtinstallerframework/ifw-tutorial.html
- http://www.cnblogs.com/dyllove98/archive/2013/06/17/3141316.html
- http://www.qt.io/download-open-source/#
http://www.cnblogs.com/csuftzzk/p/qt-installer-framework.html