Fix resetting emulated wii remote settings to default not updating Extension combo box

This commit is contained in:
Antonio Maiorano 2018-10-02 23:32:00 -04:00
parent 58b0a284a8
commit f257630c0a
2 changed files with 11 additions and 5 deletions

View File

@ -13,6 +13,7 @@
#include "Core/HW/Wiimote.h" #include "Core/HW/Wiimote.h"
#include "Core/HW/WiimoteEmu/WiimoteEmu.h" #include "Core/HW/WiimoteEmu/WiimoteEmu.h"
#include "DolphinQt/Config/Mapping/MappingWindow.h"
#include "DolphinQt/Config/Mapping/WiimoteEmuExtension.h" #include "DolphinQt/Config/Mapping/WiimoteEmuExtension.h"
#include "InputCommon/ControllerEmu/ControlGroup/Extension.h" #include "InputCommon/ControllerEmu/ControlGroup/Extension.h"
@ -23,7 +24,7 @@ WiimoteEmuGeneral::WiimoteEmuGeneral(MappingWindow* window, WiimoteEmuExtension*
: MappingWidget(window), m_extension_widget(extension) : MappingWidget(window), m_extension_widget(extension)
{ {
CreateMainLayout(); CreateMainLayout();
Connect(); Connect(window);
} }
void WiimoteEmuGeneral::CreateMainLayout() void WiimoteEmuGeneral::CreateMainLayout()
@ -66,10 +67,11 @@ void WiimoteEmuGeneral::CreateMainLayout()
setLayout(m_main_layout); setLayout(m_main_layout);
} }
void WiimoteEmuGeneral::Connect() void WiimoteEmuGeneral::Connect(MappingWindow* window)
{ {
connect(m_extension_combo, static_cast<void (QComboBox::*)(int)>(&QComboBox::currentIndexChanged), connect(m_extension_combo, static_cast<void (QComboBox::*)(int)>(&QComboBox::currentIndexChanged),
this, &WiimoteEmuGeneral::OnAttachmentChanged); this, &WiimoteEmuGeneral::OnAttachmentChanged);
connect(window, &MappingWindow::Update, this, &WiimoteEmuGeneral::Update);
} }
void WiimoteEmuGeneral::OnAttachmentChanged(int extension) void WiimoteEmuGeneral::OnAttachmentChanged(int extension)
@ -92,14 +94,17 @@ void WiimoteEmuGeneral::OnAttachmentChanged(int extension)
SaveSettings(); SaveSettings();
} }
void WiimoteEmuGeneral::LoadSettings() void WiimoteEmuGeneral::Update()
{ {
auto* ce_extension = static_cast<ControllerEmu::Extension*>( auto* ce_extension = static_cast<ControllerEmu::Extension*>(
Wiimote::GetWiimoteGroup(GetPort(), WiimoteEmu::WiimoteGroup::Extension)); Wiimote::GetWiimoteGroup(GetPort(), WiimoteEmu::WiimoteGroup::Extension));
m_extension_combo->setCurrentIndex(ce_extension->switch_extension); m_extension_combo->setCurrentIndex(ce_extension->switch_extension);
OnAttachmentChanged(ce_extension->switch_extension); }
void WiimoteEmuGeneral::LoadSettings()
{
Update();
Wiimote::LoadConfig(); Wiimote::LoadConfig();
} }

View File

@ -22,8 +22,9 @@ private:
void LoadSettings() override; void LoadSettings() override;
void SaveSettings() override; void SaveSettings() override;
void CreateMainLayout(); void CreateMainLayout();
void Connect(); void Connect(MappingWindow* window);
void OnAttachmentChanged(int index); void OnAttachmentChanged(int index);
void Update();
// Main // Main
QHBoxLayout* m_main_layout; QHBoxLayout* m_main_layout;