Audio en alta resolución

La versión de Android 10 incluye las siguientes mejoras para el audio de alta resolución:

  • Número de punto flotante: Los extractores y los códecs WAV y FLAC se actualizaron para admitir números de punto flotante (más de 24 bits de precisión sin pérdida). Los efectos de Downmix y Virtualizer se actualizaron para flotar. MediaPlayer (NuPlayer) permite la precisión actualizada.
  • Alta frecuencia: Los extractores y códecs WAV y FLAC se actualizaron para admitir 192 KHz. Los efectos predeterminados que proporciona Android se prueban para la compatibilidad con 192 KHz en frecuencias estándar. Las frecuencias estándar permitidas son 88.2 kHz, 96 kHz, 176.4 kHz y 192 kHz.
  • Multicanal: Los efectos de reproducción predeterminados de Android se prueban para la compatibilidad con varios canales hasta ocho.
  • Tiempo: La información de tiempo se incluye en todo el framework de audio.

A partir de Android 9, las siguientes mejoras no requieren ninguna implementación de socios:

  • La cantidad de segmentos de salida de cliente simultáneos aumenta de 14 a 40, ya que las instancias de cliente limitadas de AudioTrack fueron un problema para las apps en Android 8.x.
  • La memoria máxima del cliente y el servidor aumenta de 4 MB a 32 MB (según la memoria total del dispositivo) para permitir más pistas de audio de alta resolución simultáneas.
  • La cantidad total de segmentos mixtos aumenta de 32 a 256 para evitar la contención de recursos entre las apps y la IU del sistema.

Cambios en el efecto de salida

Consulta Efectos de sonido para ver los cambios de la versión de Android 11.

Antes del lanzamiento de Android 9, el procesamiento de cadenas de efectos se implementaba en formato de muestra estéreo int16. Esto tenía varias limitaciones:

  • Todos los efectos de salida forzaron la conversión de datos de audio de punto flotante a int16, lo que provocó una pérdida de precisión.
  • Se rechazaron los efectos de salida de los sumideros de salida con un recuento de canales superior a dos.

En la versión de Android 9, se actualizó la canalización de procesamiento de cadenas de efectos para admitir el formato de número de punto flotante multicanal. Puntos clave:

  • Los efectos de software de Android ya se migraron a números de punto flotante estéreo.
  • Los efectos heredados son compatibles con adaptadores de formato, que convierten el tipo de datos float a int16 según sea necesario.

Implementa efectos de salida

Hay una implementación de referencia para los efectos de salida disponible en frameworks/av/media/libeffects.

Los socios que implementen sus propios efectos de salida personalizados deben hacer lo siguiente para la versión de Android 10:

  • Actualiza los efectos de salida para admitir el formato de número de punto flotante multicanal:
    • Ya no se requiere compatibilidad con el procesamiento de Int16.
    • Admite recuentos de canales de salida de 2 a 8 (para la compatibilidad futura, considera recuentos de 1 a 30).
    • Admite recuentos de canales de entrada que coincidan con los recuentos de canales de salida para los efectos de inserción. Los efectos auxiliares siguen viendo un recuento de canales de entrada de 1 (mono).
    • Admite máscaras de posición de canal (canónicas) y máscaras de índice de canal de (1 << n) - 1.
  • Si debes seguir admitiendo los efectos de salida de proveedores heredados y no puedes actualizarlos, verifica el código heredado de la siguiente manera:
    • Los efectos de salida heredados (insert) deben rechazar las configuraciones no admitidas en EFFECT_CMD_SET_CONFIG.
      • Verifica que el formato sea int16.
      • Comprueba que las máscaras de canales de entrada y salida sean estéreo.
      • Si alguna de las verificaciones falla, muestra -EINVAL.
    • AudioFlinger configura los efectos de salida heredados (auxiliares) con una máscara de canal de entrada mono y, posiblemente, máscaras de canal de salida multicanal, según si el sumidero de salida es multicanal. Deben rechazar las configuraciones no admitidas en EFFECT_CMD_SET_CONFIG.
      • Verifica que el formato sea int16.
      • Verifica que la máscara del canal de entrada sea mono y que la máscara del canal de salida sea estéreo.
      • Si alguna de las verificaciones falla, muestra -EINVAL.
    • Verifica el código heredado. No des por sentado que funciona.