Cuando se captura audio, el HAL de audio recibe una llamada openInputStream
que incluye un argumento AudioSource
para indicar cómo se debe procesar la entrada del micrófono.
La fuente VOICE_RECOGNITION
espera una transmisión de micrófono estéreo que tenga un efecto de cancelación de eco (si está disponible), pero que no se le aplique ningún otro procesamiento.
Entrada de micrófono multicanal
Para capturar audio de un dispositivo con más de dos canales (estéreo), usa una máscara de índice de canal en lugar de una máscara de índice posicional (como CHANNEL_IN_LEFT
). Por ejemplo:
final AudioFormat audioFormat = new AudioFormat.Builder()
.setEncoding(AudioFormat.ENCODING_PCM_16BIT)
.setSampleRate(44100)
.setChannelIndexMask(0xf /* 4 channels, 0..3 */)
.build();
final AudioRecord audioRecord = new AudioRecord.Builder()
.setAudioFormat(audioFormat)
.build();
audioRecord.setPreferredDevice(someAudioDeviceInfo);
Cuando se configuran setChannelMask
y setChannelIndexMask
, AudioRecord
solo usa el valor que establece setChannelMask
(máximo de dos canales).
Captura simultánea
A partir de Android 10, el framework de Android admite la captura simultánea de entradas, pero con restricciones para proteger la privacidad del usuario. Como parte de estas restricciones, se ignoran las fuentes virtuales, como AUDIO_SOURCE_FM_TUNER
, y se permite que se capturen de forma simultánea junto con una entrada normal (como el micrófono).
HwAudioSource
no se considera parte de las restricciones de captura simultáneas.
Las apps diseñadas para funcionar con dispositivos AUDIO_DEVICE_IN_BUS
o con dispositivos AUDIO_DEVICE_IN_FM_TUNER
secundarios deben identificar esos dispositivos de forma explícita y usar AudioRecord.setPreferredDevice()
para omitir la lógica de selección de fuente predeterminada de Android.