summaryrefslogtreecommitdiff
path: root/src/audio/manager.cpp
diff options
context:
space:
mode:
authorouwou <26526779+ouwou@users.noreply.github.com>2023-01-16 22:52:39 -0500
committerouwou <26526779+ouwou@users.noreply.github.com>2023-01-16 22:52:39 -0500
commitea04035f0db8fa990dd7ca8dd1a64f56bceb82e2 (patch)
tree751a4f4e2cd33c19006d92547de4fcccc2a618ee /src/audio/manager.cpp
parent5e85d16cd61a9f28bd046d4c7921be8f6cc2b2fc (diff)
downloadabaddon-portaudio-ea04035f0db8fa990dd7ca8dd1a64f56bceb82e2.tar.gz
abaddon-portaudio-ea04035f0db8fa990dd7ca8dd1a64f56bceb82e2.zip
persist voice settings, handle volume w/ no ssrc
Diffstat (limited to 'src/audio/manager.cpp')
-rw-r--r--src/audio/manager.cpp23
1 files changed, 19 insertions, 4 deletions
diff --git a/src/audio/manager.cpp b/src/audio/manager.cpp
index 1a7bda5..618773d 100644
--- a/src/audio/manager.cpp
+++ b/src/audio/manager.cpp
@@ -278,13 +278,21 @@ void AudioManager::SetPlayback(bool playback) {
}
void AudioManager::SetCaptureGate(double gate) {
- m_capture_gate = gate * 0.01;
+ m_capture_gate = gate;
}
void AudioManager::SetCaptureGain(double gain) {
m_capture_gain = gain;
}
+double AudioManager::GetCaptureGate() const noexcept {
+ return m_capture_gate;
+}
+
+double AudioManager::GetCaptureGain() const noexcept {
+ return m_capture_gain;
+}
+
void AudioManager::SetMuteSSRC(uint32_t ssrc, bool mute) {
std::lock_guard<std::mutex> _(m_mutex);
if (mute) {
@@ -296,9 +304,15 @@ void AudioManager::SetMuteSSRC(uint32_t ssrc, bool mute) {
void AudioManager::SetVolumeSSRC(uint32_t ssrc, double volume) {
std::lock_guard<std::mutex> _(m_mutex);
- volume *= 0.01;
- constexpr const double E = 2.71828182845904523536;
- m_volume_ssrc[ssrc] = (std::exp(volume) - 1) / (E - 1);
+ m_volume_ssrc[ssrc] = volume;
+}
+
+double AudioManager::GetVolumeSSRC(uint32_t ssrc) const {
+ std::lock_guard<std::mutex> _(m_mutex);
+ if (const auto iter = m_volume_ssrc.find(ssrc); iter != m_volume_ssrc.end()) {
+ return iter->second;
+ }
+ return 1.0;
}
void AudioManager::SetEncodingApplication(int application) {
@@ -463,4 +477,5 @@ AudioDevices &AudioManager::GetDevices() {
AudioManager::type_signal_opus_packet AudioManager::signal_opus_packet() {
return m_signal_opus_packet;
}
+
#endif