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

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

3天内不再提示

OpenHarmony鸿蒙编译环境搭建 (兼容至4.0-Master和主干分支)

王程 来源:jf_75796907 作者:jf_75796907 2024-02-23 15:22 次阅读

预备工作

安装虚拟机工具VMware或者VirtualBox。

新建虚拟机,内存16GB及以上,硬盘100GB及以上。

安装Ubuntu,推荐使用20.04版本。用户名不能包含中文。

启动并进入Ubuntu虚拟机,以下步骤将在Ubuntu虚拟机中进行操作。

一、将Shell环境修改为bash

sudo dpkg-reconfigure dash

选择“No”。

wKgZomXYRyiAD7nzAABJaF1wMIA816.png

二、替换Ubuntu软件源

在“https://mirrors.ustc.edu.cn/repogen/”下载对应版本最新的源。

wKgaomXYRy6AB0n3AABpxvDWlNY935.png

在下载好的文件(sources.list)所在的位置开启一个终端窗口,执行下列命令。

备份原始文件:

sudo cp /etc/apt/sources.list /etc/apt/source.list.bak

替换源:

sudo mv -f sources.list /etc/apt/

更新软件包索引

sudo apt update

三、安装必要的库和工具

需要分两步进行安装。注意,这里比较重要,官网文档用一步进行安装,会出现问题,导致安装不完整,从而导致后期编译出现“3000”错误。

sudo apt-get install binutils binutils-dev git git-lfs gnupg flex bison gperf build-essential zip curl zlib1g-dev   libc6-dev-i386 lib32ncurses5-dev x11proto-core-dev libx11-dev lib32z1-dev ccache libgl1-mesa-dev libxml2-utils xsltproc unzip m4 bc gnutls-bin python3.8 python3-pip ruby genext2fs device-tree-compiler make libffi-dev e2fsprogs pkg-config perl openssl libssl-dev libelf-dev libdwarf-dev u-boot-tools mtd-utils cpio doxygen liblz4-tool openjdk-8-jre gcc g++ texinfo dosfstools mtools default-jre default-jdk libncurses5 apt-utils wget scons python3.8-distutils tar rsync git-core libxml2-dev lib32z-dev grsync xxd libglib2.0-dev libpixman-1-dev kmod jfsutils reiserfsprogs xfsprogs squashfs-tools pcmciautils quota ppp libtinfo-dev libtinfo5 libncurses5-dev libncursesw5 libstdc++6 gcc-arm-none-eabi vim ssh locales libxinerama-dev libxcursor-dev libxrandr-dev libxi-dev
sudo apt-get install gcc-arm-linux-gnueabi gcc-9-arm-linux-gnueabi

四、配置Python

设置默认Python解释器,python和python3软链接为python3.8:

sudo update-alternatives --install /usr/bin/python python /usr/bin/python3.8 1
sudo update-alternatives --install /usr/bin/python3 python3 /usr/bin/python3.8 1
python --version

安装python包管理工具(pip3):

sudo apt install python3-pip

配置pip软件包更新源:

mkdir ~/.pip
pip3 config set global.index-url https://mirrors.huaweicloud.com/repository/pypi/simple
pip3 config set global.trusted-host mirrors.huaweicloud.com
pip3 config set global.timeout 120

五、安装Samba服务

用于在开发环境中使用VS Code编写代码。执行下列命令安装samba并打开配置文件:

sudo apt install samba
sudo gedit /etc/samba/smb.conf

在配置文件末尾添加以下内容:

[home]
comment = User Homes
path = /home
guest ok = no
writable = yes
browsable = yes
create mask = 0755
directory mask = 0755

建立用户并设置密码(请将下面的用户名换成您自己的):

sudo smbpasswd -a dragon

重启samba:

sudo service smbd restart

六、获取源代码的必要工具和配置

安装git-lfs,会自动安装git:

sudo apt install git-lfs

安装repo和requests:

wget https://gitee.com/oschina/repo/raw/fork_flow/repo-py3
sudo mv repo-py3 /usr/local/bin/repo
sudo chmod a+x /usr/local/bin/repo
pip3 install -i https://repo.huaweicloud.com/repository/pypi/simple requests

配置git(请将下面的邮箱和用户名换成您自己的):

git config --global user.email "dragon@hbu.cn"
git config --global user.name "dragon"
git config --global credential.helper store
git config --global --add safe.directory "*"

七、拉取源码

以4.0为例(可以拉取branch或tag,这里使用branch):

mkdir -p ~/openharmony/4.0
cd ~/openharmony/4.0
repo init -u https://gitee.com/openharmony/manifest -b OpenHarmony-4.0-Release --no-repo-verify
repo sync -c
repo forall -c 'git lfs pull'

在源码根目录下执行prebuilts脚本,安装编译器及二进制工具:

bash build/prebuilts_download.sh

八、安装编译工具

在源码根目录运行如下命令安装hb并更新至最新版本:

python3 -m pip install --user build/hb

设置环境变量:

echo 'export PATH=~/.local/bin:$PATH' >> ~/.bashrc
source ~/.bashrc

九、编译

两种方式,使用hb或者build.sh。

使用hb。在源码根目录运行如下命令(选择要编译的产品并进行编译):

hb set
hb build

使用build.sh。命令格式为:

./build.sh --product-name {product_name} --ccache

例如,在源码根目录运行如下命令:

./build.sh --product-name rk3568 --ccache

耐心等待,对于标准系统来说,完整编译过程会持续2-3小时。

wKgaomXYR0GAAimPAADQ-7oaLKc160.png


为了能让大家更好的学习鸿蒙 (OpenHarmony) 开发威廉希尔官方网站 ,这边特意整理了《鸿蒙 (OpenHarmony)开发学习手册》,希望对大家有所帮助:

《鸿蒙(Harmony OS)开发学习手册》

入门必看:https://docs.qq.com/doc/DUk51cHZJaUpmSlhH
1.应用开发导读(ArKTS)
2.应用开发导读(Java

wKgaomXW6N2AJp9uAAQXRxEAprs547.png

HarmonyOS概念:https://docs.qq.com/doc/DUk51cHZJaUpmSlhH
1.系统定义
2.威廉希尔官方网站 框架
3.威廉希尔官方网站 特性
4.系统安全

wKgaomXW6OSAFcCRAAV2zd2X_1s891.png

快速入门:https://docs.qq.com/doc/DUk51cHZJaUpmSlhH
1.基本概念
2.构建第一个ArkTS应用
3.构建第一个JS应用
4…

wKgZomXW6PuAA7wEAAKx6By_2Z8377.png

开发基础知识:https://docs.qq.com/doc/DUk51cHZJaUpmSlhH
1.应用基础知识
2.配置文件
3.应用数据管理
4.应用安全管理
5.应用隐私保护
6.三方应用调用管控机制
7.资源分类与访问
8.学习ArkTS
9…

wKgZomXW6QaAM4niAAQzrXUUPik914.png

基于ArkTS 开发:https://docs.qq.com/doc/DUk51cHZJaUpmSlhH
1.Ability开发
2.UI开发
3.公共事件与通知
4.窗口管理
5.媒体
6.安全
7.网络与链接
8.电话服务
9.数据管理
10.后台任务(Background Task)管理
11.设备管理
12.设备使用信息统计
13.DFX
14.国际化开发
15.折叠屏系列
16………

wKgZomXW6RKATahiAAKz-zSMnR4040.png


审核编辑 黄宇

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

    关注

    0

    文章

    657

    浏览量

    32871
  • 鸿蒙
    +关注

    关注

    57

    文章

    2352

    浏览量

    42858
  • OpenHarmony
    +关注

    关注

    25

    文章

    3722

    浏览量

    16317
收藏 人收藏

    评论

    相关推荐

    鸿蒙Flutter实战:02-Windows环境搭建踩坑指南

    环境搭建 1. 下载Flutter SDK,配置环境变量 鸿蒙 Flutter SDK 需要在 Gitee 下载。目前建议下载 dev 分支
    发表于 10-22 15:05

    鸿蒙OpenHarmony南向/北向快速开发教程-迅为RK3568开发板

    源码 P3_初次编译OpenHarmony源码 P4_OpenHarmony镜像简介以及烧写工具配置 P5_优化开发流程-搭建windows开发环境
    发表于 07-23 10:44

    深耕鸿蒙生态,国科微旗舰芯片获“鸿蒙4.0”首款认证

    7月9日,国科微宣布旗下超高清视频解码及商显芯片通过OpenHarmony4.0版本兼容性测评,获颁鸿蒙生态产品兼容性证书。其中,国科微GK6323V100C是业界首款通过
    的头像 发表于 07-10 13:10 470次阅读
    深耕<b class='flag-5'>鸿蒙</b>生态,国科微旗舰芯片获“<b class='flag-5'>鸿蒙</b><b class='flag-5'>4.0</b>”首款认证

    鸿蒙开发:【OpenHarmony 4.0 Release指导】

    OpenHarmony 4.0版本如期而,开发套件同步升级到API 10。相比3.2 Release版本,新增4000多个API,应用开发能力更加丰富;HDF新增200多个HDI接口,硬件适配更加便捷;我们持续优化图形框架和方
    的头像 发表于 05-14 09:59 1472次阅读
    <b class='flag-5'>鸿蒙</b>开发:【<b class='flag-5'>OpenHarmony</b> <b class='flag-5'>4.0</b> Release指导】

    鸿蒙OpenHarmony开发:【编译构建指导】

    OpenHarmony编译子系统是以GN和Ninja构建为基座,对构建和配置粒度进行部件化抽象、对内建模块进行功能增强、对业务模块进行功能扩展的系统,该系统提供以下基本功能
    的头像 发表于 05-13 09:31 1795次阅读
    <b class='flag-5'>鸿蒙</b><b class='flag-5'>OpenHarmony</b>开发:【<b class='flag-5'>编译</b>构建指导】

    鸿蒙OpenHarmony威廉希尔官方网站 :【Docker编译环境

    OpenHarmony为开发者提供了两种Docker环境,以帮助开发者快速完成复杂的开发环境准备工作。
    的头像 发表于 05-11 09:47 1477次阅读
    <b class='flag-5'>鸿蒙</b><b class='flag-5'>OpenHarmony</b>威廉希尔官方网站
:【Docker<b class='flag-5'>编译</b><b class='flag-5'>环境</b>】

    【开源鸿蒙】下载OpenHarmony 4.1 Release源代码

    本文介绍了如何下载开源鸿蒙OpenHarmony)操作系统 4.1 Release版本的源代码,该方法同样可以用于下载OpenHarmony最新开发版本(master
    的头像 发表于 04-27 23:16 926次阅读
    【开源<b class='flag-5'>鸿蒙</b>】下载<b class='flag-5'>OpenHarmony</b> 4.1 Release源代码

    鸿蒙OpenHarmony搭建Ubuntu环境

    支持在Windows环境下进行编译,如Hi3861、Hi3516系列开发板。因此,建议使用Ubuntu的编译环境对源码进行编译
    的头像 发表于 04-19 16:53 1280次阅读
    <b class='flag-5'>鸿蒙</b><b class='flag-5'>OpenHarmony</b>【<b class='flag-5'>搭建</b>Ubuntu<b class='flag-5'>环境</b>】

    鸿蒙OpenHarmony搭建Windows环境

    支持在Windows环境下进行编译,如Hi3861、Hi3516系列开发板。因此,建议使用Ubuntu的编译环境对源码进行编译
    的头像 发表于 04-19 15:42 603次阅读
    <b class='flag-5'>鸿蒙</b><b class='flag-5'>OpenHarmony</b>【<b class='flag-5'>搭建</b>Windows<b class='flag-5'>环境</b>】

    源码开放,开发者手机 buff 叠满

    OpenHarmony 编译环境搭建 官方文档: https://gitee.com/openharmony/docs/blob/
    发表于 03-04 14:29

    [鸿蒙]OpenHarmony4.0的Rust开发

    OpenHarmony 为了集成 C/C++ 代码和提升编译速度,使用了 GN + Ninja 的编译构建系统。GN 的构建语言简洁易读,Ninja 的汇编级编译规则直接高效。 为
    的头像 发表于 02-26 17:28 892次阅读
    [<b class='flag-5'>鸿蒙</b>]<b class='flag-5'>OpenHarmony4.0</b>的Rust开发

    鸿蒙OpenHarmony 4.0蓝牙代码结构简析

    OpenHarmony 4.0蓝牙代码结构简析前言 OpenHarmony 4.0上蓝牙仓和目录结构进行一次较大整改,本文基于4.0以上版本
    的头像 发表于 02-26 16:08 1570次阅读
    【<b class='flag-5'>鸿蒙</b>】<b class='flag-5'>OpenHarmony</b> <b class='flag-5'>4.0</b>蓝牙代码结构简析

    浅谈兼容 OpenHarmony 的 Flutter

    拓展,可支持使用 Flutter Tools 指令编译和构建 OpenHarmony 应用程序。 仓库的 commit 记录显示,OpenHarmony 使用的 Flutter 版本是 3.7 稳定
    的头像 发表于 02-02 15:22 613次阅读
    浅谈<b class='flag-5'>兼容</b> <b class='flag-5'>OpenHarmony</b> 的 Flutter

    鸿蒙OS4.0兼容性测试

    dcts N N Y ssts N N Y 以上部分是对兼容性测评的常规介绍。下面我们要讲从OpenHarmony3.2Release开始,到4.0进入设置应用的兼容性证明页面,如
    发表于 01-17 20:38

    鸿蒙开发南向环境搭建教学

    南向开发环境搭建教学,更多鸿蒙开发资料可以前往高清完整版 《鸿蒙开发4.0基础-高阶文档》找保存。(附鸿
    发表于 01-05 16:38