Qt 把.exe打包成安装文件形式

news2024/12/22 9:38:20

目录

  • 1.下载工具 Qt Installer Framework
  • 2.将`bin`文件添加到环境变量
  • 3.拷贝`startmenu`示例-备用
  • 4.准备Qt Release打包好的程序
  • 5.把Release打包好的程序放到`packages\org.qtproject.ifw.example\data`文件夹下
  • 6.生成安装包
  • 7.修改安装包图标
  • 8.修改主程序程序安装引导-创建快捷键
  • 9.添加驱动安装包
  • 10.嫌弃打包耗时太长?

Qt Installer Framework 使用

1.下载工具 Qt Installer Framework

官网下载链接
下载直接安装
在这里插入图片描述

2.将bin文件添加到环境变量

在这里插入图片描述

3.拷贝startmenu示例-备用

在这里插入图片描述

4.准备Qt Release打包好的程序

确保自己的.exe能够正常运行,没有缺少dll文件
在这里插入图片描述

5.把Release打包好的程序放到packages\org.qtproject.ifw.example\data文件夹下

在这里插入图片描述

6.生成安装包

回到startmenu目录下,打开CMD终端,执行指令

binarycreator --offline-only -c config/config.xml -p packages install.exe -v

脚本程序生成脚本.bat

@echo off
start cmd /k "binarycreator --offline-only -c config/config.xml -p packages install.exe -v"

在这里插入图片描述

在这里插入图片描述
不出意外,正常生成安装包,双击即可安装
在这里插入图片描述

7.修改安装包图标

在这里插入图片描述
startmenu\config文件夹下准备3张图片

在这里插入图片描述
修改startmenu\config\config.xml文件

<?xml version="1.0" encoding="UTF-8"?>
<Installer>
    <Name>软件名称</Name><!-- 软件名称 -->
    <Version>0.1.3</Version><!-- 版本号 -->
    <Title>安装程序窗口标题</Title><!-- 安装程序窗口标题 -->
    <Publisher>公司名称</Publisher><!-- 公司名称 -->
    <!-- Directory name is used in component.xml -->
    <StartMenuDir>Ancel IR</StartMenuDir><!-- 要生成的windows开始菜单目录 -->
    <TargetDir>@HomeDir@/APPPath</TargetDir><!-- 默认安装路径 -->
    <Logo>logo.png</Logo>
    <InstallerApplicationIcon>app</InstallerApplicationIcon><!-- app.ico,但是不要ico后缀 -->
    <InstallerWindowIcon>app.png</InstallerWindowIcon>
</Installer>

重新生成后,安装过程中引导语,图标就是我们自定义的了
在这里插入图片描述
在这里插入图片描述

8.修改主程序程序安装引导-创建快捷键

修改文件packages\org.qtproject.ifw.example\meta\package.xml

<?xml version="1.0" encoding="UTF-8"?>
<Package>
    <DisplayName>主程序</DisplayName>
    <Description>主程序描述.</Description>
    <Version>1.0.0-1</Version>
    <ReleaseDate>2013-01-01</ReleaseDate>
    <Default>true</Default>
    <Script>installscript.qs</Script>
</Package>

在这里插入图片描述
创建快捷键
修改文件packages\org.qtproject.ifw.example\meta\installscript.qs

function Component()
{
    // default constructor
}

Component.prototype.createOperations = function()
{
    component.createOperations();

    //开始菜单的快捷方式
    component.addOperation
    (
        "CreateShortcut",
        "@TargetDir@\\debug.exe",
        "@StartMenuDir@\\debug.lnk",
        "workingDirectory=@TargetDir@",
        "description=Open Application"
    );

    //桌面快捷方式
    component.addOperation
    (
        "CreateShortcut",
        "@TargetDir@\\debug.exe",
        "@DesktopDir@\\debug.lnk",
        "workingDirectory=@TargetDir@",
        "description=Open Application"
    );
}

在这里插入图片描述

9.添加驱动安装包

这里以安装CH340串口驱动为例
把原来的org.qtproject.ifw.example拷贝一份,重命名为driver
在这里插入图片描述
把ch340驱动程序放到packages\driver\data目录下
在这里插入图片描述
在这里插入图片描述
修改文件packages\driver\meta\installscript.qs

function Component()
{
    // default constructor
}

Component.prototype.createOperations = function()
{
    component.createOperations();
    if (systemInfo.productType === "windows")
    {
        component.addElevatedOperation("Execute", "{0,1,256}", "@TargetDir@\\CH341SER_2.EXE");
        component.addElevatedOperation("Delete", "@TargetDir@\\CH341SER_2.EXE");
    }

}

修改文件packages\driver\meta\package.xml

<?xml version="1.0" encoding="UTF-8"?>
<Package>
    <DisplayName>CH340驱动</DisplayName>
    <Description>CH340驱动描述</Description>
    <Version>1.0.0-1</Version>
    <ReleaseDate>2013-01-01</ReleaseDate>
    <Default>true</Default>
    <Script>installscript.qs</Script>
    <RequiresAdminRights>true</RequiresAdminRights> <!-- 代表用管理员权限安装这个组件 -->
</Package>

安装的过程就会自动弹出CH340安装请求
在这里插入图片描述

10.嫌弃打包耗时太长?

全选所有文件,右键,然后压缩成data.7z
不要创建 data 文件夹,再压缩
在这里插入图片描述
最后得效果是这样
在这里插入图片描述
如果有驱动,也一样压缩成.7z
在这里插入图片描述
在这里插入图片描述
再次执行生成安装包指令,2s就能出来install.exe安装包

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1625225.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

vue快速入门(四十四)自定义组件

注释很详细&#xff0c;直接上代码 上一篇 新增内容 全局注册自定义组件并应用局部注册自定义组件并应用 此篇使用了axios模块没有安装导入的先看这一篇 axios模块下载与导入 源码 main.js import Vue from vue import App from ./App.vue//全局引入axios // 引入axios impor…

(九)Pandas表格样式 学习简要笔记 #Python #CDA学习打卡

目录 一. Pandas表格样式 1&#xff09;举例数据 2&#xff09;字体颜色 3&#xff09;背景高亮 4&#xff09;极值背景高亮 &#xff08;a&#xff09;高亮最大值 highlight_max() &#xff08;b&#xff09;高亮最小值 highlight_min() &#xff08;c&#xff09;同时…

viewerjs在vue中实现点击图片预览、切换、缩放、拖拽、旋转等功能

1、下载依赖&#xff1a; npm i viewerjs 2、定义html结构 <template> <div><ul class"artBody"><li><img src"picture-1.jpg" alt"Picture 1"></li><li><img src"picture-2.jpg" alt&…

WinForm右键菜单的快键键设置

Form中有一个富文本框控件&#xff0c;在里面右键鼠标&#xff0c;弹出下拉菜单。快捷键的效果则是按下altp,触发按下属性事件。 1.从工具箱添加RichTextBox 2.然后添加ContextMenuStrip 3.选择RichTextBox的ContextMenuStrip属性值为contextMenuStrip1 4.按照下图设置“属…

基于Python实现心脏病数据可视化DEA+预测【500010103.1】

一、数据说明 该心脏病数据集是通过组合 5 个已经独立可用但以前未合并的流行心脏病数据集来策划的。在这个数据集中&#xff0c;5 个心脏数据集结合了 11 个共同特征&#xff0c;使其成为迄今为止可用于研究目的的最大心脏病数据集。 该数据集由 1190 个实例和 11 个特征组成…

Springboot+Vue项目-基于Java+MySQL的IT技术交流和分享平台系统(附源码+演示视频+LW)

大家好&#xff01;我是程序猿老A&#xff0c;感谢您阅读本文&#xff0c;欢迎一键三连哦。 &#x1f49e;当前专栏&#xff1a;Java毕业设计 精彩专栏推荐&#x1f447;&#x1f3fb;&#x1f447;&#x1f3fb;&#x1f447;&#x1f3fb; &#x1f380; Python毕业设计 &…

【人工智能】AIGC(Artificial Intelligence Generated Content)

随着生成式 AI 应用快速进入市场&#xff0c;以及越来越多大模型的不断面世&#xff0c;2023 年已经成为生成式 AI 的元年&#xff1a;不同区域、各行各业、不同领域的人们开始尝试在工作和生活中使用生成式 AI&#xff0c;以探索各种可能性。于企业而言&#xff0c;生成式 AI …

Matlab图像处理-均值滤波,中值滤波和高斯滤波。

针对添加了零均值高斯噪声的图像&#xff0c;以取得尽可能好的处理效果为目的&#xff0c;采用不少于3种方法进行处理&#xff1b;对处理结果进行定性和定量的比较、并得出相应的结论。 1.算法原理&#xff1a; 采用的图像滤波包括均值滤波&#xff0c;中值滤波和高斯滤波。 …

算法基础:并查集详解

并查集 并查集&#xff0c;在一些有N个元素的集合应用问题中&#xff0c;我们通常是在开始时让每个元素构成一个单元素的集合&#xff0c;然后按一定顺序将属于同一组的元素所在的集合合并&#xff0c;其间要反复查找一个元素在哪个集合中。这一类问题近几年来反复出现在信息学…

【网络编程】网络编程概念 | TCP和UDP的区别 | UDP数据报套接字编程 | Socket

文章目录 网络编程一、什么是网络编程1.TCP和UDP的区别 二、UDP数据报套接字编程DatagramSocketDatagramPacket回显服务器&#xff08;echo server&#xff09; 网络编程 一、什么是网络编程 通过网络&#xff0c;让两个主机之间能够进行通信。基于通信来完成一定的功能。 ​…

Linux网络-DNS域名解析服务

目录 一.DNS相关介绍 1.DNS是什么 2.DNS系统的分布式数据结构 根域 顶级域 二级域 子域 主机 3.服务器类型 主域名服务器 从域名服务器 缓存域名服务器 转发域名服务器 二.DNS域名解析 1.DNS域名解析方式及功能 2.DNS域名解析查询方式 2.1.递归查询&#xff0…

Verilog基础语法——parameter、localparam与`define

Verilog基础语法——parameter、localparam与define 写在前面一、localparam二、parameter三、define写在最后 写在前面 在使用Verilog编写RTL代码时&#xff0c;如果需要定义一个常量&#xff0c;可以使用define、parameter和localparam三种进行定义与赋值。 一、localparam …

施耐德EOCR-2CT-300/5电流互感器 50HZ 5VA

EOCR主要产品有电子式电动机保护继电器&#xff0c;电子式过电流继电器&#xff0c;电子式欠电流继电器&#xff0c;电子式欠电压继电器&#xff0c;其它保护和监视装置&#xff0c;电流互感器。 施耐德EOCR-2CT-300/5电流互感器 EOCR-2CT系列型号&#xff1a; EOCR 2CT 100…

操作系统安全:Linux安全审计,Linux日志详解

「作者简介」&#xff1a;2022年北京冬奥会网络安全中国代表队&#xff0c;CSDN Top100&#xff0c;就职奇安信多年&#xff0c;以实战工作为基础对安全知识体系进行总结与归纳&#xff0c;著作适用于快速入门的 《网络安全自学教程》&#xff0c;内容涵盖系统安全、信息收集等…

18.Nacos配置管理-微服务读取Nacos中的配置

需要解决的问题 1.实现配置更改热更新&#xff0c;而不是改动了配置文件还要去重启服务才能生效。 2.对多个微服务的配置文件统一集中管理。而不是需要对每个微服务逐一去修改配置文件&#xff0c;特别是公共通用的配置。 配置管理服务中的配置发生改变后&#xff0c;回去立…

leetcode-二叉树的镜像-91

题目要求 思路1 1.遍历一遍二叉树&#xff0c;将左边的结点对应创建一个右边的结点 2.用此方法空间复杂度O(n)&#xff0c;并不是最优 思路2 1.将一个结点的左右子树进行交换&#xff0c;如果左子树还有左右结点&#xff0c;就再交换左子树的左右结点&#xff0c;以此递归下去…

vscode 创建代码模版

在vscode中快捷创建代码模版 1.在VSCode中&#xff0c;按下Ctrl Shift P&#xff08;Windows/Linux&#xff09;或Cmd Shift P&#xff08;Mac&#xff09;打开命令面板。 2.然后输入"Preferences: Configure User Snippets"并选择该选项。打开一个json文件用户…

Python函数小知识

目录 一、函数的定义和调用 二、函数参数 三、函数作用域 四、递归函数和匿名函数 一、函数的定义和调用 def 函数名(参数): 自定义函数可以分为有参函数和无参函数 。 函数的作用&#xff1a; 在Python中定义函数可以提高代码的复用率&#xff0c;避免重复的代码&#xff0c;…

matlab保存示波器数据

再重新运行一下示波器 然后就可以在工作区看见&#xff08;这里没有运行所以没有&#xff09; 将保存到文件夹中方便后续绘图

服务于金融新核心系统 星辰天合与中电金信完成产品兼容认证

近日&#xff0c;北京星辰天合科技股份有限公司&#xff08;简称&#xff1a;XSKY星辰天合&#xff09;与中电金信软件有限公司&#xff08;简称&#xff1a;中电金信&#xff09;完成产品兼容性认证&#xff0c;星辰天合的企业级分布式统一数据平台 XEDP 符合金融级数字底座&q…