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

    文章

    4815

    浏览量

    68858
  • 库文件
    +关注

    关注

    5

    文章

    33

    浏览量

    14507
  • HarmonyOS
    +关注

    关注

    79

    文章

    1980

    浏览量

    30379
收藏 人收藏

    评论

    相关推荐

    HarmonyOS开发指导类文档更新速递(下)

    伴随着HarmonyOS 5.0.0 Release、HarmonyOS 5.0.1 Release版本的发布,HarmonyOS官网文档也带来了不少上新内容。本期HarmonyOS
    的头像 发表于 12-30 09:54 181次阅读
    <b class='flag-5'>HarmonyOS</b>开发指导类文档更新速递(下)

    AWTK 最新动态:支持鸿蒙系统(HarmonyOS Next)

    导读HarmonyOS是全球第三大移动操作系统,有巨大的市场潜力,在国产替代的背景下,机会多多,AWTK支持HarmonyOS,让AWTK开发者也能享受HarmonyOS生态的红利。AWTK全称
    的头像 发表于 11-06 08:03 294次阅读
    AWTK 最新动态:支持鸿蒙系统(<b class='flag-5'>HarmonyOS</b> Next)

    【米尔NXP i.MX 93开发板试用评测】3、NXP的MCU工程目录结构和源码分析

    环境无缝集成。 而NXP的项目工程,可以说是CMake工程的优秀示范。 目录结构 这种目录结构有助于提高软件开发的效率和质量,特别是在大型项目和团队合作的环境中。通过合理的组织和模块化
    发表于 09-21 21:11

    简述基本与非门sr锁存器的结构及工作原理

    。以下是对其基本结构及工作原理的简述: 一、结构 基本与非门SR锁存器主要由两个与非门组成,这两个与非门的输出分别连接到对方的输入端,形成交叉反馈的结构。具体来说,锁存器有两个输入端S
    的头像 发表于 08-28 11:01 2164次阅读

    简述毫米波雷达的结构、原理和特点

    毫米波雷达是一种利用毫米波段电磁波进行探测和测量的雷达系统,具有高分辨率、高灵敏度、高抗干扰能力等特点,在军事、航空、航天、交通、气象等领域得到广泛应用。 一、毫米波雷达的结构 毫米波雷达主要由天线
    的头像 发表于 08-16 10:05 2248次阅读

    简述半导体原理——晶体管家族的核心工作机制

    简述半导体原理——晶体管家族的核心工作机制
    的头像 发表于 07-20 08:14 1036次阅读
    <b class='flag-5'>简述</b>半导体原理——晶体管家族的核心工作机制

    简述数控机床对结构与性能的要求

    数控机床是一种采用数字化控制技术进行加工的机床,具有高精度、高效率、高自动化程度等特点。数控机床在机械制造、航空航天、汽车制造、模具制造等领域得到广泛应用。为了满足不同加工需求,数控机床对结构与性能
    的头像 发表于 07-01 14:06 936次阅读

    简述无极继电器的结构和工作原理

    无极继电器是一种电子控制器件,广泛应用于电力系统、自动化控制、通信、计算机等领域。它具有体积小、重量轻、动作快、可靠性高、寿命长等优点。本文将详细介绍无极继电器的结构和工作原理。 一、无极继电器
    的头像 发表于 06-24 09:36 3636次阅读

    在模版工程中新建了一个目录components,在这个目录中新建了.c和.h文件文件中有包含idf的库文件,为什么找不到?

    我在模版工程中新建了一个目录components,在这个目录中新建了.c和.h文件,文件中有包含idf的库文件,从头文件跳转是可以跳转过去的,但是编译结果却报错,显示找不到此文件。 目录结构
    发表于 06-06 07:43

    HarmonyOS开发案例:【常用组件与布局】

    HarmonyOS ArkUI提供了丰富多样的UI组件,您可以使用这些组件轻松地编写出更加丰富、漂亮的界面。
    的头像 发表于 05-09 18:20 1267次阅读
    <b class='flag-5'>HarmonyOS</b>开发案例:【常用组件与布局】

    HarmonyOS开发案例:【首选项】

    基于HarmonyOS的首选项能力实现的一个简单示例。
    的头像 发表于 04-19 16:20 1297次阅读
    <b class='flag-5'>HarmonyOS</b>开发案例:【首选项】

    简述结构光成像

    首先我们来看看结构光成像,它是使用特定的光图案和2D相机来捕获物体表面的三维轮廓的一种成像方法。其原理是将特定的窄带光投影到三维形状物体的表面上会产生一条照明线,该照明线从投影器的其他角度来看存在
    的头像 发表于 03-05 16:35 729次阅读
    <b class='flag-5'>简述</b>面<b class='flag-5'>结构</b>光成像

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

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

    ADS应用技巧—如何修改ADS的home目录

    这里说的home目录就是启动ADS后,默认打开的路径,通常是你存放ADS工程所在的目录
    的头像 发表于 02-26 09:43 2354次阅读
    ADS应用技巧—如何修改ADS的home<b class='flag-5'>目录</b>?

    OpenHarmony 移植:build lite 配置目录全梳理

    命令行工具 hb (HarmonyOS|OpenHarmony Build 编译构建系统的缩写) 都很熟悉了。这是一个基于 gn 和 ninja 的构建系统,以支持 OpenHarmony 组件化开
    的头像 发表于 02-18 16:42 1000次阅读