音频属性

音频播放器支持定义音频系统如何处理指定来源的导向、音量和焦点决策的属性。应用可以将属性附加到音频播放(例如流式传输服务播放的音乐或新电子邮件通知)上,然后将音频源的属性传递给框架,此时音频系统会使用这些属性做出混音决策并将系统状态通知给应用。

注意:应用还可以将属性附加到音频录制(例如在视频录制中截取的音频)上,但此功能不会在公共 API 中提供。

在 Android 4.4 及更早版本中,框架仅使用音频流类型做出混音决策。但是,基于流类型做出这些决策太过于限制,无法在多个应用和设备上产生优质输出。例如,在移动设备上,某些应用(例如 Google 地图)基于 STREAM_MUSIC 流类型播放驾驶方向;但是,在采用投影仪模式(例如 Android Auto)的移动设备上,应用不能将驾驶方向与其他媒体流混合在一起播放。

现在,应用可以使用音频属性 API 为音频系统提供有关特定音频源的详细信息:

  • 用法。指定播放来源的原因,并控制导向、焦点和音量决策。
  • 内容类型。指定播放来源的类型(音乐、电影、语音、发音、未知)。
  • 标记。指定来源的播放方式。包括对可听性强制执行(一些国家/地区要求发出相机快门提示音)和硬件音频/视频同步的支持。

对于动态处理,应用必须区分电影、音乐和语音内容。关于数据本身的信息也可能非常重要,例如响度和峰值采样值。

使用属性

用法指定了在何种环境中使用相关流类型,并提供有关播放相关声音的原因以及该声音用法的信息。用法信息比流类型信息更丰富,并且使平台或导向策略可以优化音量或导向决策。

为任何实例提供以下用法值之一:

  • USAGE_UNKNOWN
  • USAGE_MEDIA
  • USAGE_VOICE_COMMUNICATION
  • USAGE_VOICE_COMMUNICATION_SIGNALLING
  • USAGE_ALARM
  • USAGE_NOTIFICATION
  • USAGE_NOTIFICATION_RINGTONE
  • USAGE_NOTIFICATION_COMMUNICATION_INSTANT
  • USAGE_NOTIFICATION_COMMUNICATION_DELAYED
  • USAGE_NOTIFICATION_EVENT
  • USAGE_ASSISTANCE_ACCESSIBILITY
  • USAGE_ASSISTANCE_NAVIGATION_GUIDANCE
  • USAGE_ASSISTANCE_SONIFICATION
  • USAGE_GAME

音频属性用法值是互斥的。有关示例,请参阅 USAGE_MEDIA USAGE_ALARM 定义;有关异常,请参阅 AudioAttributes.Builder 定义。

内容类型

内容类型定义了声音是什么,并指明内容的常规类别,如电影、语音或提示音/铃声。音频框架使用内容类型信息来选择性地配置音频处理后块。尽管提供内容类型是可选的,但只要内容类型已知,您就应该包含类型信息,例如针对电影流式传输服务使用 CONTENT_TYPE_MOVIE,或针对音乐播放应用使用 CONTENT_TYPE_MUSIC

为任何实例提供以下内容类型值之一:

  • CONTENT_TYPE_UNKNOWN(默认)
  • CONTENT_TYPE_MOVIE
  • CONTENT_TYPE_MUSIC
  • CONTENT_TYPE_SONIFICATION
  • CONTENT_TYPE_SPEECH

音频属性内容类型值是互斥的。有关内容类型的详细信息,请参阅音频属性 API

标记

标记会指定音频框架如何对音频播放应用效果。请为一个实例提供以下一个或多个标记:

  • FLAG_AUDIBILITY_ENFORCED。请求系统确保声音的可听性。用于满足旧版 STREAM_SYSTEM_ENFORCED 的需求(如强制要求发出相机快门提示音)。
  • HW_AV_SYNC。请求系统选择支持硬件 A/V 同步的输出流。

音频属性标记是非专有的(可以组合使用)。要详细了解这些标记,请参阅音频属性 API

示例

在此示例中,AudioAttributes.Builder 定义了一个新的 AudioTrack 实例将使用的音频属性:

AudioTrack myTrack = new AudioTrack(
  new AudioAttributes.Builder()
 .setUsage(AudioAttributes.USAGE_MEDIA)
    .setContentType(AudioAttributes.CONTENT_TYPE_MUSIC)
    .build(),
  myFormat, myBuffSize, AudioTrack.MODE_STREAM, mySession);

兼容性

应用开发者在为 Android 5.0 创建或更新应用时应使用音频属性。但是,应用并非必须要利用这些属性;它们可以仅处理旧版流类型,或者一直不了解属性(例如对其播放的内容一无所知的常规媒体播放器)。

在此类情况下,框架通过自动将旧版音频流类型转换为音频属性,保持对旧设备和 Android 版本的向后兼容性。但是,框架不会针对各个设备、制造商或 Android 版本强制要求或保证具备这种映射。

兼容性映射:

Android 5.0 Android 4.4 及更早版本
CONTENT_TYPE_SPEECH
USAGE_VOICE_COMMUNICATION
STREAM_VOICE_CALL
CONTENT_TYPE_SONIFICATION
USAGE_ASSISTANCE_SONIFICATION
STREAM_SYSTEM
CONTENT_TYPE_SONIFICATION
USAGE_NOTIFICATION_RINGTONE
STREAM_RING
CONTENT_TYPE_MUSIC
USAGE_UNKNOWN
USAGE_MEDIA
USAGE_GAME
USAGE_ASSISTANCE_ACCESSIBILITY
USAGE_ASSISTANCE_NAVIGATION_GUIDANCE
STREAM_MUSIC
CONTENT_TYPE_SONIFICATION
USAGE_ALARM
STREAM_ALARM
CONTENT_TYPE_SONIFICATION
USAGE_NOTIFICATION
USAGE_NOTIFICATION_COMMUNICATION_REQUEST
USAGE_NOTIFICATION_COMMUNICATION_INSTANT
USAGE_NOTIFICATION_COMMUNICATION_DELAYED
USAGE_NOTIFICATION_EVENT
STREAM_NOTIFICATION
CONTENT_TYPE_SPEECH (@hide) STREAM_BLUETOOTH_SCO
FLAG_AUDIBILITY_ENFORCED (@hide) STREAM_SYSTEM_ENFORCED
CONTENT_TYPE_SONIFICATION
USAGE_VOICE_COMMUNICATION_SIGNALLING
(@hide) STREAM_DTMF

注意:@hide 流在框架内部使用,不是公共 API 的一部分。