优秀的编程知识分享平台

网站首页 > 技术文章 正文

从零打造自己的 国产鸿蒙(OpenHarmony)定制系统-完整可落地流程

nanyue 2025-07-07 21:58:49 技术文章 5 ℃

适用版本:OpenHarmony 4.0 / 5.0 Standard

目标人群:想在 x86 PC、RK3568 开发板或自有硬件 上裁剪、加品牌、预装应用并生成可刷机镜像的开发者 / 团队





目录

  1. 环境准备
  2. 获取 & 管理源码
  3. 创建专属 Product(产品)配置
  4. “十大自定义”示例
  5. 设备移植要点(以 RK3568 为例)
  6. 构建、打包与刷机
  7. OTA 升级包生成
  8. 发行版签名与合规
  9. 持续维护与更新



1 | 环境准备


主机系统

推荐

说明

Ubuntu 22.04 LTS

官方 CI 同款

内存 / 磁盘

≥ 16 GB / 100 GB

repo sync 镜像 ~ 40 GB

依赖

git curl python3 ninja-build gcc g++ openjdk-17-jdk ccache

4.x 起默认 JDK 17

sudo apt update && sudo apt install \

git repo curl python3 ninja-build gcc g++ make \

openjdk-17-jdk ccache -y




2 | 克隆源码并锁定版本


mkdir ~/ohm && cd ~/ohm


# ① 初始化指定分支 / 标签

repo init -u https://gitee.com/openharmony/manifest.git \

-b refs/tags/OpenHarmony-4.0-Release


# ② 下载所有子仓

repo sync -c -j$(nproc)


# ③ 可选:设置本地镜像加速

git config --global http.sslVerify false

若需长期维护,可 Fork manifest 并在其中锁定子仓 commit。





3 | 创建你的

Product

(核心定制入口)



  1. 复制一个基线产品


cp -r vendor/hihope/rk3568 vendor/mycorp/myboard


  1. 重命名与修改 config.json

"name": "myboard"

"device_company": "mycorp"

"subsystems": 增删自己需要的子系统组件

  1. 声明分区 & 镜像格式(如启用 A/B、ext4/erofs)
  2. 注册到编译系统

./build.sh --product-name myboard -p


编译系统即能解析出新的 product_path






4 | “十大自定义”实操示例


#

自定义项

方法

① 品牌 Logo / 启动动画

替换 device/board/<vendor>/<board>/kernel/logo*.bmp、bootvideo.mp4,清空 out/ 后全量编译


② 默认壁纸 & 主题

applications/standard-systemui/resources/


③ 预装自研 App

在 vendor/mycorp/apps 里放 .hap,并在 config.json -> prebuilt_haps 列出


④ 自定义系统属性

编辑
base/startup/init/services/etc/param/mycorp_param.cfg


⑤ 调整分区大小

config.json -> partitions 设置 system/vendor/userdata 大小


⑥ 关闭/裁剪子系统

去掉 subsystems 中如 telephony, bt 等条目


⑦ 添加内核模块


device/board/.../kernel/linux-5.10/defconfig 打开所需 CONFIG_...


⑧ 专属系统服务


foundation/mycorp_service/ 写 ArkTS/CPP 服务,并加入 subsystems


⑨ UI 业务事件埋点

引入 common_event_service 并在 hisysevent JSON 定义事件


⑩ 系统默认语言/时区

init_rc/ohos.para 配置 persist.sys.locale 等键






5 | 设备移植要点(RK3568 示例)



  1. Board 目录


  1. device/board/rockchip/rk3568:设备树 .dts、uboot、fastboot.cfg
  2. Kernel


  1. 同步 Rockchip 分支或 mainline,保持与 BSP 补丁一致
  2. 驱动适配清单


  1. LCD/TP:drivers/gpu/drm + drivers/input
  2. Wi-Fi/BT:替换固件 + vendor/.../wifi.cfg
  3. Camera:media 子系统 HAL + sensor_list.h


开源官方已提供 DAYU200 (RK3568) 全链路适配示例,可参考步骤迅速复刻并裁剪。





6 | 编译、生成镜像并刷机


# 建议开启 ccache,加快二次编译

export USE_CCACHE=1 && ccache -M 20G


./build.sh --product-name myboard \

--target-cpu arm64 \

-j$(nproc)


  • 成功后镜像位于 out/myboard/images/
  • 常见产物


文件

用途

boot.img

Kernel & ramdisk

system.img

/system 分区

vendor.img

/vendor 分区

update.img

一键刷机包(部分板卡)



刷机

# U 盘镜像

sudo dd if=update.img of=/dev/sdX bs=4M status=progress


# Android-fastboot 设备

fastboot flash boot boot.img

fastboot flash system system.img

...

fastboot reboot





7 | OTA 升级包制作


cd build/ohos

./ota_packaging.sh \

--product-name myboard \

--target-dir out/myboard \

--version v1.0.0 \

--output ../ota/myboard_v1.0.0.zip

脚本会比较 old/new 镜像生成增量包;客户端可使用 update_tool 下发升级指令。





8 | 签名、隐私合规与发布



  1. 生成 Vendor 密钥


openssl genrsa -out mycorp_private.pem 2048

openssl rsa -in mycorp_private.pem -pubout -out mycorp_public.pem


  1. 配置签名链 build/security/signing_profile.json
  2. 隐私合规
  3. 明示收集项 → ohos.permission.* 权限对齐
  4. 敏感日志屏蔽 → hisysevent 白名单
  5. 开源许可证:保留 Apache-2.0 / BSD / LGPL 文件头、NOTICE






9 | 持续集成与版本升级


内容

建议

CI

GitLab Runner + build.sh + 缓存 ccache

上游合并

每月 repo sync + git rebase;冲突集中在 device/ & vendor/

回归测试

核心能力:启动、音视频、网络、分布式 FA/PA、OTA





结语

通过 Product 配置 + 设备板级目录 + 资源替换 + 签名打包,你就能在 30 分钟跑通编译,1 ~ 2 天完成品牌化定制,1 周交付可刷机镜像。

无论是PC、开发板还是独立硬件,OpenHarmony 都提供了足够开放的接口与文档支持。赶紧动手,打造属于你的国产鸿蒙发行版吧!

最近发表
标签列表