应用的资源文件(字符串、图片、音频等)统一存放于resources
目录下,便于开发者使用和维护。resources
目录包括两大类目录,一类为base
目录与限定词目录,另一类为 rawfile
目录,详见表1。
资源目录示例:
resources
|---base // 默认存在的目录
| |---element
| | |---string.json
| |---media
| | |---icon.png
|---en_GB-vertical-car-mdpi // 限定词目录示例,需要开发者自行创建
| |---element
| | |---string.json
| |---media
| | |---icon.png
|---rawfile // 默认存在的目录
表1 resources
目录分类
分类 | base 目录与限定词目录 |
rawfile 目录 |
---|---|---|
组织形式 | 按照两级目录形式来组织,目录命名必须符合规范,以便根据设备状态去匹配相应目录下的资源文件。 一级子目录为 base 目录和 限定词目录。base 目录是默认存在的目录。当应用的resources 资源目录中没有与设备状态匹配的限定词目录时,会自动引用该目录中的资源文件。限定词目录需要开发者自行创建。目录名称由一个或多个表征应用场景或设备特征的限定词组合而成,具体要求参见限定词目录。二级子目录为资源目录,用于存放字符串、颜色、布尔值等基础元素,以及媒体、动画、布局等资源文件,具体要求参见资源组目录)。 |
支持创建多层子目录,目录名称可以自定义,文件夹内可以自由放置各类资源文件。rawfile 目录的文件不会根据设备状态去匹配不同的资源。 |
编译方式 | 目录中的资源文件会被编译成二进制文件,并赋予资源文件ID。 | 目录中的资源文件会被直接打包进应用,不经过编译,也不会被赋予资源文件 ID。 |
引用方式 | 通过文件类型(type )和资源名称(name )的组合引用。Java 文件采用:ResourceTable.*type*_****name。特别地,如果引用的是系统资源,则采用:ohos.global.systemres.ResourceTable.*type*_*name*。 XML 文件采用:$*type*:*name*。特别地,如果引用的是系统资源,则采用:$ohos:*type*:*name*。 |
通过指定文件路径和文件名来引用。 例如:“ resources/rawfile/example.js ”。 |
限定词目录可以由一个或多个表征应用场景或设备特征的限定词组合而成,包括语言、文字、国家或地区、横竖屏、设备类型和屏幕密度等六个维度,限定词之间通过下划线(_
)或者中划线(-
)连接。开发者在创建限定词目录时,需要掌握限定词目录的命名要求以及与限定词目录与设备状态的匹配规则。
限定词目录的命名**要求**
_
)连接,除此之外的其他限定词之间均采用中划线(-
)连接。例如:zh_Hant_CN、zh_CN-car-ldpi。
表2 限定词取值要求
限定词类型 | 含义与取值说明 |
---|---|
语言 | 表示设备使用的语言类型,由 2个小写字母组成。 例如: zh 表示中文,en 表示英语。详细取值范围,参见 ISO 639-1(ISO 制定的语言编码标准)。 |
文字 | 表示设备使用的文字类型,由 1个大写字母(首字母)和 3个小写字母组成。 例如: Hans 表示简体中文,Hant 表示繁体中文。详细取值范围,参见 ISO 15924(ISO 制定的文字编码标准)。 |
国家或地区 | 表示用户所在的国家或地区,由 2~3个大写字母或者 3个数字组成。 例如: CN 表示中国,GB 表示英国。详细取值范围,参见 ISO 3166-1(ISO 制定的国家和地区编码标准)。 |
横竖屏 | 表示设备的屏幕方向,取值如下:vertical :竖屏horizontal :横屏 |
设备类型 | 表示设备的类型,取值如下:car :车机tv :智慧屏wearable :智能穿戴 |
屏幕密度 | 表示设备的屏幕密度(单位为dpi ),取值如下:sdpi :表示小规模的屏幕密度(Small-scale Dots Per Inch ),适用于120dpi及以下的设备。mdpi :表示中规模的屏幕密度(Medium-scale Dots Per Inch ),适用于120dpi~160dpi 的设备。ldpi :表示大规模的屏幕密度(Large-scale Dots Per Inch ),适用于160dpi~240dpi 的设备。xldpi :表示特大规模的屏幕密度(Extra Large-scale Dots Per Inch ),适用于240dpi~320dpi 的设备。xxldpi :表示超大规模的屏幕密度(Extra Extra Large-scale Dots Per Inch ),适用于320dpi~480dpi 的设备。xxxldpi :表示超特大规模的屏幕密度(Extra Extra Extra Large-scale Dots Per Inch ),适用于480dpi~640dpi 的设备。 |
限定词目录与设备状态的匹配规则
区域(语言_文字_国家或地区)> 横竖屏 > 设备类型 > 屏幕密度
。zh_CN-car-ldpi
”不能参与“en_US
”设备的资源匹配。
base
目录与限定词目录下面可以创建资源组目录(包括element
、media
、animation
、layout
、graphic
、profile
),用于存放特定类型的资源文件,详见表3。
表3 资源组目录 说明
资源组目录 | 目录说明 | 资源文件 |
---|---|---|
element |
表示元素资源,以下每一类数据都采用相应的 JSON 文件来表征。boolean ,布尔型color ,颜色float ,浮点型intarray ,整型数组integer ,整型pattern ,样式plural ,复数形式strarray ,字符串数组string ,字符串 |
element 目录中的文件名称建议与下面的文件名保持一致。每个文件中只能包含同一类型的数据。 boolean.json color.json float.json intarray.json integer.json pattern.json plural.json strarray.json string.json |
media |
表示媒体资源,包括图片、音频、视频等非文本格式的文件。 | 文件名可自定义,例如:icon.png 。 |
animation |
表示动画资源,采用 XML 文件格式。 | 文件名可自定义,例如:zoom_in.xml 。 |
layout |
表示布局资源,采用 XML 文件格式。 | 文件名可自定义,例如:home_layout.xml 。 |
graphic |
表示可绘制资源,采用 XML 文件格式。 | 文件名可自定义,例如:notifications_dark.xml 。 |
profile |
表示其他类型文件,以原始文件形式保存。 | 文件名可自定义。 |
目前支持的系统资源文件详见表4。
表4 系统资源文件说明
系统资源名称 | 含义 | 类型 |
---|---|---|
ic_app | 表示 HarmonyOS 应用的默认图标。 | 媒体 |
request_location_reminder_title | 表示“请求使用设备定位功能”的提示标题。 | 字符串 |
request_location_reminder_content | 表示“请求使用设备定位功能”的提示内容,即:请在下拉快捷栏打开"位置信息"开关。 | 字符串 |
boolean.json
示例
{
"boolean":[
{
"name":"boolean_1",
"value":true
},
{
"name":"boolean_ref",
"value":"$boolean:boolean_1"
}
]
}
color.json
示例
{
"color":[
{
"name":"red",
"value":"#ff0000"
},
{
"name":"red_ref",
"value":"$color:red"
}
]
}
float.json
示例
{
"float":[
{
"name":"float_1",
"value":"30.6"
},
{
"name":"float_ref",
"value":"$float:float_1"
},
{
"name":"float_px",
"value":"100px"
}
]
}
intarray.json
示例
{
"intarray":[
{
"name":"intarray_1",
"value":[
100,
200,
"$integer:integer_1"
]
}
]
}
integer.json
示例
{
"integer":[
{
"name":"integer_1",
"value":100
},
{
"name":"integer_ref",
"value":"$integer:integer_1"
}
]
}
pattern.json
示例
{
"pattern":[
{
"name":"base",
"value":[
{
"name":"width",
"value":"100vp"
},
{
"name":"height",
"value":"100vp"
},
{
"name":"size",
"value":"25px"
}
]
},
{
"name":"child",
"parent":"base",
"value":[
{
"name":"noTitile",
"value":"Yes"
}
]
}
]
}
plural.json
示例
{
"plural":[
{
"name":"eat_apple",
"value":[
{
"quantity":"one",
"value":"%d apple"
},
{
"quantity":"other",
"value":"%d apples"
}
]
}
]
}
strarray.json
示例
{
"strarray":[
{
"name":"size",
"value":[
{
"value":"small"
},
{
"value":"$string:hello"
},
{
"value":"large"
},
{
"value":"extra large"
}
]
}
]
}
string.json
示例
{
"string":[
{
"name":"hello",
"value":"hello base"
},
{
"name":"app_name",
"value":"my application"
},
{
"name":"app_name_ref",
"value":"$string:app_name"
},
{
"name":"app_sys_ref",
"value":"$ohos:string:request_location_reminder_title"
}
]
}