AudioConfigPane: dedupe code into ToggleBackendSpecificControls
This commit is contained in:
parent
283c681f30
commit
4834a90e63
|
@ -115,9 +115,9 @@ void AudioConfigPane::InitializeGUI()
|
||||||
|
|
||||||
void AudioConfigPane::LoadGUIValues()
|
void AudioConfigPane::LoadGUIValues()
|
||||||
{
|
{
|
||||||
PopulateBackendChoiceBox();
|
|
||||||
|
|
||||||
const SConfig& startup_params = SConfig::GetInstance();
|
const SConfig& startup_params = SConfig::GetInstance();
|
||||||
|
PopulateBackendChoiceBox();
|
||||||
|
ToggleBackendSpecificControls(SConfig::GetInstance().sBackend);
|
||||||
|
|
||||||
// Audio DSP Engine
|
// Audio DSP Engine
|
||||||
if (startup_params.bDSPHLE)
|
if (startup_params.bDSPHLE)
|
||||||
|
@ -125,20 +125,24 @@ void AudioConfigPane::LoadGUIValues()
|
||||||
else
|
else
|
||||||
m_dsp_engine_radiobox->SetSelection(SConfig::GetInstance().m_DSPEnableJIT ? 1 : 2);
|
m_dsp_engine_radiobox->SetSelection(SConfig::GetInstance().m_DSPEnableJIT ? 1 : 2);
|
||||||
|
|
||||||
m_volume_slider->Enable(SupportsVolumeChanges(SConfig::GetInstance().sBackend));
|
|
||||||
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->Enable(std::string(SConfig::GetInstance().sBackend) == BACKEND_OPENAL ||
|
|
||||||
std::string(SConfig::GetInstance().sBackend) ==
|
|
||||||
BACKEND_PULSEAUDIO);
|
|
||||||
m_dpl2_decoder_checkbox->SetValue(startup_params.bDPL2Decoder);
|
m_dpl2_decoder_checkbox->SetValue(startup_params.bDPL2Decoder);
|
||||||
|
|
||||||
m_audio_latency_spinctrl->Enable(std::string(SConfig::GetInstance().sBackend) == BACKEND_OPENAL);
|
|
||||||
m_audio_latency_spinctrl->SetValue(startup_params.iLatency);
|
m_audio_latency_spinctrl->SetValue(startup_params.iLatency);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void AudioConfigPane::ToggleBackendSpecificControls(const std::string& backend)
|
||||||
|
{
|
||||||
|
m_dpl2_decoder_checkbox->Enable(backend == BACKEND_OPENAL || backend == BACKEND_PULSEAUDIO);
|
||||||
|
m_audio_latency_spinctrl->Enable(backend == BACKEND_OPENAL);
|
||||||
|
|
||||||
|
// FIXME: this one should ask the backend whether it supports it.
|
||||||
|
// but getting the backend from string etc. is probably
|
||||||
|
// too much just to enable/disable a stupid slider...
|
||||||
|
m_volume_slider->Enable(backend == BACKEND_COREAUDIO || backend == BACKEND_OPENAL ||
|
||||||
|
backend == BACKEND_XAUDIO2);
|
||||||
|
}
|
||||||
|
|
||||||
void AudioConfigPane::RefreshGUI()
|
void AudioConfigPane::RefreshGUI()
|
||||||
{
|
{
|
||||||
if (Core::IsRunning())
|
if (Core::IsRunning())
|
||||||
|
@ -171,19 +175,11 @@ void AudioConfigPane::OnVolumeSliderChanged(wxCommandEvent& event)
|
||||||
|
|
||||||
void AudioConfigPane::OnAudioBackendChanged(wxCommandEvent& event)
|
void AudioConfigPane::OnAudioBackendChanged(wxCommandEvent& event)
|
||||||
{
|
{
|
||||||
m_volume_slider->Enable(
|
|
||||||
SupportsVolumeChanges(WxStrToStr(m_audio_backend_choice->GetStringSelection())));
|
|
||||||
m_audio_latency_spinctrl->Enable(WxStrToStr(m_audio_backend_choice->GetStringSelection()) ==
|
|
||||||
BACKEND_OPENAL);
|
|
||||||
m_dpl2_decoder_checkbox->Enable(
|
|
||||||
WxStrToStr(m_audio_backend_choice->GetStringSelection()) == BACKEND_OPENAL ||
|
|
||||||
WxStrToStr(m_audio_backend_choice->GetStringSelection()) == BACKEND_PULSEAUDIO);
|
|
||||||
|
|
||||||
// Don't save the translated BACKEND_NULLSOUND string
|
// Don't save the translated BACKEND_NULLSOUND string
|
||||||
SConfig::GetInstance().sBackend = m_audio_backend_choice->GetSelection() ?
|
SConfig::GetInstance().sBackend = m_audio_backend_choice->GetSelection() ?
|
||||||
WxStrToStr(m_audio_backend_choice->GetStringSelection()) :
|
WxStrToStr(m_audio_backend_choice->GetStringSelection()) :
|
||||||
BACKEND_NULLSOUND;
|
BACKEND_NULLSOUND;
|
||||||
|
ToggleBackendSpecificControls(WxStrToStr(m_audio_backend_choice->GetStringSelection()));
|
||||||
AudioCommon::UpdateSoundStream();
|
AudioCommon::UpdateSoundStream();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -202,11 +198,3 @@ 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);
|
||||||
}
|
}
|
||||||
|
|
||||||
bool AudioConfigPane::SupportsVolumeChanges(const std::string& backend)
|
|
||||||
{
|
|
||||||
// FIXME: this one should ask the backend whether it supports it.
|
|
||||||
// but getting the backend from string etc. is probably
|
|
||||||
// too much just to enable/disable a stupid slider...
|
|
||||||
return (backend == BACKEND_COREAUDIO || backend == BACKEND_OPENAL || backend == BACKEND_XAUDIO2);
|
|
||||||
}
|
|
||||||
|
|
|
@ -26,7 +26,7 @@ private:
|
||||||
void RefreshGUI();
|
void RefreshGUI();
|
||||||
|
|
||||||
void PopulateBackendChoiceBox();
|
void PopulateBackendChoiceBox();
|
||||||
static bool SupportsVolumeChanges(const std::string&);
|
void ToggleBackendSpecificControls(const std::string& backend);
|
||||||
|
|
||||||
void OnDSPEngineRadioBoxChanged(wxCommandEvent&);
|
void OnDSPEngineRadioBoxChanged(wxCommandEvent&);
|
||||||
void OnDPL2DecoderCheckBoxChanged(wxCommandEvent&);
|
void OnDPL2DecoderCheckBoxChanged(wxCommandEvent&);
|
||||||
|
|
Loading…
Reference in New Issue