1# 窗口元数据配置 2<!--Kit: ArkUI--> 3<!--Subsystem: Window--> 4<!--Owner: @waterwin--> 5<!--Designer: @nyankomiya--> 6<!--Tester: @qinliwen0417--> 7<!--Adviser: @ge-yafang--> 8 9## metadata标签 10 11该标签标识HAP的自定义元信息,标签值为数组类型,包含name、value、resource三个子标签。 12 13**表1** metadata标签说明 14 15| 属性名称 | 含义 | 数据类型 | 是否可缺省 | 16| -------- | -------- | -------- | -------- | 17| name | 标识数据项的名称,取值为长度不超过255字节的字符串。 | 字符串 | 该标签可缺省,缺省值为空。 | 18| value | 标识数据项的值,取值为长度不超过255字节的字符串。 | 字符串 | 该标签可缺省,缺省值为空。 | 19| resource | 标识了用户自定义数据,取值为长度不超过255字节的字符串,内容为该数据的资源索引,例如配置成$profile:shortcuts_config,表示指向了/resources/base/profile/shortcuts_config.json配置文件。| 字符串 | 该标签可缺省,缺省值为空。 | 20 21下面给出几种metadata标签的使用场景及示例,开发者也可以根据实际需求自定义设置。 22 231. 使用metadata标签配置主窗口的默认大小和位置(单位为vp)。其中name取值及对应含义如下: 24 25 * name取值为ohos.ability.window.height表示主窗口的默认高度,value表示高度大小。 26 * name取值为ohos.ability.window.width表示主窗口的默认宽度,value表示宽度大小。 27 * name取值为ohos.ability.window.left表示主窗口默认左边的位置。value表示配置格式,取值:对齐方式 +/- 偏移量。对齐方式包括center、left和right,默认值为left;当偏移量为0时可以省略。 28 * name取值为ohos.ability.window.top表示主窗口顶部的位置。value表示配置格式,取值:对齐方式 +/- 偏移量。对齐方式包括center、top和bottom,默认值为top。如果对齐方式和偏移量同时省略,则按照系统默认的层叠规格处理。 29 302. 使用metadata标签配置是否移除启动页。配置项为:name取值为enable.remove.starting.window,value取值为true或false,取值为true表示移除启动页、取值为false表示不移除启动页,未配置时默认为false。 31 323. 使用metadata标签配置主窗启动时是否以最大化状态显示。配置项为:name为ohos.ability.window.isMaximize,value取值为true或false,取值为true表示最大化启动、取值为false表示不以最大化状态启动,未配置时默认为false。主窗最大化显示配置存在如下约束与限制: 33 34 * 该配置项仅在PC/2in1设备上生效。 35 * 若使用[startOptions](../reference/apis-ability-kit/js-apis-app-ability-startOptions.md)的supportWindowModes属性,需要配置FULL_SCREEN选项,此时使用metadata标签配置主窗最大化启动生效,否则不生效。 36 * 若使用[module.json5](../quick-start/module-configuration-file.md#abilities标签)的supportWindowMode属性,需要配置fullscreen选项,此时使用metadata标签配置主窗最大化启动生效,否则不生效。 37 * 主窗显示设置优先级排序为:全屏显示 > 使用[startOptions](../reference/apis-ability-kit/js-apis-app-ability-startOptions.md)接口指定大小和位置 > 使用[setWindowRectAutoSave()](../reference/apis-arkui/arkts-apis-window-WindowStage.md#setwindowrectautosave14)方法开启窗口尺寸记忆 > 使用metadata标签配置最大化 > 使用metadata标签配置大小和位置。全屏显示配置方法包括如下三种: 38 1. 使用[startOptions](../reference/apis-ability-kit/js-apis-app-ability-startOptions.md)的windowMode属性并将其配置为WINDOW_MODE_FULLSCREEN。 39 2. 使用[startOptions](../reference/apis-ability-kit/js-apis-app-ability-startOptions.md)的supportWindowModes属性,且只配置FULL_SCREEN选项。 40 3. 使用[module.json5](../quick-start/module-configuration-file.md#abilities标签)的supportWindowMode属性,且只配置fullscreen选项。 41 424. 使用metadata配置[自由多窗](https://developer.huawei.com/consumer/cn/doc/design-guides/pad-0000001823654157#section1768267204717)下的可支持窗口模式。配置项为:name为ohos.ability.window.SupportWindowModeInFreeWindow,value取值为:fullscreen(表示全屏模式)、split(表示分屏模式)、floating(表示悬浮窗模式)。value取值为字符串,可以取多种模式,每个之间用逗号分隔开,不区分顺序,不添加空格,例如:fullscreen,split。仅在平板、PC/2in1设备上生效。 43 44 自由多窗下的可支持窗口模式可以采用多种方法进行配置,配置优先级为:通过[SetSupportedWindowModes](../reference/apis-arkui/arkts-apis-window-WindowStage.md#setsupportedwindowmodes15)接口配置 > 通过StartAbility配置[StartOption](../reference/apis-ability-kit/js-apis-app-ability-startOptions.md#startoptions)中的SupportWindowMode > 使用metadata配置 > 配置module.json5中[abilities](../quick-start/module-configuration-file.md#abilities标签)标签下的SupportWindowMode属性。 45 46 非自由多窗模式下只能通过配置module.json5中abilities标签下的SupportWindowMode属性配置窗口支持模式,其他配置方式均不生效。 47 48<!--Del--> 495. 使用metadata标签配置主窗边角以直角显示。配置项为:name为ohos.ability.window.isRightAngle,value取值为true或false,取值为true表示窗口边角以直角显示、取值为false则使用系统默认圆角,未配置时默认为false。主窗直角配置仅在PC/2in1设备上生效,且仅支持系统应用。<!--DelEnd--> 50 51 52```json 53{ 54 "module": { 55 "abilities": [{ 56 "metadata": [{ 57 "name": "ability_metadata", 58 "value": "a test demo for ability", 59 "resource": "$profile:config_file" 60 }, 61 { 62 "name": "ability_metadata_2", 63 "value": "a string test", 64 "resource": "$profile:config_file" 65 }, 66 { 67 "name": "ohos.ability.window.height", 68 "value": "987" 69 }, 70 { 71 "name": "ohos.ability.window.width", 72 "value": "1300" 73 }, 74 { 75 "name": "ohos.ability.window.left", 76 "value": "right-50" 77 }, 78 { 79 "name": "ohos.ability.window.top", 80 "value": "center+50" 81 }, 82 { 83 "name": "ohos.ability.window.isMaximize", 84 "value": "true" 85 }, 86 { 87 "name": "enable.remove.starting.window", 88 "value": "true" 89 }], 90 }], 91 92 "extensionAbilities": [{ 93 "metadata": [{ 94 "name": "extensionAbility_metadata", 95 "value": "a test for extensionAbility", 96 "resource": "$profile:config_file" 97 }, 98 { 99 "name": "extensionAbility_metadata_2", 100 "value": "a string test", 101 "resource": "$profile:config_file" 102 }, 103 { 104 "name": "ohos.ability.window.SupportWindowModeInFreeWindow", 105 "value": "fullscreen,split,floating", 106 }], 107 }] 108 } 109} 110```