Este guia explica como rotear áudio para dispositivos Bluetooth usando o API Telecom e configurar a conexão para Chamadas VoIP. Leia o Guia Criar um app de chamadas antes de continuar.
Usando o ConnectionService
e Connection
, você poderá acessar
o estado do áudio e uma lista de dispositivos Bluetooth disponíveis, além de poder
áudio para um dispositivo Bluetooth selecionado.
Conexão VoIP e ConnectionService
Crie uma classe VoIPConnection
que se estenda da
Connection
. Esta classe controla o estado da chamada atual. Conforme o
Guia Criar um app de chamadas
estados, torná-lo um aplicativo autogerenciado e configurar o modo de áudio para um
para o aplicativo.
Kotlin
class VoIPConnection : Connection() { init { setConnectionProperties(PROPERTY_SELF_MANAGED) setAudioModeIsVoip(true) } }
Java
public class VoIPConnection extends Connection { public VoIPConnection() { setConnectionProperties(PROPERTY_SELF_MANAGED); setAudioModeIsVoip(true); } }
Em seguida, retorne uma instância dessa classe
ConnectionService
quando um
de uma chamada recebida ou efetuada.
Kotlin
class VoIPConnectionService : ConnectionService() { override fun onCreateOutgoingConnection( connectionManagerPhoneAccount: PhoneAccountHandle, request: ConnectionRequest, ): Connection { return VoIPConnection() } }
Java
public class VoIPConnectionService extends ConnectionService { @Override public Connection onCreateOutgoingConnection(PhoneAccountHandle connectionManagerPhoneAccount, ConnectionRequest request) { return new VoIPConnection(); } }
Verifique se o manifesto aponta corretamente para a classe VoIPConnectionService
.
<service android:name=".voip.TelegramConnectionService" android:permission="android.permission.BIND_TELECOM_CONNECTION_SERVICE">
<intent-filter>
<action android:name="android.telecom.ConnectionService"/>
</intent-filter>
</service>
Com esses Connection
personalizados e
ConnectionService
turmas, você
pode controlar qual dispositivo e que tipo de roteamento de áudio você quer usar durante uma
a chamada.
Conferir o estado atual do áudio
Para saber o estado atual do áudio, chame
getCallAudioState()
getCallAudioState()
retorna se o dispositivo estiver transmitindo usando Bluetooth, minifone de ouvido, com fio ou
Alto-falante.
mAudioState = connection.getCallAudioState()
Ativado com estado alterado
Inscrever-se nas alterações em CallAudioState substituindo
onCallAudioStateChanged()
Isso alerta você sobre qualquer mudança no estado.
Kotlin
fun onCallAudioStateChanged(audioState: CallAudioState) { mAudioState = audioState }
Java
@Override public void onCallAudioStateChanged(CallAudioState audioState) { mAudioState = audioState; }
Obter o dispositivo atual
Obter o dispositivo ativo atual usando
CallAudioState.getActiveBluetoothDevice()
Essa função retorna o dispositivo Bluetooth ativo.
Kotlin
val activeDevice: BluetoothDevice = mAudioState.getActiveBluetoothDevice()
Java
BluetoothDevice activeDevice = mAudioState.getActiveBluetoothDevice();
Comprar dispositivos Bluetooth
Veja uma lista de dispositivos Bluetooth disponíveis para roteamento de áudio de chamadas usando
CallAudioState.getSupportedBluetoothDevices()
Kotlin
val availableBluetoothDevices: Collection= mAudioState.getSupportedBluetoothDevices()
Java
CollectionavailableBluetoothDevices = mAudioState.getSupportedBluetoothDevices();
Encaminhar o áudio da chamada
Como usar o nível 28 da API e mais recentes (recomendado)
Encaminhe o áudio da chamada para um dispositivo Bluetooth disponível usando o
requestBluetoothAudio(BluetoothDevice)
:
requestBluetoothAudio(availableBluetoothDevices[0]);
Como usar o nível 23 da API e mais recentes
Ativar
ROUTE_BLUETOOTH
sem especificar o dispositivo usando
setAudioRoute(int)
O roteamento padrão é de dispositivos Bluetooth atuais e ativos no Android 9 e versões mais recentes.
setAudioRoute(CallAudioState.ROUTE_BLUETOOTH);