0
  • 聊天消息
  • 系统消息
  • 评论与回复
登录后你可以
  • 下载海量资料
  • 学习在线课程
  • 观看技术视频
  • 写文章/发帖/加入社区
创作中心

完善资料让更多小伙伴认识你,还能领取20积分哦,立即完善>

3天内不再提示

峰会回顾第29期 | Qt For OpenHarmony

OpenHarmony TSC 来源:OpenHarmony TSC 作者:OpenHarmony TSC 2023-09-07 08:45 次阅读

演讲嘉宾 | 蔡万苍

回顾整理 | 廖 涛

排版校对 | 李萍萍

b482039e-4d17-11ee-bb52-92fbcf53809c.png

嘉宾简介

蔡万苍,13年C++/Qt开发相关工作经验,曾任职Qt公司,担任技术支持、Qt咨询师,协助国内多家Qt企业版用户完成基于Qt的软件框架搭建,参与Qt开源社区Bug维护及修改,在基于Qt框架的软件架构设计、Qt跨平台适配上有多年的技术积累和经验,开源书籍QmlBook-in-Chinese在github上star数达到1000+,现任职于软通动力信息技术(集团)股份有限公司,担任成都图形框架研究院软件开发专家角色,负责图形框架研究院的技术管理工作。

内容来源

第一届开放原子开源基金会OpenHarmony技术峰会——生态与互联分论坛

视频回顾

打开 哔哩哔哩APP 搜索 OpenHarmony-TSC 视频更清晰

正 文 内 容

在全球超过70个行业,8000家公司,100万的开发者都在使用Qt,通过Qt适配OpenHarmony,能够丰富OpenHarmony的开发生态、应用生态,加速OpenHarmony在各行业的推广使用。如何推进和完成Qt在OpenHarmony上的适配呢?软通动力成都图形框架研究院软件开发专家蔡万苍在第一届OpenHarmony技术峰会上分享了精彩观点。

b4d84c68-4d17-11ee-bb52-92fbcf53809c.png

01

Qt 适配 OpenHarmony 意义

Qt是一个C++跨平台开发框架,主要用于开发图形用户界面(Graphical User Interface,GUI)程序,具有跨平台类库(支持目前所有主流软硬件平台组合)、集成开发工具(缩短软件产品上市时间)以及跨平台集成开发环境(高生产力开发环境)等。全球超过100万研发者使用过Qt,Qt的跨平台开发能力覆盖70多个行业,是从1994年至今得到广泛的认同和验证的主流技术。

b4f7fc20-4d17-11ee-bb52-92fbcf53809c.png

Qt适配OpenHarmony有什么意义?

一、扩大OpenHarmony开发者阵营:基于Qt跨平台特性及Qt For OpenHarmony的适配,吸引数量庞大的Qt开发人员在OpenHarmony上进行跨平台应用迁移及应用开发,能够实现开发人员业务目标与个人能力和OpenHarmony开源生态与技术发展的双赢。

二、丰富OpenHarmony应用生态:Qt支持目前主流的所有操作系统,如UBuntu、CentOS、OpenEuler、Android、OS X、iOS、Windows、VxWorks、QNX等,涵盖从嵌入式平台、移动平台及PC桌面,基于Qt框架典型的桌面应用,从娱乐到工业软件都有所涉及,如暴雪的战网客户端、WPS、VirtualBox等等,大部分应用程序都可以使用Qt实现。通过Qt适配OpenHarmony,能够加速OpenHarmony的行业应用推广。

02

计划贡献内容

2.1►►

适配计划

Qt按使用及部署划分,包含了设计工具、开发工具、框架必要模块、框架附加模块4个部分,基于OpenHarmony跨平台开发考虑,总体计划如下:

针对OpenHarmony的开发工具进行补充

对Qt必要模块进行适配支持

对部分Qt附加模块适配支持

b521cff0-4d17-11ee-bb52-92fbcf53809c.png

具体工作如下:

成立 OH_QT sig,完成Qt Core(Qt核心模块)、Qt GUI(显示相关代码)以及Qt QML适配

完成Qt工程部署,适配Qt相关的开发工具,实现Qt应用程序北向开发封装;适配Qt附加库部分,如Qt Multimedia,QtRemoteObjects

完成Qt示例及DEMO适配验证、Qt单元测试适配验证;向Qt社区申请立项OpenHarmony支持,申请OH_QT sig毕业

开发Qt工程转换DevEco工程工具实现快速的应用迁移配置

2.2►►

Qt 配套开发工具

Qt开发者通常使用Qt配套的集成开发环境Qt Creator,采用qmake或cmake进行软件工程管理配置,为方便开发者对已有软件进行移植适配,我们会开发对应的工程转换工具,将Qt的应用工程转换为DevEco Application工程,帮助开发者快速实现应用的迁移配置。

03

技术难点分享

Qt本身是跨平台的框架,我们要把它跟OpenHarmony做移植,无非考虑几个问题:一是Qt应用程序的界面如何在OpenHarmony上进行显示;OpenHarmony本身触屏的输入、鼠标/键盘的输入怎么能够把它映射到Qt本身的应用程序框架里去。需要了解Qt的QPA实现及系统接口调用的相关逻辑,就能实现Qt应用程序在OpenHarmony上的运行。

3.1►►

QPA 实现及系统接口调用

Qt平台抽象(QPA)是Qt的平台抽象层,QPA插件是通过子类化各种QPlatform*类来实现系统接口的接入,例如用于窗口系统集成的QPlatformIntegration和QPlatformWindow以及用于更深层次的平台主题化和集成的QPlatformTheme。

b530a52a-4d17-11ee-bb52-92fbcf53809c.png

QPA核心对象及作用:通过QPlatfromIntegration实现对QPA插件的对象声明周期管理,Qt GUI等模块通过Qt已完成的平台抽象层相关类实现对系统底层的调用,其中比较重要的实现类包括:EventDispatcher(实现系统底层事件接入)、BackingStore(系统图形绘制双缓存实现)、Screen(系统屏幕对象,用于管理Window显示)、Window(系统窗口对象)、InputContext(系统输入处理,包括鼠标、输入法等)、OpenGLContext(系统窗口OpenGL渲染上下文)以及Clipboard(系统剪切板)。

b54edd2e-4d17-11ee-bb52-92fbcf53809c.png

Qt Widget For OpenHarmony渲染流程:基于Qt框架自成体系的图形框架和事件系统,在OpenHarmony上基于XComponent生成的EGLSurface,采用图像二维绘制的方式在OpenGL Surface上实现双缓存渲染机制,完成Qt Widget的窗口内容渲染。

b561d0d2-4d17-11ee-bb52-92fbcf53809c.png

Qt Quick For OpenHarmony渲染流程:Qt Quick采用自成体系的Scene Graph基于OpenGL标准接口实现,QPA OpenHarmony插件基于XCompent生成EGL Surface,并通过QPA标准实现类重载实现PlatformIntegration实现与Scene Graph的OpenGLContext绑定,Qt Quick基于标准OpenGL接口在XComponent上实现图形渲染。

b5713b8a-4d17-11ee-bb52-92fbcf53809c.png

OpenHarmony Touch事件接入:基于XComponent的事件监控回调,在QPA的InputContext实现中实现对XComponent的输入监控,将监控的输入转换为Qt Event发送到Qt Event队列中,由Qt框架实现对输入的处理,完成对触屏操作和鼠标操作的处理。

b5891480-4d17-11ee-bb52-92fbcf53809c.png

基于NAPI的应用框架接口调用:基于OpenHarmony的应用接口规范,部分接口未提供NDK接口,需要通过Node.JS的C++插件NAPI调用ETS SDK的接口进行实现,QPA For OpenHarmony部分系统接口采用该种方式完成对系统接口的调用,例如系统剪切板。

b59f0b14-4d17-11ee-bb52-92fbcf53809c.png

基于TS脚本自定义符合Qt标准的对话框:Qt上层接口的QMessageBox支持系统默认样式对话框弹出,该接口在OpenHarmony的SDK中有提供,由于参数差异,无法通过NAPI直接调用,我们采用ETS语言实现后导入到DialogHelpers中进行使用。目前系统输入法采用NAPI接口进行调用,通过Custom ETS实现对系统输入法的调用进行监控,再传入Qt Input Context转换为Qt Key Event输入到Qt框架,由于输入法的高性能要求,后续会与OpenHarmony团队进行沟通,考虑开放系统底层输入法NDK接口。

b5b644f0-4d17-11ee-bb52-92fbcf53809c.png

3.2►►

Qt For OpenHarmony 应用管理

符合OpenHarmony标准的应用管理:

启动流程:(1)Qt框架按照Stage模型开发符合Stage-Ability,应用程序通过EntryAbility调用启动;(2)在QtAbilityStage的onCreate中,使用NAPI机制初始化Qt的Native模块,并调用App自己的main入口函数,拉起应用逻辑。

退出流程:在EntryAbility的onDestory中,使用NAPI机制通知Qt的QPA模块,退出Qt Framework的主循环及业务逻辑。

b5c3c2ec-4d17-11ee-bb52-92fbcf53809c.png

与传统的C++应用程序不同,遵循Openharmony的北向开发应用管理,需要通过eTS框架完成应用程序C/C++应用程序main函数入口调用启动。

由于XComponent的动态创建问题,目前QPA的NAPI函数调用放在index.ets中进行调用,该问题还需要与OpenHarmony团队进行沟通,讨论基于OpenHarmony的最优解:(1)基于ETS框架自定义ETS脚本,实现XComponent的动态创建,在ETS框架下实现应用程序窗口管理;(2)基于NDK开发的XComponent的新增接口,在Qt App侧实现应用程序的窗口管理。

b5df10d8-4d17-11ee-bb52-92fbcf53809c.png

04

总结与展望

基于Qt跨平台特性及Qt For OpenHarmony的适配,能够促进OpenHarmony跨平台应用迁移及应用开发,对OpenHarmony技术生态有一定的积极作用,期待大家一块参与到Qt适配OpenHarmony的相关工作中来。

E N D

审核编辑 黄宇

声明:本文内容及配图由入驻作者撰写或者入驻合作网站授权转载。文章观点仅代表作者本人,不代表电子发烧友网立场。文章及其配图仅供工程师学习之用,如有内容侵权或者其他违规问题,请联系本站处理。 举报投诉
  • OpenHarmony
    +关注

    关注

    23

    文章

    3301

    浏览量

    15159
收藏 人收藏

    评论

    相关推荐

    Qt For OpenHarmony图形化的进展突破

    Qt 适配 OpenHarmony 意义 Qt 是一个 C++ 跨平台开发框架,主要用于开发图形用户界面(Graphical User Interface,GUI)程序,具有跨平台类库(支持目前
    的头像 发表于 02-02 14:29 562次阅读
    <b class='flag-5'>Qt</b> For <b class='flag-5'>OpenHarmony</b>图形化的进展突破

    高能回顾 | 首届OpenHarmony竞赛训练营精彩瞬间

    点击视频回顾竞赛精彩瞬间! ↓↓↓ 根深叶茂,众行者远,期待下一次相聚! 原文标题:高能回顾 | 首届OpenHarmony竞赛
    的头像 发表于 11-11 21:10 296次阅读

    限量门票!第二届开放原子开源基金会OpenHarmony技术峰会报名开启~

    报名通道:>>立即报名 峰会时间:11月4日 峰会地址:北京市 朝阳区 国家会议中心 第二届开放原子开源基金会OpenHarmony技术峰会将于2023年11月4日在
    发表于 10-20 14:18

    报名开启!第二届开放原子开源基金会OpenHarmony技术峰会来啦~

    第二届开放原子开源基金会OpenHarmony技术峰会将于2023年11月4日在北京举办。峰会以“技术筑生态,智联赢未来”为主题,特邀全球开源操作系统技术领袖、前沿实践专家及高校技术导师,面向全球
    发表于 10-20 12:06

    Qt For OpenHarmony

    本文转载自 OpenHarmony TSC 官方​《峰会回顾29 |
    发表于 09-15 15:39

    峰会回顾第31期 | OpenHarmony生态共建:多种指令集架构芯片适配

    演讲嘉宾 | 连志安 回顾整理 | 廖   涛 排版校对 | 李萍萍 嘉宾简介 连志安,江苏润开鸿数字科技有限公司生态技术总监、OpenHarmony龙芯架构SIG组长、《物联网——嵌入式开发实战
    的头像 发表于 09-15 08:41 765次阅读
    <b class='flag-5'>峰会</b><b class='flag-5'>回顾</b>第31期 | <b class='flag-5'>OpenHarmony</b>生态共建:多种指令集架构芯片适配

    开源图形驱动在OpenHarmony上的使用和落地

    本文转载自 OpenHarmony TSC 官方《峰会回顾10 | 开源图形驱动在OpenHarmo
    发表于 08-31 18:07

    峰会回顾7 | 视窗绘制技术演进和新趋势

    本帖最后由 OpenHarmony开发者 于 2023-8-22 16:56 编辑 本文转载自 OpenHarmony TSC 官方《峰会回顾
    发表于 08-22 16:33

    根深叶茂,聚力前行 | 2023开放原子全球开源峰会OpenHarmony感谢信

    与展览等方式,在2023开放原子全球开源峰会精彩亮相,展示生态进展与最新行业落地成果,让广大企业、开发者了解OpenHarmony最新动态,展现OpenHarmony生态新路径。 让我们一起
    的头像 发表于 07-06 21:10 1422次阅读

    嘉宾金句|2023开放原子全球开源峰会OpenAtom OpenHarmony分论坛

    高质量、深层次的思想碰撞 今天,让我们来回顾这些精彩的发言 一起感受开源的魅力吧 原文标题:嘉宾金句|2023开放原子全球开源峰会OpenAtom OpenHarmony分论坛 文章出处:【微信公众号:OpenAtom
    的头像 发表于 06-21 21:25 208次阅读

    峰会回顾第13期 | 开源机密计算平台:蓬莱-OpenHarmony

    开源基金会OpenHarmony技术峰会——安全及机密计算分论坛   正 文 内 容   OpenHarmony赋能万物互联,存在覆盖从端到云
    的头像 发表于 06-09 08:38 342次阅读
    <b class='flag-5'>峰会</b><b class='flag-5'>回顾</b>第13期 | 开源机密计算平台:蓬莱-<b class='flag-5'>OpenHarmony</b>

    峰会回顾第11期 | OpenHarmony兼容性设计与实践

    演讲嘉宾 | 纪   永 回顾整理 | 廖   涛 排版校对 | 李萍萍       嘉宾简介 纪永,华为终端测试技术专家、高级工程师,XTS仓Committer。技术领域:OpenHarmony
    的头像 发表于 06-02 08:41 532次阅读
    <b class='flag-5'>峰会</b><b class='flag-5'>回顾</b>第11期 | <b class='flag-5'>OpenHarmony</b>兼容性设计与实践

    峰会回顾第10期 | 开源图形驱动在OpenHarmony上的使用和落地

    黑科技核心成员,在OpenHarmony社区上担任开源图形驱动SIG、游戏SIG、兼容性工作组组长等职务。   内容来源 第一届开放原子开源基金会OpenHarmony技术峰会——OS内核及视窗分论坛   正 文 内 容   图
    的头像 发表于 05-15 09:30 858次阅读
    <b class='flag-5'>峰会</b><b class='flag-5'>回顾</b>第10期 | 开源图形驱动在<b class='flag-5'>OpenHarmony</b>上的使用和落地

    峰会回顾第6期 | 毕昇编译器与OpenHarmony RISC-V生态的进展

    设计经验,负责探索先进软硬件协同设计技术、工具以及方法。   文章内 容来 源 第一届开放原子开源基金会OpenHarmony技术峰会——开发者工具分论坛   视频回顾   正 文 内 容   由C、C++、Java等高级语言编
    的头像 发表于 05-05 15:46 1131次阅读
    <b class='flag-5'>峰会</b><b class='flag-5'>回顾</b>第6期 | 毕昇编译器与<b class='flag-5'>OpenHarmony</b> RISC-V生态的进展

    峰会回顾第8期 | OpenHarmony 分布式硬件关键技术

    演讲嘉宾 | 李   刚 回顾整理 | 廖   涛 排版校对 | 李萍萍       嘉宾简介 李刚,华为OpenHarmony技术专家,OpenHarmony分布式硬件技术负责人。主要负责
    的头像 发表于 05-05 15:46 738次阅读
    <b class='flag-5'>峰会</b><b class='flag-5'>回顾</b>第8期 | <b class='flag-5'>OpenHarmony</b> 分布式硬件关键技术