Blog:
基于嵌入式Linux测试Qt Webengine

Tuesday, April 10, 2018

简介

QT 5.6版本开始,QT已经正式从webkit组件切换到webengine 组件,新的webengine组件是基于chromium内核引擎,更稳定且更好的支持新的如HTML5等特性,同时具备更好的跨平台性。本文就基于嵌入式Linux平台演示部署Qt提供的webengine 示例应用。

本文所演示的平台来自于Toradex Colibri iMX6 Arm嵌入式平台,这是一个基于NXP iMX6 Arm处理器,支持单核/双核Cortex-A9的计算机模块平台。

准备

a). Colibri iMX6 Arm核心版配合Colibri Eva Board载板,连接调试串口UART1到开发主机方便调试。

b). Colibri iMX6系统使用基于OpenEmbedded框架重新编译的集成Qt5.7 base以及qtwebengine支持的Toradex Linux image releaseV2.7版本以及对应的SDK。这个可以结合这里的说明自己进行编译,需要修改的文件请参考如下,image更新方法请参考这里

./ local.conf 文件

添加如下内容,在生成的image中增加qtwebengine组件

IMAGE_INSTALL_append = " qtwebengine qtwebengine-dev"

./ packagegroup-qt5-toolchain-target.bb 文件

修改方法参考如下patch文件,用于为生成的SDK 增加qtwebengine支持

https://github.com/simonqin09/Qtwebengine_demo/blob/master/packagegroup-qt5-toolchain_add_webengine.patch

c). 关于开发主机SDK安装和Qtcreator开发环境的配置请参考之前发布的《嵌入式Linux基于Qt开发GPIO应用一文》。

d). 演示程序使用的LCD10inch 18bit LVDS屏幕,请参考这里修改配置uboot显示分辨率为1024x768

QT Webengine 示例程序修改和编译

为了方便,本文演示应用程序直接使用Qt 5.7 自带的 Webengine Quick Nano Brower 示例程序,这是一个基于Qt QuickWebengine开发的精简浏览器示例。

a). 为了增加对中文的支持,首先如下修改 main.cpp 文件

https://github.com/simonqin09/Qtwebengine_demo/blob/master/patch_add_chinese_font.patch

说明如下:

./ 中文字体文件在运行的时候要放置到上面代码里面设定的 /home/root/fonts/STKAITI.TTF 位置,这个位置也可以自行修改。

./ 本文所使用的字体文件请从这里下载

./ 字体大小这里设置为10,也可以自行修改。

b). 为了适配LCD屏幕,需要修改应用GUI显示分辨率

./ BrowserWindow.qml 文件,如下修改

ApplicationWindow {

……


width: 1024
height: 768

visible: true
title: currentWebView && currentWebView.title

b). 配置好交叉编译后,将编译生成的可执行文件 quicknanobrower

Qt Webengine程序部署配置

a). 将编译好的可执行程序 quicknanobrower复制到Colibri iMX6模块 “/home/root” 目录下,同时放置字体文件 STKAITI.TTF /home/root/fonts 目录下

b). 设置应用开机自启动

./ qt5-x11-demo-init,程序启动脚本文件

https://github.com/simonqin09/Qtwebengine_demo/blob/master/qt5-x11-demo-init

$ cp qt5-x11-demo-init /usr/bin
$ chmod +x qt5-x11-demo-init

./ qt5-x11-demo.servicesystemd自启动配置文件,详细说明可以参考这里

https://github.com/simonqin09/Qtwebengine_demo/blob/master/qt5-x11-demo.service

$ cp qt5-x11-demo.service /etc/systemd/system/
$ systemctl enable qt5-x11-demo.service

Qt Webengine示例程序演示

a). 开机后,系统自动启动程序,如下所示

总结

本文基于NXP iMX6嵌入式平台在嵌入式linux系统下演示Qt Webengine 示例应用编译和部署,具体实际应用可以参考此示例进行开发。

Author: 秦海,技术销售工程师,韬睿(上海)
Share this on:

Leave a comment

Please login to leave a comment!
Have a Question?