Merge pull request #5711 from LAGonauta/latency-setting-only-on-windows
Hide audio latency setting when no backend supports it
This commit is contained in:
commit
d9d4bd7eef
|
@ -24,6 +24,7 @@
|
||||||
|
|
||||||
AudioPane::AudioPane()
|
AudioPane::AudioPane()
|
||||||
{
|
{
|
||||||
|
CheckNeedForLatencyControl();
|
||||||
CreateWidgets();
|
CreateWidgets();
|
||||||
LoadSettings();
|
LoadSettings();
|
||||||
ConnectWidgets();
|
ConnectWidgets();
|
||||||
|
@ -69,19 +70,23 @@ void AudioPane::CreateWidgets()
|
||||||
backend_box->setLayout(backend_layout);
|
backend_box->setLayout(backend_layout);
|
||||||
m_backend_label = new QLabel(tr("Audio Backend:"));
|
m_backend_label = new QLabel(tr("Audio Backend:"));
|
||||||
m_backend_combo = new QComboBox();
|
m_backend_combo = new QComboBox();
|
||||||
m_latency_label = new QLabel(tr("Latency:"));
|
|
||||||
m_dolby_pro_logic = new QCheckBox(tr("Dolby Pro Logic II Decoder"));
|
m_dolby_pro_logic = new QCheckBox(tr("Dolby Pro Logic II Decoder"));
|
||||||
m_latency_spin = new QSpinBox();
|
|
||||||
|
|
||||||
|
if (m_latency_control_supported)
|
||||||
|
{
|
||||||
|
m_latency_label = new QLabel(tr("Latency:"));
|
||||||
|
m_latency_spin = new QSpinBox();
|
||||||
m_latency_spin->setMinimum(0);
|
m_latency_spin->setMinimum(0);
|
||||||
m_latency_spin->setMaximum(30);
|
m_latency_spin->setMaximum(200);
|
||||||
m_latency_spin->setToolTip(tr("Sets the latency (in ms). Higher values may reduce audio "
|
m_latency_spin->setToolTip(tr("Sets the latency (in ms). Higher values may reduce audio "
|
||||||
"crackling. Certain backends only."));
|
"crackling. Certain backends only."));
|
||||||
|
}
|
||||||
|
|
||||||
m_dolby_pro_logic->setToolTip(
|
m_dolby_pro_logic->setToolTip(
|
||||||
tr("Enables Dolby Pro Logic II emulation using 5.1 surround. Certain backends only."));
|
tr("Enables Dolby Pro Logic II emulation using 5.1 surround. Certain backends only."));
|
||||||
|
|
||||||
backend_layout->addRow(m_backend_label, m_backend_combo);
|
backend_layout->addRow(m_backend_label, m_backend_combo);
|
||||||
|
if (m_latency_control_supported)
|
||||||
backend_layout->addRow(m_latency_label, m_latency_spin);
|
backend_layout->addRow(m_latency_label, m_latency_spin);
|
||||||
backend_layout->addRow(m_dolby_pro_logic);
|
backend_layout->addRow(m_dolby_pro_logic);
|
||||||
|
|
||||||
|
@ -122,8 +127,11 @@ void AudioPane::ConnectWidgets()
|
||||||
connect(m_backend_combo, static_cast<void (QComboBox::*)(int)>(&QComboBox::currentIndexChanged),
|
connect(m_backend_combo, static_cast<void (QComboBox::*)(int)>(&QComboBox::currentIndexChanged),
|
||||||
this, &AudioPane::SaveSettings);
|
this, &AudioPane::SaveSettings);
|
||||||
connect(m_volume_slider, &QSlider::valueChanged, this, &AudioPane::SaveSettings);
|
connect(m_volume_slider, &QSlider::valueChanged, this, &AudioPane::SaveSettings);
|
||||||
|
if (m_latency_control_supported)
|
||||||
|
{
|
||||||
connect(m_latency_spin, static_cast<void (QSpinBox::*)(int)>(&QSpinBox::valueChanged), this,
|
connect(m_latency_spin, static_cast<void (QSpinBox::*)(int)>(&QSpinBox::valueChanged), this,
|
||||||
&AudioPane::SaveSettings);
|
&AudioPane::SaveSettings);
|
||||||
|
}
|
||||||
connect(m_stretching_buffer_slider, &QSlider::valueChanged, this, &AudioPane::SaveSettings);
|
connect(m_stretching_buffer_slider, &QSlider::valueChanged, this, &AudioPane::SaveSettings);
|
||||||
connect(m_dolby_pro_logic, &QCheckBox::toggled, this, &AudioPane::SaveSettings);
|
connect(m_dolby_pro_logic, &QCheckBox::toggled, this, &AudioPane::SaveSettings);
|
||||||
connect(m_stretching_enable, &QCheckBox::toggled, this, &AudioPane::SaveSettings);
|
connect(m_stretching_enable, &QCheckBox::toggled, this, &AudioPane::SaveSettings);
|
||||||
|
@ -165,6 +173,7 @@ void AudioPane::LoadSettings()
|
||||||
m_dolby_pro_logic->setChecked(SConfig::GetInstance().bDPL2Decoder);
|
m_dolby_pro_logic->setChecked(SConfig::GetInstance().bDPL2Decoder);
|
||||||
|
|
||||||
// Latency
|
// Latency
|
||||||
|
if (m_latency_control_supported)
|
||||||
m_latency_spin->setValue(SConfig::GetInstance().iLatency);
|
m_latency_spin->setValue(SConfig::GetInstance().iLatency);
|
||||||
|
|
||||||
// Stretch
|
// Stretch
|
||||||
|
@ -204,6 +213,7 @@ void AudioPane::SaveSettings()
|
||||||
SConfig::GetInstance().bDPL2Decoder = m_dolby_pro_logic->isChecked();
|
SConfig::GetInstance().bDPL2Decoder = m_dolby_pro_logic->isChecked();
|
||||||
|
|
||||||
// Latency
|
// Latency
|
||||||
|
if (m_latency_control_supported)
|
||||||
SConfig::GetInstance().iLatency = m_latency_spin->value();
|
SConfig::GetInstance().iLatency = m_latency_spin->value();
|
||||||
|
|
||||||
// Stretch
|
// Stretch
|
||||||
|
@ -223,8 +233,11 @@ void AudioPane::OnBackendChanged()
|
||||||
const auto backend = SConfig::GetInstance().sBackend;
|
const auto backend = SConfig::GetInstance().sBackend;
|
||||||
|
|
||||||
m_dolby_pro_logic->setEnabled(AudioCommon::SupportsDPL2Decoder(backend));
|
m_dolby_pro_logic->setEnabled(AudioCommon::SupportsDPL2Decoder(backend));
|
||||||
|
if (m_latency_control_supported)
|
||||||
|
{
|
||||||
m_latency_label->setEnabled(AudioCommon::SupportsLatencyControl(backend));
|
m_latency_label->setEnabled(AudioCommon::SupportsLatencyControl(backend));
|
||||||
m_latency_spin->setEnabled(AudioCommon::SupportsLatencyControl(backend));
|
m_latency_spin->setEnabled(AudioCommon::SupportsLatencyControl(backend));
|
||||||
|
}
|
||||||
m_volume_slider->setEnabled(AudioCommon::SupportsVolumeChanges(backend));
|
m_volume_slider->setEnabled(AudioCommon::SupportsVolumeChanges(backend));
|
||||||
m_volume_indicator->setEnabled(AudioCommon::SupportsVolumeChanges(backend));
|
m_volume_indicator->setEnabled(AudioCommon::SupportsVolumeChanges(backend));
|
||||||
}
|
}
|
||||||
|
@ -237,12 +250,22 @@ void AudioPane::OnEmulationStateChanged(bool running)
|
||||||
m_dolby_pro_logic->setEnabled(!running);
|
m_dolby_pro_logic->setEnabled(!running);
|
||||||
m_backend_label->setEnabled(!running);
|
m_backend_label->setEnabled(!running);
|
||||||
m_backend_combo->setEnabled(!running);
|
m_backend_combo->setEnabled(!running);
|
||||||
|
if (m_latency_control_supported)
|
||||||
|
{
|
||||||
m_latency_label->setEnabled(!running);
|
m_latency_label->setEnabled(!running);
|
||||||
m_latency_spin->setEnabled(!running);
|
m_latency_spin->setEnabled(!running);
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
|
||||||
void AudioPane::OnVolumeChanged(int volume)
|
void AudioPane::OnVolumeChanged(int volume)
|
||||||
{
|
{
|
||||||
m_volume_slider->setValue(volume);
|
m_volume_slider->setValue(volume);
|
||||||
m_volume_indicator->setText(tr("%1 %").arg(volume));
|
m_volume_indicator->setText(tr("%1 %").arg(volume));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void AudioPane::CheckNeedForLatencyControl()
|
||||||
|
{
|
||||||
|
std::vector<std::string> backends = AudioCommon::GetSoundBackends();
|
||||||
|
m_latency_control_supported =
|
||||||
|
std::any_of(backends.cbegin(), backends.cend(), AudioCommon::SupportsLatencyControl);
|
||||||
|
}
|
||||||
|
|
|
@ -32,6 +32,9 @@ private:
|
||||||
void OnBackendChanged();
|
void OnBackendChanged();
|
||||||
void OnVolumeChanged(int volume);
|
void OnVolumeChanged(int volume);
|
||||||
|
|
||||||
|
void CheckNeedForLatencyControl();
|
||||||
|
bool m_latency_control_supported;
|
||||||
|
|
||||||
QGridLayout* m_main_layout;
|
QGridLayout* m_main_layout;
|
||||||
|
|
||||||
// DSP Engine
|
// DSP Engine
|
||||||
|
|
|
@ -24,6 +24,7 @@
|
||||||
|
|
||||||
AudioConfigPane::AudioConfigPane(wxWindow* parent, wxWindowID id) : wxPanel(parent, id)
|
AudioConfigPane::AudioConfigPane(wxWindow* parent, wxWindowID id) : wxPanel(parent, id)
|
||||||
{
|
{
|
||||||
|
CheckNeedForLatencyControl();
|
||||||
InitializeGUI();
|
InitializeGUI();
|
||||||
LoadGUIValues();
|
LoadGUIValues();
|
||||||
BindEvents();
|
BindEvents();
|
||||||
|
@ -44,9 +45,12 @@ void AudioConfigPane::InitializeGUI()
|
||||||
m_volume_text = new wxStaticText(this, wxID_ANY, "");
|
m_volume_text = new wxStaticText(this, wxID_ANY, "");
|
||||||
m_audio_backend_choice =
|
m_audio_backend_choice =
|
||||||
new wxChoice(this, wxID_ANY, wxDefaultPosition, wxDefaultSize, m_audio_backend_strings);
|
new wxChoice(this, wxID_ANY, wxDefaultPosition, wxDefaultSize, m_audio_backend_strings);
|
||||||
m_audio_latency_spinctrl =
|
if (m_latency_control_supported)
|
||||||
new wxSpinCtrl(this, wxID_ANY, "", wxDefaultPosition, wxDefaultSize, wxSP_ARROW_KEYS, 0, 200);
|
{
|
||||||
|
m_audio_latency_spinctrl = new wxSpinCtrl(this, wxID_ANY, "", wxDefaultPosition, wxDefaultSize,
|
||||||
|
wxSP_ARROW_KEYS, 0, 200);
|
||||||
m_audio_latency_label = new wxStaticText(this, wxID_ANY, _("Latency (ms):"));
|
m_audio_latency_label = new wxStaticText(this, wxID_ANY, _("Latency (ms):"));
|
||||||
|
}
|
||||||
|
|
||||||
m_stretch_checkbox = new wxCheckBox(this, wxID_ANY, _("Enable Audio Stretching"));
|
m_stretch_checkbox = new wxCheckBox(this, wxID_ANY, _("Enable Audio Stretching"));
|
||||||
m_stretch_label = new wxStaticText(this, wxID_ANY, _("Buffer Size:"));
|
m_stretch_label = new wxStaticText(this, wxID_ANY, _("Buffer Size:"));
|
||||||
|
@ -54,8 +58,12 @@ void AudioConfigPane::InitializeGUI()
|
||||||
new DolphinSlider(this, wxID_ANY, 80, 5, 300, wxDefaultPosition, wxDefaultSize);
|
new DolphinSlider(this, wxID_ANY, 80, 5, 300, wxDefaultPosition, wxDefaultSize);
|
||||||
m_stretch_text = new wxStaticText(this, wxID_ANY, "");
|
m_stretch_text = new wxStaticText(this, wxID_ANY, "");
|
||||||
|
|
||||||
m_audio_latency_spinctrl->SetToolTip(_("Sets the latency (in ms). Higher values may reduce audio "
|
if (m_latency_control_supported)
|
||||||
|
{
|
||||||
|
m_audio_latency_spinctrl->SetToolTip(
|
||||||
|
_("Sets the latency (in ms). Higher values may reduce audio "
|
||||||
"crackling. Certain backends only."));
|
"crackling. Certain backends only."));
|
||||||
|
}
|
||||||
m_dpl2_decoder_checkbox->SetToolTip(
|
m_dpl2_decoder_checkbox->SetToolTip(
|
||||||
_("Enables Dolby Pro Logic II emulation using 5.1 surround. Certain backends only."));
|
_("Enables Dolby Pro Logic II emulation using 5.1 surround. Certain backends only."));
|
||||||
m_stretch_checkbox->SetToolTip(_("Enables stretching of the audio to match emulation speed."));
|
m_stretch_checkbox->SetToolTip(_("Enables stretching of the audio to match emulation speed."));
|
||||||
|
@ -76,10 +84,13 @@ void AudioConfigPane::InitializeGUI()
|
||||||
wxALIGN_CENTER_VERTICAL);
|
wxALIGN_CENTER_VERTICAL);
|
||||||
backend_grid_sizer->Add(m_dpl2_decoder_checkbox, wxGBPosition(1, 0), wxGBSpan(1, 2),
|
backend_grid_sizer->Add(m_dpl2_decoder_checkbox, wxGBPosition(1, 0), wxGBSpan(1, 2),
|
||||||
wxALIGN_CENTER_VERTICAL);
|
wxALIGN_CENTER_VERTICAL);
|
||||||
|
if (m_latency_control_supported)
|
||||||
|
{
|
||||||
backend_grid_sizer->Add(m_audio_latency_label, wxGBPosition(2, 0), wxDefaultSpan,
|
backend_grid_sizer->Add(m_audio_latency_label, wxGBPosition(2, 0), wxDefaultSpan,
|
||||||
wxALIGN_CENTER_VERTICAL);
|
wxALIGN_CENTER_VERTICAL);
|
||||||
backend_grid_sizer->Add(m_audio_latency_spinctrl, wxGBPosition(2, 1), wxDefaultSpan,
|
backend_grid_sizer->Add(m_audio_latency_spinctrl, wxGBPosition(2, 1), wxDefaultSpan,
|
||||||
wxALIGN_CENTER_VERTICAL);
|
wxALIGN_CENTER_VERTICAL);
|
||||||
|
}
|
||||||
|
|
||||||
wxStaticBoxSizer* const backend_static_box_sizer =
|
wxStaticBoxSizer* const backend_static_box_sizer =
|
||||||
new wxStaticBoxSizer(wxVERTICAL, this, _("Backend Settings"));
|
new wxStaticBoxSizer(wxVERTICAL, this, _("Backend Settings"));
|
||||||
|
@ -139,7 +150,10 @@ void AudioConfigPane::LoadGUIValues()
|
||||||
m_volume_slider->SetValue(SConfig::GetInstance().m_Volume);
|
m_volume_slider->SetValue(SConfig::GetInstance().m_Volume);
|
||||||
m_volume_text->SetLabel(wxString::Format("%d %%", SConfig::GetInstance().m_Volume));
|
m_volume_text->SetLabel(wxString::Format("%d %%", SConfig::GetInstance().m_Volume));
|
||||||
m_dpl2_decoder_checkbox->SetValue(startup_params.bDPL2Decoder);
|
m_dpl2_decoder_checkbox->SetValue(startup_params.bDPL2Decoder);
|
||||||
|
if (m_latency_control_supported)
|
||||||
|
{
|
||||||
m_audio_latency_spinctrl->SetValue(startup_params.iLatency);
|
m_audio_latency_spinctrl->SetValue(startup_params.iLatency);
|
||||||
|
}
|
||||||
m_stretch_checkbox->SetValue(startup_params.m_audio_stretch);
|
m_stretch_checkbox->SetValue(startup_params.m_audio_stretch);
|
||||||
m_stretch_slider->Enable(startup_params.m_audio_stretch);
|
m_stretch_slider->Enable(startup_params.m_audio_stretch);
|
||||||
m_stretch_slider->SetValue(startup_params.m_audio_stretch_max_latency);
|
m_stretch_slider->SetValue(startup_params.m_audio_stretch_max_latency);
|
||||||
|
@ -152,9 +166,12 @@ void AudioConfigPane::ToggleBackendSpecificControls(const std::string& backend)
|
||||||
{
|
{
|
||||||
m_dpl2_decoder_checkbox->Enable(AudioCommon::SupportsDPL2Decoder(backend));
|
m_dpl2_decoder_checkbox->Enable(AudioCommon::SupportsDPL2Decoder(backend));
|
||||||
|
|
||||||
|
if (m_latency_control_supported)
|
||||||
|
{
|
||||||
bool supports_latency_control = AudioCommon::SupportsLatencyControl(backend);
|
bool supports_latency_control = AudioCommon::SupportsLatencyControl(backend);
|
||||||
m_audio_latency_spinctrl->Enable(supports_latency_control);
|
m_audio_latency_spinctrl->Enable(supports_latency_control);
|
||||||
m_audio_latency_label->Enable(supports_latency_control);
|
m_audio_latency_label->Enable(supports_latency_control);
|
||||||
|
}
|
||||||
|
|
||||||
bool supports_volume_changes = AudioCommon::SupportsVolumeChanges(backend);
|
bool supports_volume_changes = AudioCommon::SupportsVolumeChanges(backend);
|
||||||
m_volume_slider->Enable(supports_volume_changes);
|
m_volume_slider->Enable(supports_volume_changes);
|
||||||
|
@ -175,8 +192,12 @@ void AudioConfigPane::BindEvents()
|
||||||
m_audio_backend_choice->Bind(wxEVT_CHOICE, &AudioConfigPane::OnAudioBackendChanged, this);
|
m_audio_backend_choice->Bind(wxEVT_CHOICE, &AudioConfigPane::OnAudioBackendChanged, this);
|
||||||
m_audio_backend_choice->Bind(wxEVT_UPDATE_UI, &WxEventUtils::OnEnableIfCoreNotRunning);
|
m_audio_backend_choice->Bind(wxEVT_UPDATE_UI, &WxEventUtils::OnEnableIfCoreNotRunning);
|
||||||
|
|
||||||
m_audio_latency_spinctrl->Bind(wxEVT_SPINCTRL, &AudioConfigPane::OnLatencySpinCtrlChanged, this);
|
if (m_latency_control_supported)
|
||||||
|
{
|
||||||
|
m_audio_latency_spinctrl->Bind(wxEVT_SPINCTRL, &AudioConfigPane::OnLatencySpinCtrlChanged,
|
||||||
|
this);
|
||||||
m_audio_latency_spinctrl->Bind(wxEVT_UPDATE_UI, &WxEventUtils::OnEnableIfCoreNotRunning);
|
m_audio_latency_spinctrl->Bind(wxEVT_UPDATE_UI, &WxEventUtils::OnEnableIfCoreNotRunning);
|
||||||
|
}
|
||||||
|
|
||||||
m_stretch_checkbox->Bind(wxEVT_CHECKBOX, &AudioConfigPane::OnStretchCheckBoxChanged, this);
|
m_stretch_checkbox->Bind(wxEVT_CHECKBOX, &AudioConfigPane::OnStretchCheckBoxChanged, this);
|
||||||
m_stretch_slider->Bind(wxEVT_SLIDER, &AudioConfigPane::OnStretchSliderChanged, this);
|
m_stretch_slider->Bind(wxEVT_SLIDER, &AudioConfigPane::OnStretchSliderChanged, this);
|
||||||
|
@ -241,3 +262,10 @@ void AudioConfigPane::PopulateBackendChoiceBox()
|
||||||
int num = m_audio_backend_choice->FindString(StrToWxStr(SConfig::GetInstance().sBackend));
|
int num = m_audio_backend_choice->FindString(StrToWxStr(SConfig::GetInstance().sBackend));
|
||||||
m_audio_backend_choice->SetSelection(num);
|
m_audio_backend_choice->SetSelection(num);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void AudioConfigPane::CheckNeedForLatencyControl()
|
||||||
|
{
|
||||||
|
std::vector<std::string> backends = AudioCommon::GetSoundBackends();
|
||||||
|
m_latency_control_supported =
|
||||||
|
std::any_of(backends.cbegin(), backends.cend(), AudioCommon::SupportsLatencyControl);
|
||||||
|
}
|
||||||
|
|
|
@ -26,6 +26,7 @@ private:
|
||||||
void BindEvents();
|
void BindEvents();
|
||||||
|
|
||||||
void PopulateBackendChoiceBox();
|
void PopulateBackendChoiceBox();
|
||||||
|
void CheckNeedForLatencyControl();
|
||||||
void ToggleBackendSpecificControls(const std::string& backend);
|
void ToggleBackendSpecificControls(const std::string& backend);
|
||||||
|
|
||||||
void OnDSPEngineRadioBoxChanged(wxCommandEvent&);
|
void OnDSPEngineRadioBoxChanged(wxCommandEvent&);
|
||||||
|
@ -50,4 +51,6 @@ private:
|
||||||
wxStaticText* m_stretch_label;
|
wxStaticText* m_stretch_label;
|
||||||
DolphinSlider* m_stretch_slider;
|
DolphinSlider* m_stretch_slider;
|
||||||
wxStaticText* m_stretch_text;
|
wxStaticText* m_stretch_text;
|
||||||
|
|
||||||
|
bool m_latency_control_supported;
|
||||||
};
|
};
|
||||||
|
|
Loading…
Reference in New Issue