一文搞懂鸿蒙OS应用的目录结构

风&飘 2021-08-10 14:04:57 5085

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

①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 应用的逻辑结构如图 1 所示:

图 1:HarmonyOS 应用逻辑结构图

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

图 2: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 文件。

图 4:entry 模块图

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 索引,通过指定文件路径和文件名来引用)。

其中最重要的是 base 目录(如图 5 所示),其目录内容如下:

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

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

图 6

但文件名称建议和如下文件名称一致:
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 版本管理需要忽略的文件。

来源:鸿蒙技术社区

声明:本文内容由易百纳平台入驻作者撰写,文章观点仅代表作者本人,不代表易百纳立场。如有内容侵权或者其他问题,请联系本站进行删除。
风&飘
红包 93 收藏 评论 打赏
评论
0个
内容存在敏感词
手气红包
    易百纳技术社区暂无数据
相关专栏
置顶时间设置
结束时间
删除原因
  • 广告/SPAM
  • 恶意灌水
  • 违规内容
  • 文不对题
  • 重复发帖
打赏作者
易百纳技术社区
风&飘
您的支持将鼓励我继续创作!
打赏金额:
¥1易百纳技术社区
¥5易百纳技术社区
¥10易百纳技术社区
¥50易百纳技术社区
¥100易百纳技术社区
支付方式:
微信支付
支付宝支付
易百纳技术社区微信支付
易百纳技术社区
打赏成功!

感谢您的打赏,如若您也想被打赏,可前往 发表专栏 哦~

举报反馈

举报类型

  • 内容涉黄/赌/毒
  • 内容侵权/抄袭
  • 政治相关
  • 涉嫌广告
  • 侮辱谩骂
  • 其他

详细说明

审核成功

发布时间设置
发布时间:
是否关联周任务-专栏模块

审核失败

失败原因
备注
拼手气红包 红包规则
祝福语
恭喜发财,大吉大利!
红包金额
红包最小金额不能低于5元
红包数量
红包数量范围10~50个
余额支付
当前余额:
可前往问答、专栏板块获取收益 去获取
取 消 确 定

小包子的红包

恭喜发财,大吉大利

已领取20/40,共1.6元 红包规则

    易百纳技术社区