mirror of
https://github.com/RetroDECK/Duckstation.git
synced 2025-01-17 22:25:37 +00:00
Qt: Hook up audio driver selection
This commit is contained in:
parent
609b050676
commit
57c1ca97f7
|
@ -275,6 +275,7 @@ void Settings::Load(SettingsInterface& si)
|
||||||
audio_backend =
|
audio_backend =
|
||||||
ParseAudioBackend(si.GetStringValue("Audio", "Backend", GetAudioBackendName(DEFAULT_AUDIO_BACKEND)).c_str())
|
ParseAudioBackend(si.GetStringValue("Audio", "Backend", GetAudioBackendName(DEFAULT_AUDIO_BACKEND)).c_str())
|
||||||
.value_or(DEFAULT_AUDIO_BACKEND);
|
.value_or(DEFAULT_AUDIO_BACKEND);
|
||||||
|
audio_driver = si.GetStringValue("Audio", "Driver");
|
||||||
audio_stretch_mode =
|
audio_stretch_mode =
|
||||||
AudioStream::ParseStretchMode(
|
AudioStream::ParseStretchMode(
|
||||||
si.GetStringValue("Audio", "StretchMode", AudioStream::GetStretchModeName(DEFAULT_AUDIO_STRETCH_MODE)).c_str())
|
si.GetStringValue("Audio", "StretchMode", AudioStream::GetStretchModeName(DEFAULT_AUDIO_STRETCH_MODE)).c_str())
|
||||||
|
@ -477,6 +478,7 @@ void Settings::Save(SettingsInterface& si) const
|
||||||
si.SetIntValue("CDROM", "SeekSpeedup", cdrom_seek_speedup);
|
si.SetIntValue("CDROM", "SeekSpeedup", cdrom_seek_speedup);
|
||||||
|
|
||||||
si.SetStringValue("Audio", "Backend", GetAudioBackendName(audio_backend));
|
si.SetStringValue("Audio", "Backend", GetAudioBackendName(audio_backend));
|
||||||
|
si.SetStringValue("Audio", "Driver", audio_driver.c_str());
|
||||||
si.SetStringValue("Audio", "StretchMode", AudioStream::GetStretchModeName(audio_stretch_mode));
|
si.SetStringValue("Audio", "StretchMode", AudioStream::GetStretchModeName(audio_stretch_mode));
|
||||||
si.SetUIntValue("Audio", "BufferMS", audio_buffer_ms);
|
si.SetUIntValue("Audio", "BufferMS", audio_buffer_ms);
|
||||||
si.SetUIntValue("Audio", "OutputLatencyMS", audio_output_latency_ms);
|
si.SetUIntValue("Audio", "OutputLatencyMS", audio_output_latency_ms);
|
||||||
|
|
|
@ -144,6 +144,7 @@ struct Settings
|
||||||
|
|
||||||
AudioBackend audio_backend = DEFAULT_AUDIO_BACKEND;
|
AudioBackend audio_backend = DEFAULT_AUDIO_BACKEND;
|
||||||
AudioStretchMode audio_stretch_mode = DEFAULT_AUDIO_STRETCH_MODE;
|
AudioStretchMode audio_stretch_mode = DEFAULT_AUDIO_STRETCH_MODE;
|
||||||
|
std::string audio_driver;
|
||||||
u32 audio_output_latency_ms = DEFAULT_AUDIO_OUTPUT_LATENCY_MS;
|
u32 audio_output_latency_ms = DEFAULT_AUDIO_OUTPUT_LATENCY_MS;
|
||||||
u32 audio_buffer_ms = DEFAULT_AUDIO_BUFFER_MS;
|
u32 audio_buffer_ms = DEFAULT_AUDIO_BUFFER_MS;
|
||||||
u32 audio_output_volume = 100;
|
u32 audio_output_volume = 100;
|
||||||
|
|
|
@ -3048,7 +3048,7 @@ void System::CheckForSettingsChanges(const Settings& old_settings)
|
||||||
UpdateOverclock();
|
UpdateOverclock();
|
||||||
}
|
}
|
||||||
|
|
||||||
if (g_settings.audio_backend != old_settings.audio_backend)
|
if (g_settings.audio_backend != old_settings.audio_backend || g_settings.audio_driver != old_settings.audio_driver)
|
||||||
{
|
{
|
||||||
if (g_settings.audio_backend != old_settings.audio_backend)
|
if (g_settings.audio_backend != old_settings.audio_backend)
|
||||||
{
|
{
|
||||||
|
|
|
@ -1,5 +1,6 @@
|
||||||
#include "audiosettingswidget.h"
|
#include "audiosettingswidget.h"
|
||||||
#include "core/spu.h"
|
#include "core/spu.h"
|
||||||
|
#include "frontend-common/common_host.h"
|
||||||
#include "settingsdialog.h"
|
#include "settingsdialog.h"
|
||||||
#include "settingwidgetbinder.h"
|
#include "settingwidgetbinder.h"
|
||||||
#include "util/audio_stream.h"
|
#include "util/audio_stream.h"
|
||||||
|
@ -29,10 +30,11 @@ AudioSettingsWidget::AudioSettingsWidget(SettingsDialog* dialog, QWidget* parent
|
||||||
Settings::DEFAULT_AUDIO_OUTPUT_LATENCY_MS);
|
Settings::DEFAULT_AUDIO_OUTPUT_LATENCY_MS);
|
||||||
SettingWidgetBinder::BindWidgetToBoolSetting(sif, m_ui.startDumpingOnBoot, "Audio", "DumpOnBoot", false);
|
SettingWidgetBinder::BindWidgetToBoolSetting(sif, m_ui.startDumpingOnBoot, "Audio", "DumpOnBoot", false);
|
||||||
SettingWidgetBinder::BindWidgetToBoolSetting(sif, m_ui.muteCDAudio, "CDROM", "MuteCDAudio", false);
|
SettingWidgetBinder::BindWidgetToBoolSetting(sif, m_ui.muteCDAudio, "CDROM", "MuteCDAudio", false);
|
||||||
|
connect(m_ui.audioBackend, &QComboBox::currentIndexChanged, this, &AudioSettingsWidget::updateDriverNames);
|
||||||
|
updateDriverNames();
|
||||||
|
|
||||||
m_ui.outputLatencyMinimal->setChecked(m_ui.outputLatencyMS->value() == 0);
|
m_ui.outputLatencyMinimal->setChecked(m_ui.outputLatencyMS->value() == 0);
|
||||||
m_ui.outputLatencyMS->setEnabled(m_ui.outputLatencyMinimal->isChecked());
|
m_ui.outputLatencyMS->setEnabled(m_ui.outputLatencyMinimal->isChecked());
|
||||||
m_ui.driver->setEnabled(false);
|
|
||||||
|
|
||||||
connect(m_ui.bufferMS, &QSlider::valueChanged, this, &AudioSettingsWidget::updateLatencyLabel);
|
connect(m_ui.bufferMS, &QSlider::valueChanged, this, &AudioSettingsWidget::updateLatencyLabel);
|
||||||
connect(m_ui.outputLatencyMS, &QSlider::valueChanged, this, &AudioSettingsWidget::updateLatencyLabel);
|
connect(m_ui.outputLatencyMS, &QSlider::valueChanged, this, &AudioSettingsWidget::updateLatencyLabel);
|
||||||
|
@ -92,6 +94,38 @@ AudioSettingsWidget::AudioSettingsWidget(SettingsDialog* dialog, QWidget* parent
|
||||||
|
|
||||||
AudioSettingsWidget::~AudioSettingsWidget() = default;
|
AudioSettingsWidget::~AudioSettingsWidget() = default;
|
||||||
|
|
||||||
|
void AudioSettingsWidget::updateDriverNames()
|
||||||
|
{
|
||||||
|
const AudioBackend backend =
|
||||||
|
Settings::ParseAudioBackend(
|
||||||
|
m_dialog
|
||||||
|
->getEffectiveStringValue("Audio", "Backend", Settings::GetAudioBackendName(Settings::DEFAULT_AUDIO_BACKEND))
|
||||||
|
.c_str())
|
||||||
|
.value_or(Settings::DEFAULT_AUDIO_BACKEND);
|
||||||
|
|
||||||
|
std::vector<std::string> names;
|
||||||
|
|
||||||
|
#ifdef WITH_CUBEB
|
||||||
|
if (backend == AudioBackend::Cubeb)
|
||||||
|
names = CommonHost::GetCubebDriverNames();
|
||||||
|
#endif
|
||||||
|
|
||||||
|
m_ui.driver->disconnect();
|
||||||
|
if (names.empty())
|
||||||
|
{
|
||||||
|
m_ui.driver->setEnabled(false);
|
||||||
|
m_ui.driver->clear();
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
m_ui.driver->setEnabled(true);
|
||||||
|
for (const std::string& name : names)
|
||||||
|
m_ui.driver->addItem(QString::fromStdString(name));
|
||||||
|
|
||||||
|
SettingWidgetBinder::BindWidgetToStringSetting(m_dialog->getSettingsInterface(), m_ui.driver, "Audio", "Driver",
|
||||||
|
std::move(names.front()));
|
||||||
|
}
|
||||||
|
|
||||||
void AudioSettingsWidget::updateLatencyLabel()
|
void AudioSettingsWidget::updateLatencyLabel()
|
||||||
{
|
{
|
||||||
const u32 output_latency_ms = static_cast<u32>(m_ui.outputLatencyMS->value());
|
const u32 output_latency_ms = static_cast<u32>(m_ui.outputLatencyMS->value());
|
||||||
|
|
|
@ -15,6 +15,7 @@ public:
|
||||||
~AudioSettingsWidget();
|
~AudioSettingsWidget();
|
||||||
|
|
||||||
private Q_SLOTS:
|
private Q_SLOTS:
|
||||||
|
void updateDriverNames();
|
||||||
void updateLatencyLabel();
|
void updateLatencyLabel();
|
||||||
void updateVolumeLabel();
|
void updateVolumeLabel();
|
||||||
void onMinimalOutputLatencyChecked(bool new_value);
|
void onMinimalOutputLatencyChecked(bool new_value);
|
||||||
|
|
|
@ -2,6 +2,8 @@
|
||||||
#include "core/system.h"
|
#include "core/system.h"
|
||||||
#include <memory>
|
#include <memory>
|
||||||
#include <mutex>
|
#include <mutex>
|
||||||
|
#include <string>
|
||||||
|
#include <vector>
|
||||||
|
|
||||||
class SettingsInterface;
|
class SettingsInterface;
|
||||||
|
|
||||||
|
@ -33,6 +35,7 @@ void ReleaseHostDisplayResources();
|
||||||
#ifdef WITH_CUBEB
|
#ifdef WITH_CUBEB
|
||||||
std::unique_ptr<AudioStream> CreateCubebAudioStream(u32 sample_rate, u32 channels, u32 buffer_ms, u32 latency_ms,
|
std::unique_ptr<AudioStream> CreateCubebAudioStream(u32 sample_rate, u32 channels, u32 buffer_ms, u32 latency_ms,
|
||||||
AudioStretchMode stretch);
|
AudioStretchMode stretch);
|
||||||
|
std::vector<std::string> GetCubebDriverNames();
|
||||||
#endif
|
#endif
|
||||||
#ifdef _WIN32
|
#ifdef _WIN32
|
||||||
std::unique_ptr<AudioStream> CreateXAudio2Stream(u32 sample_rate, u32 channels, u32 buffer_ms, u32 latency_ms,
|
std::unique_ptr<AudioStream> CreateXAudio2Stream(u32 sample_rate, u32 channels, u32 buffer_ms, u32 latency_ms,
|
||||||
|
|
|
@ -4,7 +4,7 @@
|
||||||
#include "common/string_util.h"
|
#include "common/string_util.h"
|
||||||
#include "common_host.h"
|
#include "common_host.h"
|
||||||
#include "core/host.h"
|
#include "core/host.h"
|
||||||
#include "core/host_settings.h"
|
#include "core/settings.h"
|
||||||
#include "cubeb/cubeb.h"
|
#include "cubeb/cubeb.h"
|
||||||
Log_SetChannel(CubebAudioStream);
|
Log_SetChannel(CubebAudioStream);
|
||||||
|
|
||||||
|
@ -73,9 +73,8 @@ bool CubebAudioStream::Initialize(u32 latency_ms)
|
||||||
|
|
||||||
cubeb_set_log_callback(CUBEB_LOG_NORMAL, LogCallback);
|
cubeb_set_log_callback(CUBEB_LOG_NORMAL, LogCallback);
|
||||||
|
|
||||||
std::string backend(Host::GetStringSettingValue("Audio", "CubebBackend"));
|
int rv =
|
||||||
|
cubeb_init(&m_context, "DuckStation", g_settings.audio_driver.empty() ? nullptr : g_settings.audio_driver.c_str());
|
||||||
int rv = cubeb_init(&m_context, "DuckStation", backend.empty() ? nullptr : backend.c_str());
|
|
||||||
if (rv != CUBEB_OK)
|
if (rv != CUBEB_OK)
|
||||||
{
|
{
|
||||||
Host::ReportFormattedErrorAsync("Error", "Could not initialize cubeb context: %d", rv);
|
Host::ReportFormattedErrorAsync("Error", "Could not initialize cubeb context: %d", rv);
|
||||||
|
@ -199,3 +198,12 @@ std::unique_ptr<AudioStream> CommonHost::CreateCubebAudioStream(u32 sample_rate,
|
||||||
stream.reset();
|
stream.reset();
|
||||||
return stream;
|
return stream;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
std::vector<std::string> CommonHost::GetCubebDriverNames()
|
||||||
|
{
|
||||||
|
std::vector<std::string> names;
|
||||||
|
const char** cubeb_names = cubeb_get_backend_names();
|
||||||
|
for (u32 i = 0; cubeb_names[i] != nullptr; i++)
|
||||||
|
names.emplace_back(cubeb_names[i]);
|
||||||
|
return names;
|
||||||
|
}
|
||||||
|
|
Loading…
Reference in a new issue