audioDevices do not update after granting bluetooth permission (Android 12)
neubami94 opened this issue · 10 comments
Describe the bug
audioDevices do not update after granting bluetooth permission (Android 12)
To Reproduce
Steps to reproduce the behavior:
- turn on bluetooth on your android 12 device and connect to bluetooth audio device
- open app and grant BLUETOOTH_CONNECT permission
- call audioSwitch.start
- audioDevices contain Bluetooth headset ✅
- remove permission, app restarts automatically
- audioDevices now do not contain Bluetooth headset ✅
BUT - grant permission again, app does not restart automatically
- audioDevices still do not contain Bluetooth headset ❌
AND
- turn on bluetooth on your android 12 device and connect to bluetooth audio device
- open app and call audioSwitch.start
- grant BLUETOOTH_CONNECT permission
- audioDevices still do not contain Bluetooth headset ❌
Expected behavior
audioDevices emit and contain Bluetooth headset
Actual behavior
audioDevices do not emit and do not contain Bluetooth headset
Application Logs
2022-03-25 16:02:47.408 24131-24131/com.nn.my2ncommunicator.dev.debug D/AS/AudioSwitch: AudioSwitch(1.1.4)
2022-03-25 16:02:47.409 24131-24131/com.nn.my2ncommunicator.dev.debug D/AS/AudioSwitch: Preferred device list = [BluetoothHeadset, WiredHeadset, Earpiece, Speakerphone]
2022-03-25 16:02:47.429 24131-24171/com.nn.my2ncommunicator.dev.debug W/AS/BluetoothHeadsetManager: Bluetooth unsupported, permissions not granted
2022-03-25 16:02:47.432 24131-24171/com.nn.my2ncommunicator.dev.debug W/AS/BluetoothHeadsetManager: Bluetooth unsupported, permissions not granted
2022-03-25 16:02:47.433 24131-24171/com.nn.my2ncommunicator.dev.debug D/AS/AudioDeviceManager: Earpiece available
2022-03-25 16:02:47.445 24131-24171/com.nn.my2ncommunicator.dev.debug D/AS/AudioDeviceManager: Speakerphone available
2022-03-25 16:02:47.446 24131-24171/com.nn.my2ncommunicator.dev.debug D/AS/AudioSwitch: Available AudioDevice list updated: [Earpiece(name=Earpiece), Speakerphone(name=Speakerphone)]
2022-03-25 16:02:47.446 24131-24171/com.nn.my2ncommunicator.dev.debug D/AS/AudioSwitch: Current user selected AudioDevice = null
---- Permission granted here ------
2022-03-25 16:03:01.830 24131-24171/com.nn.my2ncommunicator.dev.debug W/AS/BluetoothHeadsetManager: Cannot deactivate when in the Disconnected state
2022-03-25 16:03:01.837 24131-24171/com.nn.my2ncommunicator.dev.debug D/AS/AudioSwitch: Selected AudioDevice = Speakerphone(name=Speakerphone)
2022-03-25 16:03:01.837 24131-24171/com.nn.my2ncommunicator.dev.debug W/AS/BluetoothHeadsetManager: Bluetooth unsupported, permissions not granted
2022-03-25 16:03:01.837 24131-24171/com.nn.my2ncommunicator.dev.debug D/AS/AudioDeviceManager: Earpiece available
2022-03-25 16:03:01.848 24131-24171/com.nn.my2ncommunicator.dev.debug D/AS/AudioDeviceManager: Speakerphone available
2022-03-25 16:03:01.848 24131-24171/com.nn.my2ncommunicator.dev.debug D/AS/AudioSwitch: Available AudioDevice list updated: [Earpiece(name=Earpiece), Speakerphone(name=Speakerphone)]
2022-03-25 16:03:01.848 24131-24171/com.nn.my2ncommunicator.dev.debug D/AS/AudioSwitch: Current user selected AudioDevice = Speakerphone(name=Speakerphone)
2022-03-25 16:03:01.849 24131-24171/com.nn.my2ncommunicator.dev.debug W/AS/BluetoothHeadsetManager: Cannot deactivate when in the Disconnected state
2022-03-25 16:03:17.557 24131-24171/com.nn.my2ncommunicator.dev.debug W/AS/BluetoothHeadsetManager: Cannot deactivate when in the Disconnected state
2022-03-25 16:05:22.182 24131-24171/com.nn.my2ncommunicator.dev.debug W/AS/BluetoothHeadsetManager: Cannot deactivate when in the Disconnected state
2022-03-25 16:05:27.259 24131-24171/com.nn.my2ncommunicator.dev.debug W/AS/BluetoothHeadsetManager: Cannot deactivate when in the Disconnected state
2022-03-25 16:05:48.282 24131-24171/com.nn.my2ncommunicator.dev.debug W/AS/BluetoothHeadsetManager: Cannot deactivate when in the Disconnected state
AudioSwitch Version
- Version: (e.g. 1.1.4)
Android Device (please complete the following information):
- Device: Pixel 3a
- API Version: 31
We are currently dealing with the same issue.
I tried calling audioSwitch.availableAudioDevices after granting the permissions and it does not contain the bluetooth device. So thats why it does not emit.
I hotfixed the issue by writing a bluetooth permission manager, observing when a permission is granted and then calling this:
@Synchronized
fun restart(): Completable {
return Completable.fromCallable {
logThread("Restart")
audioSwitch.stop()
audioSwitch.start { audioDevices, selectedAudioDevice ->
selectedAudioDevice?.let { currentlyActiveOutput.onNext(selectedAudioDevice) }
availableAudioOutputs.onNext(audioDevices)
}
}
}
@zelenmi6 any update on this?? i am still facing the error with 1.1.5 audioswitch
in the listener I'm getting the Bluetooth device name but the audio is still coming from the earpiece and later on the listener also gives Earpiece
There's no way for AudioSwitch to automatically know that the bluetooth permission is granted, so you'd need to manually restart it yourself.
@davidliu is correct. AudioSwitch expects the permissions it requires to be granted before it is started. If permissions are granted afterwards, then it should be restarted.
After granting the permission if we call the below code
_audioSwitch.start { listAudioDevice: List<AudioDevice?>?, selectedDevice: AudioDevice? ->}
got error message: Redundant start() invocation while already in the started or activated state
How to restart the audio switch? @afalls-twilio @davidliu
stop
then start
.
@davidliu
Thank you so much it's working fine.
I have one more query regarding the audio switch. Might have you help me?
Precondition: Bluetooth is connected
When I select audio from Bluetooth to phone/speaker sometimes voice comes in speaker/phone and sometimes in Bluetooth.
For more info please check this one:#163