Audio de alta resolución

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

  • Flotante: los códecs y extractores WAV, FLAC 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 y extractores WAV, FLAC 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.
  • Sincronización: la información de sincronizació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 cliente simultáneas aumenta de 14 a 40, ya que las instancias limitadas de AudioTrack de cliente han sido un problema para las aplicaciones en Android 8.x.
  • La memoria máxima cliente/servidor aumenta de 4 MB a 32 MB (dependiendo de la memoria total del dispositivo) para permitir más pistas de audio simultáneas de alta resolución.
  • 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 los 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 punto flotante a int16, lo que provocó una pérdida de precisión.
  • Los efectos de salida se rechazaron de los sumideros de salida con un número de canales superior a dos.

En la versión de Android 9, la canalización de procesamiento de la cadena de efectos se actualiza 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 se admiten con adaptadores de formato, que convierten float a int16 según sea necesario.

Implementar efectos de salida

Una implementación de referencia para 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 del 2 al 8 (para compatibilidad futura, considere recuentos del 1 al 30).
    • Admite recuentos de canales de entrada que coinciden con recuentos de canales de salida para efectos de inserción. Los efectos auxiliares continúan teniendo 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 los efectos de salida de proveedores heredados y no puede actualizarlos, verifique el código heredado de la siguiente manera:
    • Los efectos de salida (inserción) heredados deben rechazar configuraciones no admitidas en EFFECT_CMD_SET_CONFIG .
      • Comprueba que el formato sea int16.
      • Compruebe que las máscaras de los canales de entrada y salida sean estéreo.
      • Si cualquiera 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 las configuraciones no admitidas en EFFECT_CMD_SET_CONFIG .
      • Comprueba que el formato sea int16.
      • Compruebe que la máscara del canal de entrada sea mono y la máscara del canal de salida sea estéreo.
      • Si cualquiera de las comprobaciones falla, devuelve -EINVAL .
    • Verificar el código heredado. ¡No asumas que funciona!