跳到主要内容

音频会话管理

对于涉及多个音频流并发的场景,系统已预设了默认的音频焦点策略,该策略将对所有音频流(包括播放和录制)实施统一的焦点管理。

当系统提供的默认焦点策略不能满足应用需求时,应用可利用音频会话管理提供的接口,管理应用内音频流的焦点,自定义音频流的焦点策略,调整音频流释放焦点的时机,以满足特定需求。该篇文章的示例代码均为ArkTS,如果需要使用OHAudio开发请参考使用OHAudio开发音频会话功能(C/C++)

使用音频会话相关接口,可以实现以下功能:

  • 系统默认焦点策略不能满足应用当前需求,应用可使用音频会话修改焦点策略来适配适合自己的焦点策略。

    典型场景:应用播放短视频时,会打断后台音乐,应用希望自身的音频流停止后,后台的音乐可以自动恢复(该场景需要应用在音频流启动前激活音频会话,音频流停止后停用音频会话)。

  • 当应用在某个业务流程中需要启动多个音频流,且要保证整个流程的完整性时,应用可使用音频会话申请焦点策略来适配适合自己业务场景的焦点策略。

    典型场景:应用连续播放多个音频时,在多个音频衔接的间隙,不希望后台被影响的其他音频自动恢复,希望整个播放过程保持音频焦点的连贯性(该场景需要应用在整个播放过程开始前激活音频会话,整个播放过程结束后停用音频会话)。

  • 音频并发策略优先级为:STOP > PAUSE > DUCK > PLAYBOTH。当指定的音频会话策略优先级高于默认并发策略时,指定的音频会话策略不会生效。
  • 应用在开始音频播放或录制之前需要确保音频会话已经处于激活状态,否则音频会话的自定义焦点策略不会生效。若应用使用了异步接口,则需要格外注意异步操作执行的时序。

获取音频会话管理器

在使用AudioSessionManager的API前,需要先通过getSessionManager获取一个单例AudioSessionManager对象。

使用OHAudio开发请参考:获取音频会话管理器

import { audio } from '@kit.AudioKit';
// ...

let audioManager = audio.getAudioManager();
// 创建音频会话管理器。
let audioSessionManager: audio.AudioSessionManager = audioManager.getSessionManager();

音频会话策略

应用在激活AudioSession时,需先指定音频会话策略(AudioSessionStrategy)。可通过设置音频并发模式(AudioConcurrencyMode)来指定不同的音频会话策略。

使用OHAudio开发请参考:音频会话策略(OH_AudioSession_Strategy)

系统预设的音频并发模式如下所示:

  • 默认模式(CONCURRENCY_DEFAULT):即系统默认的音频焦点策略

  • 并发模式(CONCURRENCY_MIX_WITH_OTHERS):和其他音频流并发。

    典型场景:

    • 应用播放音乐时,会被后起的音乐或视频打断,应用希望自身的音频流和后起的音乐或视频并发(该场景需要应用在音频流启动前激活AudioSession)。
    • 应用录音时,会打断后台正在播放的音乐或视频,应用希望自身的音频流和后台正在播放的音乐或视频并发(该场景需要应用在音频流启动前激活AudioSession)。
  • 降低音量模式(CONCURRENCY_DUCK_OTHERS):和其他音频流并发,并且降低其他音频流的音量。

    典型场景: 应用播放游戏音效时,会和后台正在播放的音乐并发,应用希望自身的音频流和后台正在播放的音乐并发时压低后台音乐音量(该场景需要应用在音频流启动前激活AudioSession)。

  • 暂停模式(CONCURRENCY_PAUSE_OTHERS):暂停其他音频流,待释放焦点后通知其他音频流恢复。

    典型场景: 应用播放短视频时,会打断后台正在播放的音乐,应用希望自身的音频流停止后,后台的音乐可以自动恢复(该场景需要应用在音频流启动前激活AudioSession,音频流停止后停用AudioSession)。

  • 当应用通过AudioSession使用上述各种模式时,系统将尽量满足其焦点策略,但可能无法保证在所有场景下完全满足。
  • 并发模式(CONCURRENCY_MIX_WITH_OTHERS)在本应用申请焦点和后续其他应用申请焦点时均会生效;降低音量模式(CONCURRENCY_DUCK_OTHERS)和暂停模式(CONCURRENCY_PAUSE_OTHERS)仅在本应用申请焦点时生效,后续其他应用申请焦点时,优先遵循其他应用的并发模式。

使用音频会话修改焦点策略

系统默认焦点策略不能满足应用当前需求时,应用可通过指定音频会话策略后激活AudioSession来完成焦点策略修改。

AudioSession激活成功后,应用新起的音频流将会按照修改后的焦点策略起流。

使用AudioSession修改焦点策略时,AudioSession不会持有焦点,焦点仍由各个音频流持有。

使用OHAudio开发请参考:使用OHAudio开发音频会话功能(C/C++)

当AudioSession因超时而停用时,被其压低音量(Duck)的音频会触发恢复音量(Unduck)操作,被其暂停(Pause)的音频流会触发停止(Stop)操作。

AudioSession停用事件

应用在使用AudioSession的过程中,推荐应用监听音频会话停用事件(AudioSessionDeactivatedEvent)。当AudioSession被停用(非主动停用)时,应用会收到此事件通知。应用可根据自身业务需求,做相应的处理,例如释放相应资源、重新激活AudioSession等。

音频会话停用事件(AudioSessionDeactivatedEvent)包含AudioSessionDeactivatedReason参数,用于标识会话停用的具体原因(如焦点被抢占或超时)。

  1. 应用焦点被抢占(DEACTIVATED_LOWER_PRIORITY):该应用所有的音频流持有的焦点全部被其他应用抢占时,AudioSession被同时停用。
  2. 超时(DEACTIVATED_TIMEOUT):若AudioSession处于激活状态,但该应用没有音频流在运行状态,则AudioSession会在规定时间后被超时停用。

开发步骤

  1. 指定音频会话策略(AudioSessionStrategy)并激活音频会话。

    应用可以通过activateAudioSession接口激活当前应用的音频会话。

    应用在激活AudioSession时,需指定音频会话策略。策略中包含参数concurrencyMode,其类型为AudioConcurrencyMode,用于声明音频并发策略。

    import { audio } from '@kit.AudioKit';
    import { BusinessError } from '@kit.BasicServicesKit';
    // ...

    // 设置音频并发模式。
    let strategy: audio.AudioSessionStrategy = {
    concurrencyMode: audio.AudioConcurrencyMode.CONCURRENCY_MIX_WITH_OTHERS
    };

    // 激活音频会话。
    audioSessionManager.activateAudioSession(strategy).then(() => {
    console.info('Succeeded in activating audio session.');
    // ...
    }).catch((err: BusinessError) => {
    console.error(`Failed to activate audio session. Code: ${err.code}, message: ${err.message}`);
    // ...
    });
  2. 查询音频会话是否已激活(可选)。

    应用可以通过isAudioSessionActivated接口检查当前应用的音频会话是否已激活。

    // 查询音频会话是否已激活。
    let isActivated = audioSessionManager.isAudioSessionActivated();
  3. 监听音频会话停用事件(可选)。

    应用可以通过on('audioSessionDeactivated')接口监听音频会话停用事件(AudioSessionDeactivatedEvent)

    当AudioSession被停用(非主动停用)时,应用会收到音频会话停用事件(AudioSessionDeactivatedEvent),其中包含音频会话停用原因(AudioSessionDeactivatedReason)

    在收到AudioSessionDeactivatedEvent时,应用可根据自身业务需求,做相应的处理,例如释放相应资源、重新激活AudioSession等。

    应用可以通过off('audioSessionDeactivated')接口取消监听音频会话停用事件。

    import { audio } from '@kit.AudioKit';
    // ...

    // 监听音频会话停用事件。
    audioSessionManager.on('audioSessionDeactivated', (audioSessionDeactivatedEvent: audio.AudioSessionDeactivatedEvent) => {
    // ...
    console.info(`Succeeded in using on function. AudioSessionDeactivatedEvent: ${JSON.stringify(audioSessionDeactivatedEvent)}`);
    });
  4. 停用音频会话。

    应用可以通过deactivateAudioSession接口停用当前应用的音频会话。

    AudioSession停用后,应用新起的音频流将会按照默认焦点策略起流。

    import { BusinessError } from '@kit.BasicServicesKit';
    // ...

    // 停用音频会话。
    // ...
    audioSessionManager.deactivateAudioSession().then(() => {
    console.info('Succeeded in deactivating audio session.');
    // ...
    }).catch((err: BusinessError) => {
    console.error(`Failed to deactivate audio session. Code: ${err.code}, message: ${err.message}`);
    // ...
    });

完整示例

下面展示了使用AudioSession修改焦点策略的示例代码。

import { audio } from '@kit.AudioKit';
import { BusinessError } from '@kit.BasicServicesKit';
// ...

let audioManager = audio.getAudioManager();
// 创建音频会话管理器。
let audioSessionManager: audio.AudioSessionManager = audioManager.getSessionManager();
// ...
// 设置音频并发模式。
let strategy: audio.AudioSessionStrategy = {
concurrencyMode: audio.AudioConcurrencyMode.CONCURRENCY_MIX_WITH_OTHERS
};

// 激活音频会话。
audioSessionManager.activateAudioSession(strategy).then(() => {
console.info('Succeeded in activating audio session.');
// ...
}).catch((err: BusinessError) => {
console.error(`Failed to activate audio session. Code: ${err.code}, message: ${err.message}`);
// ...
});

// 查询音频会话是否已激活。
let isActivated = audioSessionManager.isAudioSessionActivated();

// 监听音频会话停用事件。
audioSessionManager.on('audioSessionDeactivated', (audioSessionDeactivatedEvent: audio.AudioSessionDeactivatedEvent) => {
// ...
console.info(`Succeeded in using on function. AudioSessionDeactivatedEvent: ${JSON.stringify(audioSessionDeactivatedEvent)}`);
});

if (isActivated) {
// 音频会话激活后,应用在此处正常执行音频播放、暂停、停止、释放等操作即可。
}
// ...

// 取消监听音频会话停用事件。
audioSessionManager.off('audioSessionDeactivated');

// ...
// 停用音频会话。
// ...
audioSessionManager.deactivateAudioSession().then(() => {
console.info('Succeeded in deactivating audio session.');
// ...
}).catch((err: BusinessError) => {
console.error(`Failed to deactivate audio session. Code: ${err.code}, message: ${err.message}`);
// ...
});

使用音频会话申请焦点策略

当应用需要启动多个音频流并保证流程连续性时,可通过AudioSession申请焦点,确保多音频流播放的连续性。

激活AudioSession时系统会根据应用选择的音频会话场景申请对应的音频焦点并由AudioSession持有该焦点,后续应用通过AudioRenderer启动的播放流将不再申请音频焦点。

使用OHAudio开发请参考:使用OHAudio开发音频会话功能(C/C++)

典型使用场景如下:

  • 在多个小视频滑动播放时,多个音频流频繁申请和释放焦点可能导致漏音。使用AudioSession申请一次焦点,可以避免中间多个音频流播放时频繁申请和释放焦点,从而防止漏音。
  • 在VoIP通话场景下,可能需要启动铃声流、录音流和播放流,这些音频流的焦点优先级不同,部分音频流可能被其他应用的音频流中断。为了保持业务体验的连续性,可以使用AudioSession申请焦点,避免音频流被中断。
  • 应用使用播放器的SDK播放音频流,不持有AudioRenderer对象,但希望监听焦点变化。

  • AudioSession申请的焦点是应用级别的,如果应用内部包含不同的模块,各个模块间要做好协调处理,避免其中一个模块使用AudioSession申请了焦点,另一个模块的音频流被AudioSession的焦点管控而产生非预期的效果。
  • 通过AudioSession申请焦点,仅对播放流有效,对录音流及部分播放音频流(如STREAM_USAGE_ALARM、STREAM_USAGE_NOTIFICATION、STREAM_USAGE_ACCESSIBILITY等)无效。
  • 在AudioSession激活过程中,如果动态修改AudioSessionScene,需要重新调用activateAudioSession才能生效。
  • 通过AudioSession申请焦点后,焦点由AudioSession持有。应用当前播放场景结束后,需要主动停用AudioSession才会释放焦点。避免出现播放流停止后,焦点未释放导致的焦点异常持有。

音频会话场景

使用AudioSession申请焦点策略时,系统提供了三种音频会话场景。激活AudioSession前需要先通过setAudioSessionScene设置对应的音频会话场景,后续AudioSession激活时系统会根据应用选择的音频会话场景申请对应的音频焦点。

名称说明
AUDIO_SESSION_SCENE_MEDIA0媒体音频会话场景。
AUDIO_SESSION_SCENE_GAME1游戏音频会话场景。
AUDIO_SESSION_SCENE_VOICE_COMMUNICATION2VoIP语音通话音频会话场景。

监听AudioSession焦点和状态变化事件

AudioSession申请的焦点和AudioRenderer申请的焦点是同等地位。

应用可以通过on('audioSessionStateChanged')来监听AudioSession的焦点和状态变化。为了维持应用和系统的状态一致性,确保良好的用户体验,应用应监听AudioSession焦点状态事件,并在焦点变化时做出必要响应。

on('audioSessionStateChanged')包含了AudioSession停用事件的信息,当使用音频会话申请焦点策略时无需再额外监听音频会话停用事件(AudioSessionDeactivatedEvent)。

如果应用同时注册了AudioRenderer的焦点事件监听,需要注意以下两点:

  1. 应用会收到AudioSession焦点状态变化和AudioRenderer焦点变化的回调(InterruptEvent),根据需要处理这些回调即可。
  2. 如果AudioSession的焦点被暂停,恢复暂停状态时,只会给AudioSession发送焦点恢复事件,不会再给AudioRenderer发送焦点恢复事件。收到恢复事件后,当应用需要通过AudioSession申请焦点恢复播放时,必须重新调用setAudioSessionScene设置场景参数,再调用activateAudioSession激活AudioSession。

开发步骤

  1. 指定音频会话场景(AudioSessionScene)和策略(AudioSessionStrategy)并激活音频会话。

    应用通过AudioSession申请焦点。首先要调用接口setAudioSessionScene设置场景参数,然后调用activateAudioSession接口激活AudioSession。激活AudioSession时系统会根据应用选择的音频会话场景申请对应的音频焦点。

    • 激活AudioSession时系统会根据应用选择的音频会话场景申请对应的音频焦点,后续应用通过AudioRenderer启动的播放流不再申请音频焦点。
    • 如果激活AudioSession时应用已存在启动的音频播放流,系统会释放该音频播放流持有的焦点,并由AudioSession统一管理。
    import { audio } from '@kit.AudioKit';
    import { BusinessError } from '@kit.BasicServicesKit';
    // ...

    // 应用根据业务场景设置适合自己的音频会话场景,激活AudioSession时,系统会根据应用选择的音频会话场景申请对应的音频焦点。
    audioSessionManager.setAudioSessionScene(audio.AudioSessionScene.AUDIO_SESSION_SCENE_MEDIA);
    // ...

    // 设置音频会话策略。
    let strategy: audio.AudioSessionStrategy = {
    concurrencyMode: audio.AudioConcurrencyMode.CONCURRENCY_MIX_WITH_OTHERS
    };

    // 激活AudioSession。
    audioSessionManager.activateAudioSession(strategy).then(() => {
    console.info('Succeeded in activating audio session.');
    // ...
    }).catch((err: BusinessError) => {
    console.error(`Failed to activate audio session. Code: ${err.code}, message: ${err.message}`);
    // ...
    });
  2. 查询音频会话是否已激活(可选)。

    应用可以通过isAudioSessionActivated接口检查当前应用的音频会话是否已激活。

    // 查询音频会话是否已激活。
    let isActivated = audioSessionManager.isAudioSessionActivated();
  3. 监听AudioSession焦点状态变化事件。

    应用可以通过on('audioSessionStateChanged')来监听AudioSession的焦点和状态变化。

    import { audio } from '@kit.AudioKit';
    import { BusinessError } from '@kit.BasicServicesKit';
    // ...

    // 监听AudioSession焦点和状态变化事件。
    let audioSessionStateChangedCallback = (audioSessionStateChangedEvent: audio.AudioSessionStateChangedEvent) => {
    // ...
    console.info(`hint of audioSessionStateChanged: ${audioSessionStateChangedEvent.stateChangeHint} `);

    switch (audioSessionStateChangedEvent.stateChangeHint) {
    case audio.AudioSessionStateChangeHint.AUDIO_SESSION_STATE_CHANGE_HINT_PAUSE:
    // 此分支表示系统已将音频流暂停,应用需切换至音频暂停状态。
    // 临时失去焦点:AudioSession会停用并释放焦点,同时停止应用所有音频流的播放。因此,当应用收到Resume回调后,需要重新激活AudioSession并恢复需要继续播放的音频流。
    break;
    case audio.AudioSessionStateChangeHint.AUDIO_SESSION_STATE_CHANGE_HINT_RESUME:
    // 此分支表示系统解除AudioSession焦点的暂停操作。
    break;
    case audio.AudioSessionStateChangeHint.AUDIO_SESSION_STATE_CHANGE_HINT_STOP:
    // 此分支表示系统已将音频流停止(永久失去焦点),为保持状态一致,应用需切换至音频暂停状态。
    // 永久失去焦点:AudioSession会停用并释放焦点,同时停止应用所有音频流的播放。后续不会再收到音频焦点事件,恢复播放需用户主动触发。
    break;
    case audio.AudioSessionStateChangeHint.AUDIO_SESSION_STATE_CHANGE_HINT_TIME_OUT_STOP:
    // 此分支表示由于长时间无音频流播放,系统已将AudioSession停止(永久失去焦点),应用需切换至音频停止状态。
    // 永久失去焦点:后续不会再收到音频焦点事件,恢复播放需用户主动触发。
    break;
    case audio.AudioSessionStateChangeHint.AUDIO_SESSION_STATE_CHANGE_HINT_DUCK:
    // 此分支表示系统已将应用所有播放音频流音量降低(默认降到正常音量的20%)。
    break;
    case audio.AudioSessionStateChangeHint.AUDIO_SESSION_STATE_CHANGE_HINT_UNDUCK:
    // 此分支表示系统已将应用所有播放音频流音量恢复正常。
    case audio.AudioSessionStateChangeHint.AUDIO_SESSION_STATE_CHANGE_HINT_MUTE_SUGGESTION:
    // 此分支表示其他应用开始播放非混音音频,系统可自行决定是否静音。
    break;
    case audio.AudioSessionStateChangeHint.AUDIO_SESSION_STATE_CHANGE_HINT_UNMUTE_SUGGESTION:
    // 此分支表示其他应用的非混音音频播放结束,系统可自行决定是否取消静音。
    break;
    default:
    break;
    }
    };

    audioSessionManager.on('audioSessionStateChanged', audioSessionStateChangedCallback);
  4. 停用音频会话。

    应用可以通过deactivateAudioSession接口停用当前应用的音频会话。

    停用AudioSession时系统会释放AudioSession申请的焦点,并停用该应用正在播放的所有音频流。

    import { BusinessError } from '@kit.BasicServicesKit';
    // ...

    // 停用AudioSession,即释放焦点并停用该应用正在播放的所有音频流。
    audioSessionManager.deactivateAudioSession().then(() => {
    console.info('Succeeded in deactivating audio session.');
    // ...
    }).catch((err: BusinessError) => {
    console.error(`Failed to deactivate audio session. Code: ${err.code}, message: ${err.message}`);
    // ...
    });

完整示例

下面展示了使用AudioSession申请焦点策略的示例代码。

import { audio } from '@kit.AudioKit';
import { BusinessError } from '@kit.BasicServicesKit';
// ...

// 应用根据业务场景设置适合自己的音频会话场景,激活AudioSession时,系统会根据应用选择的音频会话场景申请对应的音频焦点。
audioSessionManager.setAudioSessionScene(audio.AudioSessionScene.AUDIO_SESSION_SCENE_MEDIA);
// ...

// 设置音频会话策略。
let strategy: audio.AudioSessionStrategy = {
concurrencyMode: audio.AudioConcurrencyMode.CONCURRENCY_MIX_WITH_OTHERS
};

// 激活AudioSession。
audioSessionManager.activateAudioSession(strategy).then(() => {
console.info('Succeeded in activating audio session.');
// ...
}).catch((err: BusinessError) => {
console.error(`Failed to activate audio session. Code: ${err.code}, message: ${err.message}`);
// ...
});

// 监听AudioSession焦点和状态变化事件。
let audioSessionStateChangedCallback = (audioSessionStateChangedEvent: audio.AudioSessionStateChangedEvent) => {
// ...
console.info(`hint of audioSessionStateChanged: ${audioSessionStateChangedEvent.stateChangeHint} `);

switch (audioSessionStateChangedEvent.stateChangeHint) {
case audio.AudioSessionStateChangeHint.AUDIO_SESSION_STATE_CHANGE_HINT_PAUSE:
// 此分支表示系统已将音频流暂停,应用需切换至音频暂停状态。
// 临时失去焦点:AudioSession会停用并释放焦点,同时停止应用所有音频流的播放。因此,当应用收到Resume回调后,需要重新激活AudioSession并恢复需要继续播放的音频流。
break;
case audio.AudioSessionStateChangeHint.AUDIO_SESSION_STATE_CHANGE_HINT_RESUME:
// 此分支表示系统解除AudioSession焦点的暂停操作。
break;
case audio.AudioSessionStateChangeHint.AUDIO_SESSION_STATE_CHANGE_HINT_STOP:
// 此分支表示系统已将音频流停止(永久失去焦点),为保持状态一致,应用需切换至音频暂停状态。
// 永久失去焦点:AudioSession会停用并释放焦点,同时停止应用所有音频流的播放。后续不会再收到音频焦点事件,恢复播放需用户主动触发。
break;
case audio.AudioSessionStateChangeHint.AUDIO_SESSION_STATE_CHANGE_HINT_TIME_OUT_STOP:
// 此分支表示由于长时间无音频流播放,系统已将AudioSession停止(永久失去焦点),应用需切换至音频停止状态。
// 永久失去焦点:后续不会再收到音频焦点事件,恢复播放需用户主动触发。
break;
case audio.AudioSessionStateChangeHint.AUDIO_SESSION_STATE_CHANGE_HINT_DUCK:
// 此分支表示系统已将应用所有播放音频流音量降低(默认降到正常音量的20%)。
break;
case audio.AudioSessionStateChangeHint.AUDIO_SESSION_STATE_CHANGE_HINT_UNDUCK:
// 此分支表示系统已将应用所有播放音频流音量恢复正常。
case audio.AudioSessionStateChangeHint.AUDIO_SESSION_STATE_CHANGE_HINT_MUTE_SUGGESTION:
// 此分支表示其他应用开始播放非混音音频,系统可自行决定是否静音。
break;
case audio.AudioSessionStateChangeHint.AUDIO_SESSION_STATE_CHANGE_HINT_UNMUTE_SUGGESTION:
// 此分支表示其他应用的非混音音频播放结束,系统可自行决定是否取消静音。
break;
default:
break;
}
};

audioSessionManager.on('audioSessionStateChanged', audioSessionStateChangedCallback);

// 查询音频会话是否已激活。
let isActivated = audioSessionManager.isAudioSessionActivated();

if (isActivated) {
// 音频会话激活后,应用在此处正常执行音频播放、暂停、停止、释放等操作即可。
// 根据实际业务,应用可以启动多个AudioRenderer音频播放流。此处启动的音频播放流不再持有焦点,统一由AudioSession管理。
// 如果存在多条音频流同时播放,需要特别注意AudioSession停用时机(停用AudioSession时会同时释放应用所有音频播放流)。
}
// ...

// 业务结束,取消监听AudioSession焦点和状态变化事件。
audioSessionManager.off('audioSessionStateChanged');
// ...

// 停用AudioSession,即释放焦点并停用该应用正在播放的所有音频流。
audioSessionManager.deactivateAudioSession().then(() => {
console.info('Succeeded in deactivating audio session.');
// ...
}).catch((err: BusinessError) => {
console.error(`Failed to deactivate audio session. Code: ${err.code}, message: ${err.message}`);
// ...
});

启用混音播放下静音建议通知

从API version 23开始,当本应用在并发模式为CONCURRENCY_MIX_WITH_OTHERS下进行播放时,如果有其他应用的音频同时播放,此时两者会混合播放。部分场景下(如游戏或广播),应用可以通过启用静音建议通知,以给用户提供更好的体验。

启用静音建议通知后,本应用播放音频的同时,其他应用播放了不可与本应用并发播放的音频,本应用会收到静音建议通知,此时本应用可以选择不做处理,让本应用和其他应用进行并发播放;也可以选择将自身静音播放,让其他应用单独播放音频。

启用混音播放下静音建议通知,需要先调用接口setAudioSessionScene设置场景参数并订阅音频会话状态更改事件AudioSessionStateChangedEvent,启用后再调用activateAudioSession接口激活AudioSession。启用静音建议通知的前提是AudioConcurrencyMode模式必须为CONCURRENCY_MIX_WITH_OTHERS。

import { audio } from '@kit.AudioKit';
import { BusinessError } from '@kit.BasicServicesKit';
// ...

// 应用根据业务场景设置适合自己的音频会话场景,激活AudioSession时,系统会根据应用选择的音频会话场景申请对应的音频焦点。
audioSessionManager.setAudioSessionScene(audio.AudioSessionScene.AUDIO_SESSION_SCENE_MEDIA);

// 本接口必须在激活音频会话前调用才会生效。
audioSessionManager.enableMuteSuggestionWhenMixWithOthers(true);

// 设置音频会话策略。
let strategy: audio.AudioSessionStrategy = {
concurrencyMode: audio.AudioConcurrencyMode.CONCURRENCY_MIX_WITH_OTHERS
};

// 激活AudioSession。
audioSessionManager.activateAudioSession(strategy).then(() => {
console.info('Succeeded in activating audio session.');
// ...
}).catch((err: BusinessError) => {
console.error(`Failed to activate audio session. Code: ${err.code}, message: ${err.message}`);
// ...
});