当前位置:网站首页>Analysis of the source code of the JS UI framework of Hongmeng system
Analysis of the source code of the JS UI framework of Hongmeng system
2022-08-02 06:43:00 【Big Taobao Technology】
▐ 系统架构分层
data:image/s3,"s3://crabby-images/9470c/9470cfc399eab2c271700514d6403ea933dd3124" alt=""
▐ HarmonyOS 和 OpenHarmony 的区别
data:image/s3,"s3://crabby-images/2bcc1/2bcc1ef55d556167ea2e762c253dd7ec7ea01442" alt=""
▐ source code directory构
repo init -u https://gitee.com/openharmony/manifest.git -b master --no-repo-verify
repo sync -c
OpenHarmony/
├── applications # 应用程序样例
├── base # 基础软件服务子系统集
├── docs
├── domains # 增强软件服务子系统集
├── drivers # 驱动子系统
├── foundation # 系统基础能力子系统集
│ ├── aafwk # Ability 框架
│ ├── ace # JS UI 框架
│ │ ├── ace_engine # ACE 1.0, 仓库名: ace_ace_engine
│ │ └── ace_engine_lite # ACE 2.0, 仓库名: ace_engine_lite
│ ├── appexecfwk # 用户程序框架和包管理模块
│ └── graphic # 图形库相关的子系统
├── interface
│ └── sdk-js # JS API 的 TS 类型文件
├── kernel # LiteOS 内核
│ ├── liteos_a
│ └── liteos_m
├── test
└── third_party
▐ 新旧 ACE 框架
data:image/s3,"s3://crabby-images/904c4/904c4b203a3a834206e3e21e929f6210719d3e73" alt=""
data:image/s3,"s3://crabby-images/9f84b/9f84bcaa23121090505465adc951cf2f36f7788f" alt=""
▐ 容器创建和管理
data:image/s3,"s3://crabby-images/78f17/78f17c2cae69090ba4350229fbf83eb3fdb30e90" alt=""
Frontend: 前端代码的执行环境,JS 或者 JSON,有这层抽象或许还可以支持其他脚本引擎. TaskExecutor: 单一线程内的任务管理器,类似其他渲染引擎中的 TaskRunner. AssetManager: 资源管理器,可用于加载 JS 代码、图片、字体等资源.应该也具备缓存能力. PipelineContext: 渲染管线的管理类,监听 vsync 回调刷新内部脏节点的布局、绘制、渲染. AceView: 渲染生成的 UI 根节点,可以贴到外层容器中. PlatformResRegister: 平台资源的注册和管理,以及部分通信接口,可在这里实现同层渲染功能.
▐ JS UI 开发框架
data:image/s3,"s3://crabby-images/5f11a/5f11a82db869d29108c85603ae7e6525dc39795f" alt=""
Frontend
部分,有三种不同类型的实现,分别是基于渲染指令的命令式 UI、声明式 UI、以及无需脚本引擎,用 JSON 文件渲染的 UI.命令式 UI 和 声明式 UI 都是用 QuickJS 作为脚本引擎,声明式 UI 里包含了 V8 的抽象,但是这部分好像没有开源出来.JS Frontend (命令式 UI)
xx.hml
的模板文件、xx.css
的样式文件、xx.js
的脚本文件以及 xx.json
配置文件.<div class="container">
<text class="title-text">{{headTitle}}</text>
</div>
/* xxx.css */
.container {
flex-direction: column;
margin-top: 20px;
margin-left: 30px;
}
.title-text {
color: #1a1a1a;
font-size: 50px;
}
// xxx.js
export default {
data: {
headTitle: 'Capture the Beauty in This Moment'
}
}
data:image/s3,"s3://crabby-images/0f9b2/0f9b289c345d0fef48a075ceade4870cdf8acf20" alt=""
ace
的模块中,可以用 import 导入,环境中也有 ace
这个全局环境:import * as ace from 'ace'
// 创建 body 节点
ace.domCreateBody(0, 'div', {/* attrs */}, {/* styles */}, {/* events */})
Declarative Frontend (声明式 UI)
@Component
class MyDemo {
Column(
Text('Hello World!'),
Text('Some text here')
.fontsize(36)
.color(Color.Red)
).center()
}
data:image/s3,"s3://crabby-images/a2007/a2007cdb15ac944f69af1be33747aa5141f30ec7" alt=""
Card Frontend (无脚本 UI)
template
、styles
、actions
、data
这几部分,模板里可以写花括号的数据绑定 {{some.data}}
,里边可以写简单的 JS 表达式,也不是完全静态的.而且 CardFrontend 类上有 UpdateData()
接口,可以更新模板的数据,具备一定的动态化能力.▐ 节点构建流程
data:image/s3,"s3://crabby-images/46e96/46e96753a51fab5cdb1239c6f100934ee3c875d0" alt=""
▐ 布局绘制渲染
data:image/s3,"s3://crabby-images/c818e/c818ec526fb91a66908f4e4ee0b2da2543422cd0" alt=""
OnVsyncEvent()
回调,如果 surface 已经初始化好,则依次刷新内部的脏节点,如果包含动画,则调用 RequestFrame()
请求触发下一帧 vsync.首先 dirty Elements 会触发 Rebuild()
重新构建 RenderNode,并且调用 MarkNeedLayout()
把它加到待布局的队列里,然后 FlushLayout
会刷新这个队列,调用节点的 OnLayout()
方法计算布局,然后把自身再加入到待绘制的队列里,然后 FlushRender()
依次调用节点的 Repaint()
方法重新绘制,生成 layer tree.data:image/s3,"s3://crabby-images/14dd9/14dd9627a48174846e10405d51d9ad5686f98f30" alt=""
OpenHarmony 官网:https://www.openharmony.cn/ ACE Lite: https://gitee.com/openharmony/ace_engine_lite ACE Engine: https://gitee.com/openharmony/ace_ace_engine 配置文件:https://gitee.com/openharmony/manifest/blob/master/default.xml ACE 架构图:https://gitee.com/openharmony/ace_engine_lite/blob/OpenHarmony-2.0-Canary/figures/JS%E5%BA%94%E7%94%A8%E5%BC%80%E5%8F%91%E6%A1%86%E6%9E%B6.png 类小程序 DSL:https://device.harmonyos.com/en/docs/apiref/js-framework-file-0000000000616658 新 ACE 架构图:https://gitee.com/openharmony/ace_ace_engine/blob/OpenHarmony-2.0-Canary/figures/JS-UI%E6%A1%86%E6%9E%B6%E6%9E%B6%E6%9E%84.png qjs_engine.cpp: https://gitee.com/openharmony/ace_ace_engine/blob/OpenHarmony-2.0-Canary/frameworks/bridge/js_frontend/engine/quickjs/qjs_engine.cpp#L1925-1940 TaskCenter.ts: https://gitee.com/openharmony/third_party_jsframework/blob/OpenHarmony-2.0-Canary/runtime/main/manage/event/TaskCenter.ts#L127-133 FlutterSceneBuilder: https://gitee.com/openharmony/ace_ace_engine/blob/OpenHarmony-2.0-Canary/frameworks/core/pipeline/layers/flutter_scene_builder.
data:image/s3,"s3://crabby-images/d544f/d544ff5ae4353807b418abf4409588a84001066b" alt=""
data:image/s3,"s3://crabby-images/c6e8d/c6e8d7dab1225e0d203bbfb4a5bd4f0e8d68ad34" alt=""
data:image/s3,"s3://crabby-images/02e22/02e22fcad4c0eebc81a42e8ca00d0a2f579d6622" alt=""
data:image/s3,"s3://crabby-images/36a55/36a553da5207e638634398ea8a81e74d352a148f" alt=""
本文分享自微信公众号 - 淘系技术(AlibabaMTT).
如有侵权,请联系 [email protected] 删除.
本文参与“OSC源创计划”,欢迎正在阅读的你也加入,一起分享.
边栏推荐
- C语言入门实战(13):十进制数转二进制
- pytorch常用函数
- 国际顶会OSDI首度收录淘宝系统论文,端云协同智能获大会主旨演讲推荐
- Node的安装与环境变量的配置
- H5 access payment process - WeChat payment & Alipay payment
- 卸载redis
- Point Density-Aware Voxels for LiDAR 3D Object Detection Paper Notes
- 在腾讯做外包测试的那些日子.....
- Redis-----非关系数据库
- Stress testing and performance analysis of node projects
猜你喜欢
随机推荐
Deep learning - CNN realizes the recognition of MNIST handwritten digits
Shell 脚本不同玩法
Node的安装与环境变量的配置
关于web应用的目录结构
科技赋能拉萨之“肺”,华为助力拉鲁湿地智慧管理守护绿水青山
nacos registry
C语言小游戏——扫雷小游戏
npm、nrm两种方式查看源和切换镜像
Nacos注册中心的部署与用法详细介绍
C# 编码规范手册
leetcode solves the linked list merge problem in one step
C语言操作符详解(2)
触发器简单解释
家用 NAS 服务器(4)| MergerFS和SnapRaid数据定时备份
C竞赛训练
Detailed installation and configuration of golang environment
虚拟现实房产展示系统提前预见未来装修效果
腾讯大咖分享 | 腾讯Alluxio(DOP)在金融场景的落地与优化实践
flex布局(弹性布局)
如何优化OpenSumi终端性能?