马上注册,结交更多好友,享用更多功能,让你轻松玩转社区。
您需要 登录 才可以下载或查看,没有账号?站点注册
×
项目介绍OpenHarmony是开放原子开源基金会(OpenAtom Foundation)旗下开源项目,定位是一款面向全场景的开源分布式操作系统。
OpenHarmony在传统的单设备系统能力的基础上,创造性地提出了基于同一套系统能力、适配多种终端形态的理念,支持多种终端设备上运行,第一个版本支持128K-128M设备上运行,欢迎参加开源社区一起持续演进。
针对设备开发者,OpenHarmony采用了组件化的设计方案,可以根据设备的资源能力和业务特征进行灵活裁剪,满足不同形态的终端设备对于操作系统的要求。可运行在百K级别的资源受限设备和穿戴类设备,也可运行在百M级别的智能家用摄像头/行车记录仪等相对资源丰富的设备。 详细特征[td]系 统 | 简 介 | 链 接 | JS应用开发框架 | 作为JS应用开发框架的轻量实现,提供一套跨平台的类web应用开发框架,通过Toolkit将开发者编写的HTML、CSS和JS 文件编译打包成JS Bundle,然后再将JS Bundle解析运行成C++ UIKit的View 组件进行渲染。通过支持三方开发者使用声明式的API进行应用开发,以数据驱动视图变化,避免了大量的视图操作,大大降低了应用开发难度,提升开发者开发体验。 | README | DFX | 针对不同硬件架构和资源提供组件化且可定制的DFX框架。根据RISC-V、Cortex-M、Cortex-A不同硬件平台,提供两种不同的轻量级DFX框架。 | README | XTS认证 | XTS是OpenHarmony生态认证测试套件的**,当前包括acts(application compatibility test suite)应用兼容性测试套,后续会拓展dcts(device compatibility test suite)设备兼容性测试套等。 | README | 全球化 | 全球化资源管理子系统主要提供语言资源回溯和多偏好语言支持的能力,包括多语言资源回溯和多偏好语言支持。 | README | 公共基础 | 公共基础库存放OpenHarmony通用的基础组件。这些基础组件可被OpenHarmony各业务子系统及上层应用所使用。 | README | 内核 | OpenHarmony内核是面向IoT领域的实时操作系统内核,它具备类似RTOS般轻快和Linux般易用的特点。包括功能组件部分:进程和线程调度、内存管理、IPC机制、timer管理等操作系统基础组件。 | README | 分布式任务调度 | 分布式任务调度模块负责跨设备组件管理,提供访问和控制远程组件的能力,支持分布式场景下的应用协同。 | README | 分布式通信 | 实现近场设备间统一的分布式通信能力管理,提供不区分链路的设备发现和传输接口。包含服务发布、数据传输、安全等功能 | README | 启动恢复 | 启动恢复负责在内核启动之后,应用启动之前的操作系统中间层的启动。支持使用LiteOS-A内核的平台,当前包括:Hi3516DV300平台和Hi3518EV300平台。 | README | 图形 | 主要包括UI组件、布局、动画、字体、输入事件、窗口管理、渲染绘制等模块,构建基于轻量OS的应用框架,满足硬件资源较小的物联网设备的OpenHarmony系统应用开发。 | README | 媒体 | 为多媒体应用开发者开发者提供统一的开发接口,使得开发者可以专注于应用业务的开发,轻松使用多媒体的资源。 | README | 安全 | 主要提供样例给开发者展示如何去使用已有的安全机制来提升系统的安全能力,包括安全启动、应用权限管理、IPC通信鉴权、HUKS、HiChain、应用签名验签。 | README | 测试 | 开发过程采用测试驱动开发模式,开发者基于系统新增特性可以通过开发者自己开发用例保证,对于系统已有特性的修改,也可通过修改项目中原有自测试用例保证,旨在帮助开发者在开发阶段就能开发出高质量代码。 | README | 用户程序框架 | 包含两个模块:Ability子系统和包管理子系统。Ability子系统,是OpenHarmony为开发者提供的一套开发OpenHarmony应用的开发框架。包管理子系统,是OpenHarmony为开发者提供的安装包管理框架。 | README | 系统服务框架 | 由于平台资源有限,且硬件平台多样,因此需要屏蔽不同硬件架构和资源的不同、以及运行形态的不同,提供统一化的系统服务开发框架。根据RISC-V、Cortex-M、Cortex-A不同硬件平台,分为两种平硬件平台,简称M核、A核。 | README | 编译构建 | 编译构建提供了一个在GN与ninja基础上的编译构建框架。支持以下功能:1.构建不同芯片平台的产品。如:Hi3518EV300平台的ipcamera产品,Hi3516DV300平台的ipcamera产品,Hi3861平台的wifi模组产品。2.构建HPM包管理配置生成的自定义产品。 | README | 驱动 | OpenHarmony驱动子系统采用C面向对象编程模型构建,通过平台解耦、内核解耦,兼容不同内核,提供了归一化的驱动平台底座,旨在为开发者提供更精准、更高效的开发环境,力求做到一次开发,多系统部署。 | README | 快速入门[td]开发板类型 | 简述 | 链 接 | Hi3861开发板 | Hi3861 WLAN模组是一片大约2cm*5cm大小的开发板,是一款高度集成的2.4GHz WLAN SoC芯片,集成IEEE 802.11b/g/n基带和RF(Radio Frequency)电路。支持OpenHarmony/Huawei LiteOS和第三方组件。 | 快速入门 | Hi3516开发板 | Hi3516DV300作为新一代行业专用Smart HD IP摄像机SOC,集成新一代ISP、业界最新的H.265视频压缩编码器,同时集成高性能NNIE引擎。 | 快速入门 | Hi3518开发板 | Hi3518EV300作为新一代智慧视觉处理SOC,集成新一代ISP(Image Signal Processor)以及业界最新的H.265视频压缩编码器。 | 快速入门 | 源码下载如何参与联系方式
------------------------ 源码获取OpenHarmony介绍OpenHarmony是HarmonyOS的开源版,由华为捐赠给开放原子开源基金会(OpenAtom Foundation)开源。第一个开源版本支持在128KB~128MB设备上运行,欢迎参加开源社区一起持续演进。 源码获取概述本文档将介绍如何获取OpenHarmony源码并说明OpenHarmony的源码目录结构。OpenHarmony的代码以组件的形式开放,开发者可以通过如下其中一种方式获取: - 获取方式1:从镜像站点下载压缩文件(推荐)
- 获取方式2:从hpm网站组件式获取。通过HPM,查找满足需求的解决方案,挑选/裁剪组件后下载。
- 获取方式3:用包管理器命令行工具获取。通过HPM的hpm-cli命令行工具,执行命令下载。
- 获取方式4:从代码仓库获取。通过repo或git工具从代码仓库中下载。
获取方式1:从镜像站点获取为了获得更好的下载性能,您可以选择从以下站点的镜像库获取源码或者对应的解决方案。 表 1 源码获取路径
[td]
下载内容 | 版本信息 | 下载站点 | SHA256校验码 | OpenHarmony全量代码 | 1.0 | | | Hi3861解决方案(二进制) | 1.0 | | | Hi3518解决方案(二进制) | 1.0 | | | Hi3516解决方案(二进制) | 1.0 | | | RELEASE-NOTES | 1.0 | | - | 获取方式2:从hpm网站组件式获取适用场景对于刚接触OpenHarmony的新用户,希望能够参考一些示例解决方案从而进行快速开发。可以在HPM获取推荐的解决方案,以此为基础,增加或裁剪部分组件,快速定制系统。 操作步骤查找合适的解决方案组件包。
定制解决方案组件包。
- 仔细阅读解决方案的说明,以了解该解决方案的使用场景、特性、使用方法以及如何进行定制化,如下图所示。
- 点击「直接下载」,将解决方案下载到本地。
- 点击「定制组件」,将对解决方案包含的组件进行定制。
图 2 解决方案示例 定制组件。
- 进入解决方案定制页面,如下图所示。
- 通过关闭开关移除可选组件,或者通过“添加组件”增加新的组件。
- 在右边填写您的项目基本信息,包括名称、版本、描述等信息。
- 点击“下载“,系统会根据您的选择,生成相应的OpenHarmony代码结构文件(如name.zip),保存至本地文件。
获取方式3:用包管理器命令行获取适用场景- 用户已通过组件式获取的方式获取源码,需要对源码中的某个或某几个组件进行独立升级。
- 用户已经比较熟悉OpenHarmony系统的开发并且熟练掌握命令行工具的使用。
准备通过命令行获取,需要先安装Node.js和hpm命令行工具,安装步骤如下: 操作接下来将组件添加到开发项目中,假定要获取的组件名为@ohos/demo,具体操作如下: 获取方式4:从代码仓库获取适用场景基于OpenHarmony的稳定分支建立自己的基线,分发下游客户。 已经完成自身软件与OpenHarmony的对接,需要进行OpenHarmony官方认证。 芯片/模组/app通过OpenHarmony官方认证后,贡献代码到OpenHarmony生态。 修复OpenHarmony的问题。 学习OpenHarmony的源码。
准备操作方式一(推荐):通过repo下载 repo init -u https://gitee.com/openharmony/manifest.git -b masterrepo sync -c
方式二:通过git clone单个代码仓库 git clone https://gitee.com/openharmony/manifest.git -b master
源码目录简介下表是OpenHarmony源码的目录及简单说明: 表 2 源码目录的说明
[td]
目录名 | 描述 | applications | 应用程序样例,包括wifi-iot,camera等 | base | 基础软件服务子系统集&硬件服务子系统集 | build | 组件化编译、构建和配置脚本 | domains | 增强软件服务子系统集 | drivers | 驱动子系统 | foundation | 系统基础能力子系统集 | kernel | 内核子系统 | prebuilts | 编译器及工具链子系统 | test | 测试子系统 | third_party | 开源第三方组件 | utils | 常用的工具集 | vendor | 厂商提供的软件 | build.py | 编译脚本文件 |
|