From 5b7ce77ad3e918e3341cc3170ce7afb85b253a81 Mon Sep 17 00:00:00 2001 From: Myzel394 <50424412+Myzel394@users.noreply.github.com> Date: Sat, 21 Oct 2023 19:23:53 +0200 Subject: [PATCH] fix: Improve microphone selection --- .../alibi/ui/models/AudioRecorderModel.kt | 56 +++++++++++-------- 1 file changed, 33 insertions(+), 23 deletions(-) diff --git a/app/src/main/java/app/myzel394/alibi/ui/models/AudioRecorderModel.kt b/app/src/main/java/app/myzel394/alibi/ui/models/AudioRecorderModel.kt index d13bd84eb..2c1c71862 100644 --- a/app/src/main/java/app/myzel394/alibi/ui/models/AudioRecorderModel.kt +++ b/app/src/main/java/app/myzel394/alibi/ui/models/AudioRecorderModel.kt @@ -16,13 +16,15 @@ import app.myzel394.alibi.services.AudioRecorderService import app.myzel394.alibi.services.RecorderService import app.myzel394.alibi.ui.utils.MicrophoneInfo -class AudioRecorderModel: ViewModel() { +class AudioRecorderModel : ViewModel() { var recorderState by mutableStateOf(RecorderState.IDLE) private set var recordingTime by mutableStateOf(null) private set var amplitudes by mutableStateOf>(emptyList()) private set + var selectedMicrophone by mutableStateOf(null) + private set var onAmplitudeChange: () -> Unit = {} @@ -46,28 +48,35 @@ class AudioRecorderModel: ViewModel() { private val connection = object : ServiceConnection { override fun onServiceConnected(className: ComponentName, service: IBinder) { - recorderService = ((service as RecorderService.RecorderBinder).getService() as AudioRecorderService).also {recorder -> - recorder.onStateChange = { state -> - recorderState = state - } - recorder.onRecordingTimeChange = { time -> - recordingTime = time - } - recorder.onAmplitudeChange = { amps -> - amplitudes = amps - onAmplitudeChange() + recorderService = + ((service as RecorderService.RecorderBinder).getService() as AudioRecorderService).also { recorder -> + // Update UI when the service changes + recorder.onStateChange = { state -> + recorderState = state + } + recorder.onRecordingTimeChange = { time -> + recordingTime = time + } + recorder.onAmplitudeChange = { amps -> + amplitudes = amps + onAmplitudeChange() + } + recorder.onError = { + recorderService!!.createLastRecording() + onError() + } + recorder.onSelectedMicrophoneChange = { microphone -> + selectedMicrophone = microphone + } + }.also { + // Init UI from the service + it.startRecording() + + recorderState = it.state + recordingTime = it.recordingTime + amplitudes = it.amplitudes + selectedMicrophone = it.selectedMicrophone } - recorder.onError = { - recorderService!!.createLastRecording() - onError() - } - }.also { - it.startRecording() - - recorderState = it.state - recordingTime = it.recordingTime - amplitudes = it.amplitudes - } } override fun onServiceDisconnected(arg0: ComponentName) { @@ -80,6 +89,7 @@ class AudioRecorderModel: ViewModel() { recorderState = RecorderState.IDLE recordingTime = null amplitudes = emptyList() + selectedMicrophone = null } fun startRecording(context: Context) { @@ -120,7 +130,7 @@ class AudioRecorderModel: ViewModel() { } fun changeMicrophone(microphone: MicrophoneInfo?) { - recorderService!!.selectedDevice = microphone + recorderService!!.changeMicrophone(microphone) } fun bindToService(context: Context) {