【Ubuntu工具】避坑指南:搞坏一台电脑,终于在Ubuntu系统上成功源码安装了 QT WebEngine 5.15.13

上篇文章(【Ubuntu工具】安装教程:Ubuntu系统上源码编译安装QT5.15.13(有坑))我们通过源码成功编译安装了 QT5.15.13版本,但是里面是不包含 QWebEngine 这个组件的。这个组件是实现 QT + Web 页面开发必不可少的一部分。所以,咱们需要再源码编译安装一下这个组件。这个坑更多(主要是依赖太多),本文将用最少的步骤,带你避坑,成功安装 QWebEngine 5.15.13。

我这里有编译好的Ubuntu20.04平台的QWebEngine 5.15.13,需要的可以联系我免费要。

0. 源码下载及准备

有两种下载源码的方法。

0.1 通过官网下载源码

(1)下载地址:https://download.qt.io/archive/qt/5.15/5.15.13/submodules/

在这里插入图片描述

(2)解压到本地目录

(3)进入目录

0.2 通过 Git 下载源码

这个过程比通过上面官方直接下载源码要慢。

git clone https://code.qt.io/cgit/qt/qtwebengine.git
cd qtwebengine
git checkout 5.15.13
git submodule update --init --progress

1. 安装过程

(1)新建一个build文件夹,进入build文件夹

mkdir build
cd build

(2)qmake + make编译

注意这里的qmake要替换成你的 QT5.15.13 版本的qmake的路径,例如 /opt/Qt5.15.13/5.15.13/gcc_64/bin/qmake

qmake .. -- -proprietary-codecs
make -j8

这里不需要指定安装目录,它的安装目录是 qmake 所在的 QT 的路径

如果运气好,这里编译过了,也就基本算能安装成功了,直接执行下面的安装命令即可:

(3)安装

sudo make install

但是,80%的概率,你会遇到问题,下面来展开说说我遇到的坑。

2. 踩坑

踩坑的步骤主要在 qmake + make 编译阶段。

2.1 QtWebEngine will not be built

在运行 qmake 命令时,配置列表后经常会出现 QtWebEngine will not be built 这样的提示,这表明依赖的环境不OK,需要先安装依赖的内容。根据提示安装依赖的库即可。下面我列出了可能需要的依赖库,大家在 qmake 前都安装一下:

sudo apt-get install libx11-*
sudo apt-get install libx11*
sudo apt-get install libxcb-*
sudo apt-get install libxcb*
sudo apt-get install libxkbcommon-devsudo
sudo apt-get install libxkbcommon-x11-dev
sudo apt-get install libxcb-xinerama0-dev
sudo apt-get install libxcb-sync-dev
sudo apt install libnss3-dev
sudo apt-get install libfontconfig1-dev 
sudo apt-get install libxtst-dev
sudo apt-get install libxcomposite-dev
sudo apt-get install libxkbfile-dev
sudo apt-get install libxcursor-dev
sudo apt install dbus dbus-tests libdbus-glib-1-dev
sudo apt install llvm
sudo apt-get install libclang-dev
sudo apt install gperf
sudo apt install bison flex 
sudo apt install nodejs npm

qmake执行完之后,出现以下界面,最底部没有任何提示,才算是qmake成功,否则仍然需要安装相关依赖库,直到没有提示为止。

在这里插入图片描述

2.2 WARNING: Could not find all necessary libraries for qpa-xcb support in QtWebEngine.

这是因为缺少部分依赖库,安装 2.1 中的那些库应该可以解决此问题

2.3 fatal error: X11/extensions/Xrandr.h: No such file or directory

安装依赖库:

sudo apt install libxrandr-dev

2.4 fatal error: X11/extensions/Xdamage.h: No such file or directory

安装依赖库:

sudo apt install libxdamage-dev

2.5 编译错误:double-conversion

安装依赖库:

sudo apt install libdouble-conversion-dev

3. 总结

源码编译安装 QT WebEngine 其实步骤很明确,就是 qmake, make, make install,但是其依赖的库太多了,所以非常容易遇到问题。

我是在 Ubuntu20.04 中编译成功了 5.15.13 版本。 Ubuntu18.04 理论上也可以成功,但是不知道什么原因,在我的Ubuntu18.04中编译时,必现卡死,为此还重装过一遍系统… 感兴趣的可以试一试。

附:QWebEngine各版本对应的浏览器内核版本

大多数人装 QWebEngine 都是为了开发 QT + Web 的应用,因此了解每个版本对应的浏览器内核版本非常重要。下面是官方文档中的版本对应关系:

参考:https://wiki.qt.io/QtWebEngine/ChromiumVersions

在这里插入图片描述

如果觉得本文对你有帮助,麻烦点个赞和关注呗 ~~~


  • 大家好,我是 同学小张,日常分享AI知识和实战案例
  • 欢迎 点赞 + 关注 👏,持续学习持续干货输出
  • +v: jasper_8017 一起交流💬,一起进步💪。
  • 微信公众号也可搜同学小张 🙏

本站文章一览:

在这里插入图片描述

### 安装前准备 为了确保顺利安装 Qt 5.15,在 Ubuntu 20.04 上需先更新系统的软件包列表并安装必要的依赖项。这可以通过运行以下命令来完成: ```bash sudo apt update && sudo apt upgrade -y ``` 接着,安装一些编译所需的开发工具和库文件,这些对于构建 Qt 是必需的。 ```bash sudo apt install build-essential libgl1-mesa-dev libgles2-mesa-dev \ libegl1-mesa-dev g++ cmake perl python3 ruby git subversion \ flex bison gperf libicu-dev libxslt-dev libssl-dev \ libxcursor-dev libxcomposite-dev libxdamage-dev libxrandr-dev \ libdbus-1-dev libfontconfig1-dev libcap-dev libcups2-dev \ libxml2-dev libxrender-dev libalsa-dev libpulse-dev \ libudev-dev libpci-dev libnss3-dev libglib2.0-dev \ libgtk-3-dev qtbase5-private-dev qtmultimedia5-dev \ libsdl2-dev glew-utils libfreetype6-dev[^3] ``` ### 下载 Qt 5.15 源码 可以从官方渠道获取指定版本的源代码压缩包。这里提供了一种通过 `wget` 工具直接从网络下载的方式: ```bash wget https://download.qt.io/official_releases/qt/5.15/5.15.15/single/qt-everywhere-src-5.15.15.tar.xz tar xf qt-everywhere-src-5.15.15.tar.xz cd qt-everywhere-src-5.15.15 ``` ### 配置与编译 进入解压后的目录后,可以开始配置环境变量以及启动编译过程。建议创建一个新的虚拟环境中执行此操作以保持系统清洁。 ```bash ./configure -prefix /opt/qt5.15 -nomake tests -skip webengine make -j$(nproc) sudo make install ``` 上述命令中的选项解释如下: - `-prefix`: 设置安装路径; - `-release`: 构建发布版而非调试版; - `-opensource`: 使用开源许可协议; - `-confirm-license`: 自动同意许可证条款; - `-nomake examples/tests`: 跳过示例程序和测试套件的编译- `-skip webengine`: 不包含 WebEngine 组件,因为其编译时间较长且占用大量资源; ### 环境设置 为了让新安装Qt 可用于当前用户的 shell 会话中,需要修改 `.bashrc` 或者其他相应的 Shell 初始化脚本(取决于使用的Shell),添加下面两行到该文件末尾以便于后续项目能够找到 Qt 库的位置。 ```bash export PATH=/opt/qt5.15/bin:$PATH export LD_LIBRARY_PATH=/opt/qt5.15/lib:$LD_LIBRARY_PATH source ~/.bashrc ``` 最后重启终端使更改生效即可验证是否成功安装了所需版本的 Qt
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

同学小张

如果觉得有帮助,欢迎给我鼓励!

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值