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

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

3天内不再提示

简述HarmonyOS 应用的目录结构

华为麒麟 来源:鸿蒙技术社区 作者: starLWW 2021-08-20 10:11 次阅读

应用中的几种常见类型的文件

①Ability

Ability 是应用所具备的能力的抽象,一个应用可以包含一个或多个 Ability。

Ability 分为两种类型:FA(Feature Ability,中文名称:元程序)和 PA(Particle Ability,中文名称:元服务)。

FA/PA 是应用的基本组成单元,能够实现特定的业务功能。FA 有 UI 界面,而 PA 无 UI 界面。

②库文件

库文件是应用依赖的第三方代码(例如 so、jar、bin、har 等二进制文件),存放在 libs 目录。

③资源文件

应用的资源文件(字符串、图片、音频等)存放于 resources 目录下,便于开发者使用和维护,详见资源文件的分类。

④配置文件

配置文件(config.json)是应用的 Ability 信息,用于声明应用的 Ability,以及应用所需权限等信息,详见应用配置文件。

⑤pack.info

描述应用软件包中每个 HAP 的属性,由 IDE 编译生成,应用市场根据该文件进行拆包和 HAP 的分类存储。

HAP 的具体属性包括:

delivery-with-install:表示该 HAP 是否支持随应用安装。

“true”表示支持随应用安装;

“false”表示不支持随应用安装。

name:HAP 文件名。

module-type:模块类型,entry 或 feature。

device-type:表示支持该 HAP 运行的设备类型。

⑥HAR

HAR(HarmonyOS Ability Resources)可以提供构建应用所需的所有内容,包括源代码、资源文件和 config.json 文件。

HAR 不同于 HAP,HAR 不能独立安装运行在设备上,只能作为应用模块的依赖项被引用。

HarmonyOS 应用的目录结构

HarmonyOS 应用发布形态为 APP Pack(Application Package,简称 APP),它是由一个或多个 HAP(HarmonyOS Ability Package)包以及描述每个 HAP(Ability 的部署包)属性的 pack.info 文件组成。

Hap 包又可以分为 entry 类型和 feature 类型,每个 Hap 包由:代码、资源、第三方库及应用配置文件组成。

所以我们代码中的 entry 目录其实就是一个应用的 Hap 包,它是 entry 类型的 Hap 包。接下来我们来了解下这些资源。

entry:应用的主模块。一个 APP 中,对于同一设备类型必须有且只有一个 entry 类型的 HAP,可独立安装运行。

feature:应用的动态特性模块。一个 APP 可以包含 0 个、一个或多个 feature 类型的 HAP。只有包含 Ability 的 HAP 才能够独立运行。

HAP 是 Ability 的部署包,HarmonyOS 应用代码围绕 Ability 组件展开,它是由一个或多个 Ability 组成。

一个典型的 HarmonyOS 应用的具体目录结构如图 2 所示,主要包括 entry、gradle 目录等,其中的 build 目录是应用编译构建成功后自动生成的目录。

0ff0464a-00ef-11ec-9bcf-12bb97331649.jpg

HarmonyOS 应用目录结构图

setting.gradle 文件用于指定应用包含哪些 entry 或 feature 模块。

build.gradle 文件是应用的环境配置文件,如指定编译应用程序使用的 sdk 版本,依赖外部 maven 库等。

gradle 目录是 gradle 的配置文件,由系统自动生成,一般情况下不需要进行修改。

其中gradle》wrapper》gradle-wrapper.properties 文件一般用于指定应用使用的 gradle 版本。

build 目录是在编译构建过程中生成的,该目录中主要包含该 entry 编译生成的 hap 包及其对应的描述文件 pack.info,以及用于索引所有资源文件的 ResourceTable 文件。

图 3

特别注意的是:所有资源如包括控件名称、字符串常量、动画资源、长度资源、布局资源、图片、音视频资源等都将在 ResourceTable 文件中生成唯一的静态整型索引常量。

通过这个索引可以访问到具体的资源,如 Java 代码中得到名称为 ability_main.xml 布局文件的方法:ResourceTable.Layout_ability_main。

entry 是该应用的主模块,其目录下包含 build、libs、src 目录和一个主要的 build.gradle 文件。

entry 中各目录及文件含义如下:

①entry》libs 目录下用于存放第三方的 jar 包,是该 entry 模块对第三方类库的存放目录。

②entry》src 目录是该 entry 模块的所有源程序目录,我们重点关注该目录中的 main 目录和 config.json 文件。

main 目录下包含 java 和 resources 目录。

entry》src》main》java 包括应用中所有的 java 文件,以包的形式进行组织。

一个可视化的 Ability(FA)的呈现包含的 3 个文件,其中的 Slice 和 Ability 都在 main 目录下。

该目录下还可以添加其他业务逻辑处理的 java 类文件,如实现网络操作、数据库操作等业务类,用户自定义的工具类等。需要注意的是,实现一个可视化的 Ability,Slice 并不是必须的。

entry》src》main》resources 目录是所有资源文件所在的目录。

resources 目录包括两大类目录:

一类是 base 目录与限定词目录,目录中的资源文件会被编译成二进制文件,并赋予资源文件 ID(能被 ResourceTable 索引,通过指定资源类型(type)和资源名称(name)来引用)。

另一类是 rawfile 目录,目录中的资源文件会被直接打包进应用,不经过编译,也不会被赋予资源文件 ID(不能被 ResourceTable 索引,通过指定文件路径和文件名来引用)。

resources》base》element:表示字符串、整型数、颜色、样式等常量资源,采用相应的JSON文件来表示,可以在其他地方被引用。

默认只包含一个string.json文件,程序员可根据自己的需要添加其他类型的文件。

但文件名称建议和如下文件名称一致:

strings.json:字符串值资源(默认包含)

boolean.json:布尔型资源

color.json:颜色资源

float.json:浮点型资源

intarray.json:整型数组资源

integer.json:整型资源

pattern.json:样式资源

plural.json:复数形式资源

strarray.json:字符串数组资源

resources》base》graphic:表示可绘制资源,如 SVG(Scalable Vector Graphics)可缩放矢量图形文件、Shape 基本的几何图形(如矩形、圆形、线等)等。

用 xml 文件来表示,比如我们项目中设置的圆角按钮、按钮颜色等都是通过引用这里的资源来统一管理的:

base》graphic:xml 类型的可绘制资源。

resources》base》layout:表示布局资源,用 xml 文件来表示。

resources》base》media:表示媒体资源,包括图片、音频、视频等非文本格式的文件,支持的文件格式包括:.png、.gif、.mp3、.mp4 等。

resources》限定词目录:en_…,如 en_element、zh_element、en_GB-vertical-car-mdpi 等。限定词目录需要开发者自行创建。

目录名称由一个或多个表征应用场景或设备特征的限定词组合而成,可以包含移动国家码和移动网络码、语言、文字、横竖屏、设备类型、颜色模式等限定词。

对应限定词的取值必须与当前的设备状态完全一致,该目录才能够参与设备的资源匹配。

例如,限定词目录“zh_CN-car-ldpi”不能参与“en_US”设备的资源匹配。

resources》rawfile/profile 目录:用于存储任意格式的原始资源文件。允许程序员创建多层子目录,目录名称可以自定义,目录下也可以自由放置各类资源文件。该目录的文件不会根据设备状态去匹配不同的资源。

entry》src》main》config.json 文件是 entry(或 feature)的配置文件,由“app”、“deviceConfig”和“module”三个部分组成,缺一不可。

其中“app” 表示应用的全局配置信息,同一个应用的不同 HAP 包的“app”配置必须保持一致;“deviceConfig”表示应用在具体设备上的配置信息;“module”表示 HAP 包的配置信息。该标签下的配置只对当前 HAP 包生效。

③entry》build.gradle:entry 模块的编译配置文件,包括 entry 使用的 SDK 版本、所依赖的资源(如 maven 库、Jar 类库等)。

④entry》src》test:编写代码单元测试代码的目录,运行在本地 Java 虚拟机(JVM)上。

⑤entry》.gitignore:标识 git 版本管理需要忽略的文件。

编辑:jq

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

    关注

    30

    文章

    4552

    浏览量

    66642
  • 库文件
    +关注

    关注

    5

    文章

    33

    浏览量

    14367
  • HarmonyOS
    +关注

    关注

    79

    文章

    1769

    浏览量

    29231
收藏 人收藏

    评论

    相关推荐

    2024款鸿蒙OS 最新HarmonyOS Next_HarmonyOS4.0系列教程分享

    实战,还包含了HarmonyOS 仿小米App实战。详情参考大纲或者目录介绍。 根据华为鸿蒙生态推广部门介绍,HarmonyOS4和未来的HarmonyOS5(
    发表于 02-28 10:29

    harmonyos和安卓的区别

    HarmonyOS是由华为开发的一款全场景分布式操作系统,而安卓(Android)则是由谷歌开发的移动操作系统。虽然两者都是操作系统,但它们在很多方面存在明显的区别。下面是关于HarmonyOS
    的头像 发表于 01-10 17:55 1005次阅读

    全志R128 SDK架构与目录结构

    系统、文件系统、网络系统、BSP 驱动等。 Component。组件层包括控制台、多媒体、功耗管理、OTA、音频系统、显示系统、图像采集等。 APP。应用层包括各种应用demo。 SDK 目录结构
    发表于 01-05 10:05

    HarmonyOS资料下载专题

    HarmonyOS资料下载专题:从鸿蒙出世到现在,对于鸿蒙资料查询下载,大家是否有点迷茫-不知去何处查找。为此,本专题汇集了HarmonyOS从入门到精通的各种开发资料,内容包括:设计参考、程序源码、开发实例、教程笔记等等,为大家节省了大量的资料搜索时间,方便大家轻松下载
    发表于 10-08 14:23
    <b class='flag-5'>HarmonyOS</b>资料下载专题

    OpenHarmony ArkTS工程目录结构(Stage模型)

    配置文件中,配置卡片(WidgetCard.ets)相关信息。 卡片目录 快照目录 图片来源:OpenHarmony官网 蛟龙腾飞公司提供 *附件:OpenHarmony ArkTS工程目录
    发表于 09-18 15:23

    HarmonyOS/OpenHarmony应用开发-DevEco Studio新建项目的整体说明

    一、文件-新建-新建项目 二、传统应用形态与IDE自带的模板可供选用与免安装的元服与IDE中自带模板的选择 三、以元服务,远程模拟器为例说明IDE整体结构 1区是工程目录结构,是最基本的配置
    发表于 09-15 16:51

    HarmonyOS NEXT新能力,一站式高效开发HarmonyOS应用

    2023年8月4日的华为开发者大会2023(HDC.Together)拉开帷幕,伴随着HarmonyOS 4的发布,华为向开发者发布了汇聚所有最新开发能力的HarmonyOS NEXT开发者预览版
    的头像 发表于 08-09 17:16 772次阅读

    探秘!首届 HarmonyOS 极客马拉松究竟有多酷?

    两天一夜能做什么? 开发者的脑洞有多大? HarmonyOS 有多少可能性? 开发者代表带你探秘首届 HarmonyOS 极客马拉松现场! 速来围观! END 大会还有更多精彩环节,想需要了解更现场
    的头像 发表于 08-04 19:15 358次阅读

    Linux设备树目录结构dtb格式

    要的。 设备树目录结构 dtb 格式 /sys/firmware/devicetree 以目录结构程现的 dtb 文件, 根节点对应 base 目录
    的头像 发表于 07-30 15:25 431次阅读
    Linux设备树<b class='flag-5'>目录</b><b class='flag-5'>结构</b>dtb格式

    【直播预告】HarmonyOS极客松赋能直播第四期:HarmonyOS开发经验分享

    Release新版发布 HarmonyOS Connect认证测试 原文标题:【直播预告】HarmonyOS极客松赋能直播第四期:HarmonyOS开发经验分享 文章出处:【微信公众号:Ha
    的头像 发表于 07-03 09:05 331次阅读
    【直播预告】<b class='flag-5'>HarmonyOS</b>极客松赋能直播第四期:<b class='flag-5'>HarmonyOS</b>开发经验分享

    二次回路简述

    二次回路简述
    的头像 发表于 06-28 10:15 523次阅读
    二次回路<b class='flag-5'>简述</b>

    恒讯科技分析:如何使用cp命令在Linux中复制目录

    ,以及自定义复制过程的各种选项和技术。 我们可以cp在Linux中使用该命令将文件和目录从一个位置复制到另一个位置。它代表“复制”,是文件管理的基本命令行实用程序。 该cp命令遵循复制目录的特定语法。了解命令的基本结构对于成功进
    的头像 发表于 06-26 17:14 456次阅读

    HarmonyOS云开发:舒尔特方格游戏

    为丰富 HarmonyOS 对云端开发的支持、实现 HarmonyOS 生态端云联动,DevEco Studio 推出了云开发功能,开发者在创建工程时选择云开发模板。
    的头像 发表于 06-19 15:05 486次阅读
    <b class='flag-5'>HarmonyOS</b>云开发:舒尔特方格游戏

    Linux入门之目录结构

    Linux操作系统的发行版众多,为了统一不同发行版系统中的目录结构,FHS(Filesystem Hierarchy Standard)标准应运而生。 FHS的重点在于规范每个特定的目录下应该
    的头像 发表于 05-12 15:48 728次阅读

    HarmonyOS Codelabs最新参考

    HarmonyOS Codelabs最新参考 作者:坚果 团队:坚果派 公众号:“大前端之旅” 润开鸿技术专家,华为HDE,InfoQ签约作者,OpenHarmony布道师,擅长HarmonyOS
    的头像 发表于 04-25 15:40 583次阅读
    <b class='flag-5'>HarmonyOS</b> Codelabs最新参考