跳到主要内容

配置应用启动页

启动页的分类和实现方式

启动页分为简易启动页和增强启动页,开发者通过在module.json5配置文件中的abilities标签配置启动页资源,涉及的对应字段及含义如下表所示。

字段类型是否可缺省含义
startWindowIconstring标识当前UIAbility组件简易启动页面图标资源文件的索引,取值为长度不超过255字节的字符串。 此图标资源会在启动页面上按实际大小居中显示。 当startWindow被配置时失效。
startWindowBackgroundstring标识当前UIAbility组件简易启动页面背景颜色资源文件的索引,取值为长度不超过255字节的字符串。 考虑到启动页在各种场景下的显示效果及系统动效的连续性,不建议采用透明色。 当startWindow被配置时失效。
startWindowstring标识当前UIAbility组件增强启动页面配置资源json文件的索引,取值为长度不超过255字节的字符串。 指向二级配置json文件,当应用需要配置增强启动页时,填写此字段,以提供更丰富的启动页资源配置项。 从API version 19开始,支持使用startWindow字段配置增强启动页。

配置简易启动页

简易启动页是每个UIAbility都必须配置的能力,开发者通过配置module.json5文件中的abilities标签的startWindowIcon和startWindowBackground字段,实现简易启动页的配置。

  • startWindowIcon用于展示应用图标,不会随窗口尺寸进行缩放。建议开发者避免设计针对单个产品全屏尺寸的startWindowIcon图标资源,防止在其他尺寸设备的显示效果无法自动适配。
  • 全屏资源的展示建议采用配置增强启动页

在创建的UIAbility模板中,简易启动页相关字段的默认配置如下:

"startWindowIcon": "$media:startIcon",
"startWindowBackground": "$color:start_window_background",

此时,默认启动页呈现示意图如下:

图1 默认启动页示意图

开发者可以根据应用需要,配置使用自定义设计的图标资源和颜色资源。

配置增强启动页

从API version 19开始,支持使用startWindow字段配置增强启动页。

startWindow字段提供了增强的启动页配置能力,可用于元素更复杂的启动页配置。同时,相应资源也具备根据窗口尺寸进行缩放的能力,更易于多设备适配设计,更有利于“一次开发,多端部署”。

  • 由于应用进程创建包括启动页图片资源的解码,使用适当分辨率的图片是影响应用启动时延体验的关键。若对启动时延体验有较高要求,建议启动页中使用不超过256*256分辨率的图片资源。
  • 启动页中的图片资源支持的文件格式同Image组件,考虑到解码性能和显示效果,建议启动页中使用jpg或png格式的图片资源。
  1. 在创建的UIAbility模板中,开发者可以新增startWindow字段指向二级配置json文件,以启用启动页增强配置。

    其中,json文件需要由开发者自行创建并放置到工程目录下。推荐的文件名及路径为resources/base/profile/start_window.json,此时需在module.json5的abilities标签中配置如下:

    "startWindow": "$profile:start_window",
  2. 配置二级json文件的具体字段。启动页资源主要在上、下两个区域进行展示,如果对应区域的资源未配置,则留空,其他区域的位置和尺寸不受影响。

    具体可配置字段、各字段含义及增强启动页示意图请见下文。

    字段类型是否可缺省含义
    startWindowTypestring标识当前UIAbility组件是否隐藏启动页。 当前仅支持在2in1设备或平板设备的自由多窗模式下使用。 不同取值含义如下: - "REQUIRED_SHOW":强制显示启动页。不受Ability管理服务(即StartOptions中hideStartWindow字段)的影响。 - "REQUIRED_HIDE":强制隐藏启动页。不受Ability管理服务(即StartOptions中hideStartWindow字段)的影响。 - "OPTIONAL_SHOW":可选显示,默认行为为显示启动页,如果Ability管理服务(即StartOptions中hideStartWindow字段)设置隐藏启动页,则隐藏启动页。 - 如未配置该字段,默认取值为"REQUIRED_SHOW",即强制显示启动页。 从API version 20开始支持该字段。
    startWindowAppIconstring标识当前UIAbility组件增强启动页面图标资源文件的索引,取值为长度不超过255字节的字符串。 在窗口上部分展示,资源由系统侧进行缩放,使其完全显示在展示区域内,宽高比保持不变。 图标资源展示区域的尺寸由系统侧根据窗口尺寸选取,取值为128vp*128vp、192vp*192vp或256vp*256vp。 与插画资源startWindowIllustration同时配置时,仅展示图标资源。 从API version 19开始支持该字段。
    startWindowIllustrationstring标识当前UIAbility组件增强启动页面插画资源文件的索引,取值为长度不超过255字节的字符串。 在窗口上部分展示,如资源尺寸超出其展示区域,将由系统侧保持宽高比缩小,使得资源完全显示在其展示区域内;否则其尺寸保持不变。 插画资源展示区域宽高比为1。 与图标资源startWindowAppIcon同时配置时,仅展示图标资源。 从API version 19开始支持该字段。
    startWindowBrandingImagestring标识当前UIAbility组件增强启动页面品牌标识资源文件的索引,取值为长度不超过255字节的字符串。 在窗口下部分展示,如资源尺寸超出其展示区域,将由系统侧保持宽高比缩小,使得资源完全显示在其展示区域内;否则其尺寸保持不变。 如果窗口高度不足300vp,此资源将被隐藏。 从API version 19开始支持该字段。
    startWindowBackgroundColorstring标识当前UIAbility组件增强启动背景色资源文件的索引,取值为长度不超过255字节的字符串。 背景色填充整个窗口,显示层级最低,不建议采用透明色。 如未配置该字段,则启动页增强配置文件不生效,采用简易启动页配置。 从API version 19开始支持该字段。
    startWindowBackgroundImagestring标识当前UIAbility组件增强启动背景图片资源文件的索引,取值为长度不超过255字节的字符串。 以整个窗口为容器,填充方式由startWindowBackgroundImageFit字段指定。 从API version 19开始支持该字段。
    startWindowBackgroundImageFitstring标识当前UIAbility组件增强启动背景图片的填充方式,当前支持取值为: - "Contain":保持宽高比进行缩小或者放大,使得图片完全显示在显示边界内。 - "Cover":保持宽高比进行缩小或者放大,使得图片两边都大于或等于显示边界。 - "Auto":图像会根据其自身尺寸和组件的尺寸进行适当缩放,以在保持比例的同时填充视图。 - "Fill":不保持宽高比进行放大缩小,使得图片充满显示边界。 - "ScaleDown":保持宽高比显示,图片缩小或者保持不变。 - "None":保持原有尺寸显示。 如未配置该字段,默认采用Cover填充方式。 从API version 19开始支持该字段。
    startWindowColorModeTypestring标识当前UIAbility组件启动页深浅色模式,仅作用于同进程间拉起场景。 不同取值含义如下: - "FOLLOW_SYSTEM":启动页颜色模式跟随系统深浅色。 - "FOLLOW_APPLICATION":启动页颜色模式跟随应用深浅色。 - 如未配置该字段,默认取值为"FOLLOW_SYSTEM",即启动页颜色模式跟随系统深浅色。 从API version 20开始支持该字段。

图2 增强启动页示意图

示例如下:

{
"startWindowType": "REQUIRED_SHOW",
"startWindowColorModeType": "FOLLOW_SYSTEM",
"startWindowAppIcon": "$media:icon",
"startWindowIllustration": "$media:illustration",
"startWindowBrandingImage": "$media:brand",
"startWindowBackgroundColor": "$color:start_window_background",
"startWindowBackgroundImage": "$media:bgImage",
"startWindowBackgroundImageFit": "Contain"
}