应用在有其它应用后台播放音乐时,如何正确选择音频流类型

zbw_apple
发布于 2024-12-13 11:12
浏览
0收藏

问题背景

有其他应用在后台播放音乐时,开发者需要根据应用场景指定音频流的​StreamUsage​如果配置了不正确的StreamUsage,可能带来一些不符合预期的行为。例如以下场景:

导航场景错误使用STREAM_USAGE_MUSIC类型,导航应用播报时候会导致正在播放的音乐停止播放,而导航场景通常期望正在播放的音乐仅仅降低音量播放。​

实现方案

​开发者需要了解音频流类型对音频焦点管理的影响,然后根据自身的业务场景和实际需求,为音频选择合适的流类型。

例如有其他应用在后台播放音乐时,可参考下表进行选择:​

应用需要播放的音频场景

打断效果

推荐流类型

闹钟

打断暂停

STREAM_USAGE_ALARM

VoIP来电响铃

STREAM_USAGE_RINGTONE

VoIP语音通话

STREAM_USAGE_VOICE_COMMUNICATION

语音短消息

STREAM_USAGE_VOICE_MESSAGE

音乐场景

打断停止

STREAM_USAGE_MUSIC

短视频、电影、电视剧

STREAM_USAGE_MOVIE

有声读物、听新闻、播客

STREAM_USAGE_AUDIOBOOK

导航

音量降低

STREAM_USAGE_NAVIGATION

通知音、提示音

STREAM_USAGE_NOTIFICATION

语音播报

STREAM_USAGE_VOICE_ASSISTANT

游戏

并发播放

STREAM_USAGE_GAME

使用SoundPool播放简短音效(点赞音、效果音等)

STREAM_USAGE_MUSIC

设置音频流类型

AudioRenderer(ArkTS)

在调用createAudioRenderer接口时,传入对应的StreamUsage。

let audioRendererInfo: audio.AudioRendererInfo = { 
  usage: audio.StreamUsage.STREAM_USAGE_VOICE_COMMUNICATION, 
  rendererFlags: 0 
}; 
let audioRendererOptions: audio.AudioRendererOptions = { 
  streamInfo: audioStreamInfo, 
  rendererInfo: audioRendererInfo 
}; 
audio.createAudioRenderer(audioRendererOptions, (err, data) => { 
})

注:AudioRendererOptions中包含AudioRendererInfo,AudioRendererInfo中包含StreamUsage参数。

OHAudio(C/C++)

​在调用OH_AudioStreamBuilder_SetRendererInfo接口时,传入对应的OH_AudioStream_Usage。

OH_AudioStreamBuilder_SetRendererInfo(builder, AUDIOSTREAM_USAGE_MUSIC)

AVPlayer(ArkTS)

​通过设置属性​audioRendererInfo​中的usage来设置音频播放流类型。

avPlayer.on('stateChange', async (state: string, reason: media.StateChangeReason) => { 
  switch (state) { 
    case 'initialized': // avplayer 设置播放源后触发该状态上报 
      console.info('AVPlayer state initialized called.'); 
      this.avPlayer.audioRendererInfo = { 
        usage: audio.StreamUsage.STREAM_USAGE_MUSIC, 
        rendererFlags: 0 
      } 
      avPlayer.prepare(); 
      break; 
  } 
})

注:在设置AVPlayer的audioRendererInfo属性时,只允许在initialized状态下设置。若应用没有主动设置该属性,AVPlayer会根据媒体源是否包含视频,使用Music或Movie作为usage的默认值。

AVPlayer(C/C++)

在调用​OH_AVPlayer_SetAudioRendererInfo​​接口时,传入对应的OH_AudioStream_Usage。

OH_AVPlayer_SetAudioRendererInfo(player, AUDIOSTREAM_USAGE_MUSIC)。

SoundPool(ArkTS)

​在调用​createSoundPool​接口时,传入对应的StreamUsage。

// audioRenderInfo中的参数usage取值为STREAM_USAGE_UNKNOWN,STREAM_USAGE_MUSIC,STREAM_USAGE_MOVIE,// STREAM_USAGE_AUDIOBOOK时,SoundPool播放短音时为混音模式,不会打断其他音频播放。 
let audioRendererInfo: audio.AudioRendererInfo = { 
  usage: audio.StreamUsage.STREAM_USAGE_MUSIC, 
  rendererFlags: 0 
} 
soundPool = await media.createSoundPool(5, audioRendererInfo);


分类
收藏
回复
举报
回复
    相关推荐