From 49cf3af7690b6114ece809eace0c65d1cbcdf1fc Mon Sep 17 00:00:00 2001 From: Ryzerth Date: Sun, 21 Feb 2021 00:06:41 +0100 Subject: [PATCH] Tuned rtaudio sink --- rtaudio_sink/src/main.cpp | 27 ++++++++++++++++----------- 1 file changed, 16 insertions(+), 11 deletions(-) diff --git a/rtaudio_sink/src/main.cpp b/rtaudio_sink/src/main.cpp index 29903048..fa15c9ac 100644 --- a/rtaudio_sink/src/main.cpp +++ b/rtaudio_sink/src/main.cpp @@ -40,6 +40,8 @@ public: if (info.isDefaultOutput) { devId = devList.size(); } devList.push_back(info); deviceIds.push_back(i); + txtDevList += info.name; + txtDevList += '\0'; } } @@ -66,15 +68,15 @@ public: void menuHandler() { float menuWidth = ImGui::GetContentRegionAvailWidth(); - // ImGui::SetNextItemWidth(menuWidth); - // if (ImGui::Combo(("##_rtaudio_sink_dev_"+_streamName).c_str(), &devListId, txtDevList.c_str())) { - // // TODO: Load SR from config - // if (running) { - // doStop(); - // doStart(); - // } - // // TODO: Save to config - // } + ImGui::SetNextItemWidth(menuWidth); + if (ImGui::Combo(("##_rtaudio_sink_dev_"+_streamName).c_str(), &devId, txtDevList.c_str())) { + // TODO: Load SR from config + if (running) { + doStop(); + doStart(); + } + // TODO: Save to config + } // AudioDevice_t* dev = devices[devListId]; @@ -95,7 +97,7 @@ private: parameters.deviceId = deviceIds[devId]; parameters.nChannels = 2; unsigned int sampleRate = 48000; - unsigned int bufferFrames = sampleRate / 200; + unsigned int bufferFrames = sampleRate / 60; RtAudio::StreamOptions opts; opts.flags = RTAUDIO_MINIMIZE_LATENCY; @@ -108,7 +110,10 @@ private: } catch ( RtAudioError& e ) { spdlog::error("Could not open audio device"); + return; } + + spdlog::info("RtAudio stream open"); } void doStop() { @@ -120,7 +125,7 @@ private: audio.stopStream(); audio.closeStream(); monoPacker.out.clearReadStop(); - stereoPacker.out.clearWriteStop(); + stereoPacker.out.clearReadStop(); } static int callback( void *outputBuffer, void *inputBuffer, unsigned int nBufferFrames, double streamTime, RtAudioStreamStatus status, void *userData) {