Audio de alta resolución

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

  • Flotante: los códecs WAV, FLAC y los extractores se actualizan para admitir flotación (más de 24 bits de precisión sin pérdidas). Los efectos Downmix y Virtualizer se actualizan para flotar. MediaPlayer (NuPlayer) permite la precisión actualizada.
  • Alta frecuencia: los códecs WAV, FLAC y los extractores se actualizan para admitir 192 kHz. Los efectos predeterminados proporcionados por Android se prueban para admitir 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 compatibilidad multicanal con ocho canales.
  • Temporización: la información de temporización se incluye en todo el marco de audio.

A partir de Android 9, las siguientes mejoras no requieren la implementación de ningún socio:

  • La cantidad de pistas de salida de clientes simultáneas aumenta de 14 a 40, ya que las instancias limitadas de clientes de AudioTrack han sido un problema para las aplicaciones en Android 8.x.
  • La memoria máxima de cliente/servidor aumenta de 4 MB a 32 MB (dependiendo de la memoria total del dispositivo) para permitir más pistas de audio de alta resolución simultáneas.
  • El total de pistas mixtas aumenta de 32 a 256 para evitar la contención de recursos entre las aplicaciones y la interfaz de usuario del sistema.

Cambios en el efecto de salida

Consulte Efectos de audio para cambios en la versión de Android 11.

Antes del lanzamiento de Android 9, el procesamiento de la cadena 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 coma 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, la canalización de procesamiento de la cadena de efectos se actualizó para admitir el formato flotante multicanal. Puntos clave:

  • Los efectos del software de Android ya se han migrado a estéreo flotante.
  • Los efectos heredados son compatibles con adaptadores de formato, que convierten float a int16 según sea necesario.

Implementación de efectos de salida

Una implementación de referencia para los efectos de salida está 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:

  • Actualice los efectos de salida para admitir el formato flotante multicanal:
    • Ya no se requiere soporte de procesamiento Int16.
    • Admite recuentos de canales de salida de 2 a 8 (para compatibilidad futura, considere recuentos de 1 a 30).
    • Admite recuentos de canales de entrada que coinciden con los recuentos de canales de salida para efectos de inserción. Los efectos auxiliares continúan 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 debe continuar admitiendo efectos de salida de proveedores heredados y no puede actualizarlos, verifique el código heredado de la siguiente manera:
    • Los efectos de salida heredados (inserción) deben rechazar configuraciones no admitidas en EFFECT_CMD_SET_CONFIG .
      • Compruebe que el formato es int16.
      • Verifique que las máscaras de los canales de entrada y salida sean estéreo.
      • Si alguna de las comprobaciones falla, devuelve -EINVAL .
    • AudioFlinger configura los efectos de salida heredados (auxiliares) con una máscara de canal de entrada mono y máscaras de canal de salida potencialmente multicanal, dependiendo de si el sumidero de salida es multicanal. Deben rechazar configuraciones no admitidas en EFFECT_CMD_SET_CONFIG .
      • Compruebe que el formato es int16.
      • Compruebe 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 comprobaciones falla, devuelve -EINVAL .
    • Verifique el código heredado. ¡No asumas que funciona!