新闻  |   论坛  |   博客  |   在线研讨会
基于嵌入式Linux测试Qt webengine
toradex | 2018-04-10 15:54:53    阅读:2158   发布文章

ByToradex秦海

1). 简介

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


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



2. 准备

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


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

./ local.conf 文件

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

------------------------------------

#install qt webengine in image

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



3). QT Webengine 示例程序修改和编译

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

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



4). 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

---------------------------------------------------



5). Qt Webengine示例程序演示

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



6). 总结

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


*博客内容为网友个人发布,仅代表博主个人观点,如有侵权请联系工作人员删除。

参与讨论
登录后参与讨论
推荐文章
最近访客