# @ohos.app.ability.abilityManager (AbilityManager) AbilityManager模块提供获取、新增、修改Ability相关信息和状态信息进行的能力。 > **说明:** > > 本模块首批接口从API version 9开始支持。后续版本的新增接口,采用上角标单独标记接口的起始版本。 > 本模块接口均为系统接口,三方应用不支持调用。 ## 导入模块 ```ts import abilityManager from '@ohos.app.ability.abilityManager'; ``` ## AbilityState Ability的状态,该类型为枚举,可配合[AbilityRunningInfo](js-apis-inner-application-abilityRunningInfo.md)返回Abiltiy的状态。 **系统能力**:以下各项对应的系统能力均为SystemCapability.Ability.AbilityRuntime.Core **系统API**: 此枚举类型为系统接口内部定义,三方应用不支持调用。 | 名称 | 值 | 说明 | | -------- | -------- | -------- | | INITIAL | 0 | 表示ability为初始化状态。| | FOCUS | 2 | 表示ability为获焦状态。 | | FOREGROUND | 9 | 表示ability为前台状态。 | | BACKGROUND | 10 | 表示ability为后台状态。 | | FOREGROUNDING | 11 | 表示ability为前台调度中状态。 | | BACKGROUNDING | 12 | 表示ability为后台调度中状态。 | ## updateConfiguration updateConfiguration(config: Configuration, callback: AsyncCallback\): void 通过传入修改的配置项来更新配置(callback形式)。 **需要权限**: ohos.permission.UPDATE_CONFIGURATION **系统能力**:以下各项对应的系统能力均为SystemCapability.Ability.AbilityRuntime.Core **参数**: | 参数名 | 类型 | 必填 | 说明 | | --------- | ---------------------------------------- | ---- | -------------- | | config | [Configuration](js-apis-app-ability-configuration.md) | 是 | 新的配置项,仅需配置需要更新的项。 | | callback | AsyncCallback\ | 是 | 以回调方式返回接口运行结果,可进行错误处理或其他自定义处理。 | **错误码**: | 错误码ID | 错误信息 | | ------- | -------- | | 16000050 | Internal error. | 以上错误码详细介绍请参考[errcode-ability](../errorcodes/errorcode-ability.md)。 **示例**: ```ts import abilityManager from '@ohos.app.ability.abilityManager'; const config = { language: 'Zh-Hans', // 简体中文 colorMode: COLOR_MODE_LIGHT, // 浅色模式 direction: DIRECTION_VERTICAL, // 垂直方向 screenDensity: SCREEN_DENSITY_SDPI, // 屏幕像素密度为'sdpi' displayId: 1, // 应用在Id为1的物理屏上显示 hasPointerDevice: true, // 指针类型设备已连接 }; try { abilityManager.updateConfiguration(config, (err) => { if (err && err.code !== 0) { console.error('updateConfiguration fail, err: ${JSON.stringify(err)}'); } else { console.log('updateConfiguration success.'); } }); } catch (paramError) { console.error('error.code: ${JSON.stringify(paramError.code)}, error.message: ${JSON.stringify(paramError.message)}'); } ``` ## updateConfiguration updateConfiguration(config: Configuration): Promise\ 通过修改配置来更新配置(Promise形式)。 **需要权限**: ohos.permission.UPDATE_CONFIGURATION **系统能力**:以下各项对应的系统能力均为SystemCapability.Ability.AbilityRuntime.Core **参数**: | 参数名 | 类型 | 必填 | 说明 | | --------- | ---------------------------------------- | ---- | -------------- | | config | [Configuration](js-apis-app-ability-configuration.md) | 是 | 新的配置项,仅需配置需要更新的项。 | **返回值:** | 类型 | 说明 | | ---------------------------------------- | ------- | | Promise\ | 以Promise方式返回接口运行结果息,可进行错误处理或其他自定义处理。 | **错误码**: | 错误码ID | 错误信息 | | ------- | -------- | | 16000050 | Internal error. | 以上错误码详细介绍请参考[errcode-ability](../errorcodes/errorcode-ability.md)。 **示例**: ```ts import abilityManager from '@ohos.app.ability.abilityManager'; const config = { language: 'Zh-Hans', // 简体中文 colorMode: COLOR_MODE_LIGHT, // 浅色模式 direction: DIRECTION_VERTICAL, // 垂直方向 screenDensity: SCREEN_DENSITY_SDPI, // 屏幕像素密度为'sdpi' displayId: 1, // 应用在Id为1的物理屏上显示 hasPointerDevice: true, // 指针类型设备已连接 }; try { abilityManager.updateConfiguration(config).then(() => { console.log('updateConfiguration success.'); }).catch((err) => { console.error('updateConfiguration fail, err: ${JSON.stringify(err)}'); }); } catch (paramError) { console.error('error.code: ${JSON.stringify(paramError.code)}, error.message: ${JSON.stringify(paramError.message)}'); } ``` ## getAbilityRunningInfos getAbilityRunningInfos(callback: AsyncCallback\>): void 获取UIAbility运行相关信息(callback形式)。 **需要权限**: ohos.permission.GET_RUNNING_INFO **系统能力**:以下各项对应的系统能力均为SystemCapability.Ability.AbilityRuntime.Core **参数**: | 参数名 | 类型 | 必填 | 说明 | | --------- | ---------------------------------------- | ---- | -------------- | | callback | AsyncCallback\> | 是 | 以回调方式返回接口运行结果及运行中的ability信息,可进行错误处理或其他自定义处理。 | **错误码**: | 错误码ID | 错误信息 | | ------- | -------- | | 16000050 | Internal error. | 以上错误码详细介绍请参考[errcode-ability](../errorcodes/errorcode-ability.md)。 **示例**: ```ts import abilityManager from '@ohos.app.ability.abilityManager'; try { abilityManager.getAbilityRunningInfos((err, data) => { if (err && err.code !== 0) { console.error('getAbilityRunningInfos fail, error: ${JSON.stringify(err)}'); } else { console.log('getAbilityRunningInfos success, data: ${JSON.stringify(data)}'); } }); } catch (paramError) { console.error('error.code: ${JSON.stringify(paramError.code)}, error.message: ${JSON.stringify(paramError.message)}'); } ``` ## getAbilityRunningInfos getAbilityRunningInfos(): Promise\> 获取UIAbility运行相关信息(Promise形式)。 **需要权限**: ohos.permission.GET_RUNNING_INFO **系统能力**:以下各项对应的系统能力均为SystemCapability.Ability.AbilityRuntime.Core **返回值:** | 类型 | 说明 | | ---------------------------------------- | ------- | | Promise\> | 以Promise方式返回接口运行结果及运行中的ability信息,可进行错误处理或其他自定义处理。 | **错误码**: | 错误码ID | 错误信息 | | ------- | -------- | | 16000050 | Internal error. | 以上错误码详细介绍请参考[errcode-ability](../errorcodes/errorcode-ability.md)。 **示例**: ```ts import abilityManager from '@ohos.app.ability.abilityManager'; try { abilityManager.getAbilityRunningInfos().then((data) => { console.log('getAbilityRunningInfos success, data: ${JSON.stringify(data)}'); }).catch((err) => { console.error('getAbilityRunningInfos fail, err: ${JSON.stringify(err)}'); }); } catch (paramError) { console.error('error.code: ${JSON.stringify(paramError.code)}, error.message: ${JSON.stringify(paramError.message)}'); } ``` ## getExtensionRunningInfos getExtensionRunningInfos(upperLimit: number, callback: AsyncCallback\>): void 获取关于运行扩展能力的信息(callback形式)。 **需要权限**: ohos.permission.GET_RUNNING_INFO **系统能力**:以下各项对应的系统能力均为SystemCapability.Ability.AbilityRuntime.Core **参数**: | 参数名 | 类型 | 必填 | 说明 | | --------- | ---------------------------------------- | ---- | -------------- | | upperLimit | number | 是 | 获取消息数量的最大限制,最大为231-1。 | | callback | AsyncCallback\> | 是 | 以回调方式返回接口运行结果及运行中的extension信息,可进行错误处理或其他自定义处理。 | **错误码**: | 错误码ID | 错误信息 | | ------- | -------- | | 16000050 | Internal error. | 以上错误码详细介绍请参考[errcode-ability](../errorcodes/errorcode-ability.md)。 **示例**: ```ts import abilityManager from '@ohos.app.ability.abilityManager'; let upperLimit = 10; try { abilityManager.getExtensionRunningInfos(upperLimit, (err, data) => { if (err && err.code !== 0) { console.error('getExtensionRunningInfos fail, err: ${JSON.stringify(err)}'); } else { console.log('getExtensionRunningInfos success, data: ${JSON.stringify(data)}'); } }); } catch (paramError) { console.error('error.code: ${JSON.stringify(paramError.code)}, error.message: ${JSON.stringify(paramError.message)}'); } ``` ## getExtensionRunningInfos getExtensionRunningInfos(upperLimit: number): Promise\> 获取关于运行扩展能力的信息(Promise形式)。 **需要权限**: ohos.permission.GET_RUNNING_INFO **系统能力**:以下各项对应的系统能力均为SystemCapability.Ability.AbilityRuntime.Core **参数**: | 参数名 | 类型 | 必填 | 说明 | | --------- | ---------------------------------------- | ---- | -------------- | | upperLimit | number | 是 | 获取消息数量的最大限制,最大为231-1。 | **返回值:** | 类型 | 说明 | | ---------------------------------------- | ------- | | Promise\> | 以Promise方式返回接口运行结果及运行中的extension信息,可进行错误处理或其他自定义处理。 | **错误码**: | 错误码ID | 错误信息 | | ------- | -------- | | 16000050 | Internal error. | 以上错误码详细介绍请参考[errcode-ability](../errorcodes/errorcode-ability.md)。 **示例**: ```ts import abilityManager from '@ohos.app.ability.abilityManager'; let upperLimit = 10; try { abilityManager.getExtensionRunningInfos(upperLimit).then((data) => { console.log('getExtensionRunningInfos success, data: ${JSON.stringify(data)}'); }).catch((err) => { console.error('getExtensionRunningInfos fail, err: ${JSON.stringify(err)}'); }); } catch (paramError) { console.error('error.code: ${JSON.stringify(paramError.code)}, error.message: ${JSON.stringify(paramError.message)}'); } ``` ## getTopAbility9+ getTopAbility(callback: AsyncCallback\): void; 获取窗口焦点的ability接口(callback形式)。 **系统能力**:以下各项对应的系统能力均为SystemCapability.Ability.AbilityRuntime.Core **参数**: | 参数名 | 类型 | 必填 | 说明 | | --------- | ---------------------------------------- | ---- | -------------- | | callback | AsyncCallback\<[ElementName](js-apis-bundleManager-elementName.md)> | 是 | 以回调方式返回接口运行结果及应用名,可进行错误处理或其他自定义处理。 | **错误码**: | 错误码ID | 错误信息 | | ------- | -------- | | 16000050 | Internal error. | 以上错误码详细介绍请参考[errcode-ability](../errorcodes/errorcode-ability.md)。 **示例**: ```ts import abilityManager from '@ohos.app.ability.abilityManager'; abilityManager.getTopAbility((err, data) => { if (err && err.code !== 0) { console.error('getTopAbility fail, err: ${JSON.stringify(err)}'); } else { console.log('getTopAbility success, data: ${JSON.stringify(data)}'); } }); ``` ## getTopAbility getTopAbility(): Promise\; 获取窗口焦点的ability接口(Promise形式)。 **系统能力**:以下各项对应的系统能力均为SystemCapability.Ability.AbilityRuntime.Core **返回值:** | 类型 | 说明 | | ---------------------------------------- | ------- | | Promise\<[ElementName](js-apis-bundleManager-elementName.md)>| 以Promise方式返回接口运行结果及应用名,可进行错误处理或其他自定义处理。 | **错误码**: | 错误码ID | 错误信息 | | ------- | -------- | | 16000050 | Internal error. | 以上错误码详细介绍请参考[errcode-ability](../errorcodes/errorcode-ability.md)。 **示例**: ```ts import abilityManager from '@ohos.app.ability.abilityManager'; abilityManager.getTopAbility().then((data) => { console.log('getTopAbility success, data: ${JSON.stringify(data)}'); }).catch((err) => { console.error('getTopAbility fail, err: ${JSON.stringify(err)}'); }); ```