Module是应用/元服务的基本功能单元,包含了源代码、资源文件、第三方库及应用/元服务配置文件,每一个Module都可以独立进行编译和运行。一个应用/元服务通常会包含一个或多个Module,因此,可以在工程中创建多个Module,每个Module分为Ability和Library两种类型。Module支持entry、feature、har、shared四种类型。
1. 通过如下三种方法,在工程中添加新的Module。
方法1:鼠标移到工程目录顶部,单击鼠标右键,选择New > Module...,开始创建新的Module,此时该module将创建在工程根目录下。
方法2:选中工程目录中任意文件,然后在菜单栏选择File > New > Module...,开始创建新的Module,此时该module将创建在工程根目录下。
方法3:在工程根目录下创建一个新的Directory,可在该目录下单击鼠标右键,选择New > Module...,创建新的Module,此时module将创建在该文件目录下,方便开发者对模块进行分类管理。
说明
当前暂不支持在AppScope、hvigor、oh_modules、build、点开头的目录(如:.hvigor、.idea)下通过单击鼠标右键创建module。
2. 在New Project Module界面中,选择需要创建的模板,单击Next。
3. 在Module配置页面,设置新增Module的基本信息,然后单击Next。
4. 若该Module的模板类型为Ability,还需要设置新增Ability的Ability name和Exported参数,Exported参数表示该Ability是否可以被其它应用/元服务所调用(FA模型下为Visible参数)。
5. 单击Finish,等待创建完成后,可以在工程目录中查看和编辑新增的Module。工程中所包含模块的信息可以在build-profile.json5中module字段进行配置。
HarmonyOS工程支持导入其它HarmonyOS模块的功能。当前仅支持FA模型的模块导入到FA模型,Stage模型的模块导入到Stage模型。不支持FA模型的模块导入到Stage模型,或Stage模型的模块导入到FA模型。
说明
DevEco Studio支持引用当前工程目录之外,即其他工程下的Module。除Import Module方式导入模块外,可通过在build-profile.json5文件中srcPath字段下配置工程外Module的相对路径导入。通过srcPath方式导入工程,仅引用Module相关信息,不会将Module代码完全复制至本地。
1. 在菜单栏单击File > New > Import... > Import Module。
2. 选择导入的模块。在指定路径下,选择导入的模块,单击OK。导入的模块可以为文件夹,也可以为zip格式。
同一类型的设备(Phone、Wearable、Lite Wearable等)可能在系统API版本(apiVersion)、屏幕形状(screenShape)、窗口分辨率(screenWindow)上存在差异。针对这些差异,需要针对同一类型设备的不同型号进行适配开发,然后在应用市场实现精准的分发,以便不同设备的用户能获得更好的使用体验。为了实现应用市场的精准分发,需要在一个工程中,针对同一类型设备添加多个Entry模块来适配不同型号的设备,然后再配置不同的分发规则。具体规则如下:
说明
screenWindow标签的policy取值只能为include。
Stage模型配置分发规则
1. 在entry > src > main > resources > profile文件夹中新建一个.json文件,并根据实际需要,配置如下代码信息。
{
"distributionFilter": {
"screenShape": { //屏幕形状枚举
"policy": "include",
"value": ["circle", "rect"]
},
"screenWindow": { //窗口分辨率
"policy": "include",
"value": ["454*454", "466*466"]
},
"screenDensity": { //屏幕的像素密度
"policy": "exclude",
"value": ["ldpi", "xldpi"]
},
"countryCode": { //国家地区
"policy": "include",
"value": ["CN", "HK"]
}
}
}
2. 在module.json文件中指定分发文件。
{
"module": {
"name": "MyAbilityStage",
"metadata": [
{
"name": "ohos.module.distro",
"resource": "$profile:distro_filter_config" //distro_filter_config为被指定的分发文件
}
]
}
}
FA模型分发规则配置
在同一个工程中,如果同一个设备存在多个Entry模块,需要在每一个Entry模块的config.json文件中,配置distroFilter分发规则。
"module": {
...
"distroFilter": {
"标签名字": {
"policy": "include|exclude"
"value": [ a, b, c]
}
}
}
在工程目录中选中要删除的模块,单击鼠标右键,选中Delete,并在弹出的对话框中单击Delete。