QT 6 windows 编译避坑

感谢:Qt 静态编译与使用(6.2 详解版)_余识-的博客-CSDN博客_qt6静态编译

参考上面文章大部分编译基本顺利。

下载QT6.2.4

Index of /qt/ | 清华大学开源软件镜像站 | Tsinghua Open Source Mirror

解压源码到qt-everywhere-src-6.2.4\

编译前准备为避免库冲突 建议使用干净的一台电脑,否则路径很多需要排查太多。

安装准备


 

(1) Node.js node-v16.16.0-x64.msi  (nodejs.org) 编译WebEngine 时需要

(2)CMAKE 必须下载大于3.21版本 cmake-3.23.3-windows-x86_64.zip

        https://www.CMake.org

(3)PERL 

The Perl Programming Language - www.perl.org

strawberry-perl应该也可以,但是因为里面保护MinGWC++ 导致后面static 编译异常 ,建议使用ActiveState Perl,简洁。

strawberry-perl-5.32.1.1-64bit-portable

(4)Ninja

github Release v1.11.0 · ninja-build/ninja · GitHub下载解压到D:\program\ninja-win

(5)Python

python.org 下载python 3.9  使用过anaconda 发现当anaconda  安装其他库,使用编译时找到但是又无法编译时,排除错误很痛苦。测试几轮后放弃。使用最精简的python了。

(6)VS2019 community 

  visualstudio.com

(7)编译QT WebEngine

安装python 2.7 为避免冲突python2.7 安装后注意修改名称为python2.exe

需要gperf bison flex 这些应该是词法分析或hash相关可执行程序

 https://ftp.gnu.org/gnu/gperf/
https://github.com/jwinarske/gperf
http://gnuwin32.sourceforge.net/packages/bison.htm
http://gnuwin32.sourceforge.net/packages/flex.htm

 下载https://gn.googlesource.com/gn/

gn需要FanQiang 下载,但是怀疑cmake bug gn说要求版本6.2.4 但是其实gn未查到此版本

注意下载时所有gperf bison flex 测试一下是否能够执行

同步bison 下载需要同时下载depends库

准备编译环境

(1)设置编译路径

我安装的除了NODE.js,安装时为避免冲突和异常都未添加path

此处需要在环境下执行

 set PATH=d:\Qt\qt-everywhere-src-6.2.4\build\qtbase\bin;D:\program\python3.9;D:\program\cmake-3.23.3\bin\;D:\program\ninja-win;D:\program\Perl64\bin\;%PATH%

测试

perl --version

cmake --version

ninja --version

python -V

均需要能够正确显示结果

(2)配置

静态库编译

..\configure -static -prefix d:\Qt\6.2.4-static -release -opensource

动态库编译

..\configure  -prefix d:\Qt\6.2.4-Release -release -opensource

(3)编译

cmake --build .

编译时可以采用多线程cmake --build . --parallel 5(线程数)

编译时偶尔遇到错误(我经常发生) 继续编译几次。可以成功。

注意VS2019 自带的cmake版本过低,一定记得自己下载


cmake --install .

注意:64位还是32位 由VC 2019 自己指定了

上文中的设置应该时无效的

安装QT

从 d:\Qt\6.2.4-Release 目录中就是编译后的结果。

(1)清华源可以下载以下软件并安装

qt-creator-opensource-windows-x86_64-8.0.0

qt-vsaddin-msvc2019-2.8.1-rev.06.vsix        QT add ON

注意qt-creator 断网安装可以跳过注册。

(2)qt-creator安装


  

配置cmake

  

(3)VS2019安装

选择qmake所在路径即可

未解决问题

      qtpdf 未编译成功

需要注意的是,在configure时可以看到哪些库是否支持。


 

### 使用Qt构建QGroundControl(QGC)地面站教程 #### 准备工作 为了成功搭建Qt5.15.2 for Android编译QGroundControl (QGC),需要先准备好开发环境。可以从GitHub上获取最新的源码[^1]。 #### 下载源码 访问官方GitHub仓库下载最新版的QGroundControl源码: - GitHub地址: https://github.com/mavlink/qgroundcontrol 对于不同的需求可以选择不同分支进行下载,当前存在两个主要维护版本:一个是master版本;另一个是4.3版本。master版本推荐使用Qt 6.6以上版本来构建,而4.3版本则基于Qt 5.15.2构建[^2]。 #### 配置Qt Creator 启动Qt Creator IDE,通过菜单栏中的`File -> Open Project...`选项加载已下载好的QGC项目文件。确保选择了正确的Kit设置,即针对桌面平台应选用 `Desktop Qt 5.15.2 MSVC2019 64bit`作为编译工具链[^3]。 ```cpp // Example of Kit selection within QtCreator settings dialog. QString kitName = "Desktop Qt 5.15.2 MSVC2019 64bit"; ``` #### 编译过程 点击IDE内的绿色播放图标即可触发自动化的构建流程以及应用程序执行操作。如果一切顺利的话,在完成整个编译周期后应该能够看到正常工作的QGC图形化界面显示出来。 另外一种方式是在命令行接口(CLI)下利用CMake配合Ninja生成器来进行更灵活的手动控制: 1. 切换至解压后的qgc源代码根目录; 2. 执行如下指令完成初步配置阶段的工作: ```bash cmake -B build -G Ninja -DCMAKE_BUILD_TYPE=Debug .. ``` 3. 接着继续输入下面这条语句实现实际意义上的编译动作 ```bash cmake --build build --config Debug ``` 4. 当所有目标都已完成链接之后就可以尝试启动新创建出来的可执行文件了: ```bash ./build/QGroundControl ``` 最后一步用于打包发布用途时可以采用安装模式下的构建方法: ```bash cmake --install . --config Release ``` 这会把最终产物放置于指定位置以便分发给其他用户群体使用。 #### 自定义品牌信息 如果有意调整应用名称或是替换掉原有的LOGO图像资源,则可以在源码树内找到对应的文件加以编辑修改。具体而言就是定位到`QGCApplication.cc`里的构造函数部分实施必要的更改措施[^4]。
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值