Frontend: Add controller settings
This commit is contained in:
parent
a347b3606e
commit
1d2bd11b02
|
@ -33,11 +33,11 @@ void Settings::SetDefaults()
|
||||||
bios_patch_tty_enable = false;
|
bios_patch_tty_enable = false;
|
||||||
bios_patch_fast_boot = false;
|
bios_patch_fast_boot = false;
|
||||||
|
|
||||||
controller_a_type = ControllerType::DigitalController;
|
controller_1_type = ControllerType::DigitalController;
|
||||||
controller_b_type = ControllerType::None;
|
controller_2_type = ControllerType::None;
|
||||||
|
|
||||||
memory_card_a_path = "memory_card_a.mcd";
|
memory_card_1_path = "memory_card_1.mcd";
|
||||||
memory_card_b_path.clear();
|
memory_card_2_path.clear();
|
||||||
}
|
}
|
||||||
|
|
||||||
void Settings::Load(const char* filename)
|
void Settings::Load(const char* filename)
|
||||||
|
@ -72,13 +72,13 @@ void Settings::Load(const char* filename)
|
||||||
bios_patch_tty_enable = ini.GetBoolValue("BIOS", "PatchTTYEnable", true);
|
bios_patch_tty_enable = ini.GetBoolValue("BIOS", "PatchTTYEnable", true);
|
||||||
bios_patch_fast_boot = ini.GetBoolValue("BIOS", "PatchFastBoot", false);
|
bios_patch_fast_boot = ini.GetBoolValue("BIOS", "PatchFastBoot", false);
|
||||||
|
|
||||||
controller_a_type = ParseControllerTypeName(ini.GetValue("Controller", "PortAType", "DigitalController"))
|
controller_1_type = ParseControllerTypeName(ini.GetValue("Ports", "Controller1Type", "DigitalController"))
|
||||||
.value_or(ControllerType::DigitalController);
|
.value_or(ControllerType::DigitalController);
|
||||||
controller_b_type =
|
controller_2_type =
|
||||||
ParseControllerTypeName(ini.GetValue("Controller", "PortBType", "None")).value_or(ControllerType::None);
|
ParseControllerTypeName(ini.GetValue("Ports", "Controller2Type", "None")).value_or(ControllerType::None);
|
||||||
|
|
||||||
memory_card_a_path = ini.GetValue("MemoryCard", "CardAPath", "memory_card_a.mcd");
|
memory_card_1_path = ini.GetValue("Ports", "MemoryCard1Path", "memory_card_1.mcd");
|
||||||
memory_card_b_path = ini.GetValue("MemoryCard", "CardBPath", "");
|
memory_card_2_path = ini.GetValue("Ports", "MemoryCard2Path", "");
|
||||||
}
|
}
|
||||||
|
|
||||||
bool Settings::Save(const char* filename) const
|
bool Settings::Save(const char* filename) const
|
||||||
|
@ -110,18 +110,25 @@ bool Settings::Save(const char* filename) const
|
||||||
ini.SetBoolValue("BIOS", "PatchTTYEnable", bios_patch_tty_enable);
|
ini.SetBoolValue("BIOS", "PatchTTYEnable", bios_patch_tty_enable);
|
||||||
ini.SetBoolValue("BIOS", "PatchFastBoot", bios_patch_fast_boot);
|
ini.SetBoolValue("BIOS", "PatchFastBoot", bios_patch_fast_boot);
|
||||||
|
|
||||||
ini.SetValue("Controller", "PortAType", GetControllerTypeName(controller_a_type));
|
if (controller_1_type != ControllerType::None)
|
||||||
ini.SetValue("Controller", "PortBType", GetControllerTypeName(controller_b_type));
|
ini.SetValue("Ports", "Controller1Type", GetControllerTypeName(controller_1_type));
|
||||||
|
|
||||||
if (!memory_card_a_path.empty())
|
|
||||||
ini.SetValue("MemoryCard", "CardAPath", memory_card_a_path.c_str());
|
|
||||||
else
|
else
|
||||||
ini.DeleteValue("MemoryCard", "CardAPath", nullptr);
|
ini.DeleteValue("Ports", "Controller1Type", nullptr);
|
||||||
|
|
||||||
if (!memory_card_b_path.empty())
|
if (controller_2_type != ControllerType::None)
|
||||||
ini.SetValue("MemoryCard", "CardBPath", memory_card_b_path.c_str());
|
ini.SetValue("Ports", "Controller2Type", GetControllerTypeName(controller_2_type));
|
||||||
else
|
else
|
||||||
ini.DeleteValue("MemoryCard", "CardBPath", nullptr);
|
ini.DeleteValue("Ports", "Controller2Type", nullptr);
|
||||||
|
|
||||||
|
if (!memory_card_1_path.empty())
|
||||||
|
ini.SetValue("Ports", "MemoryCard1Path", memory_card_1_path.c_str());
|
||||||
|
else
|
||||||
|
ini.DeleteValue("Ports", "MemoryCard1Path", nullptr);
|
||||||
|
|
||||||
|
if (!memory_card_2_path.empty())
|
||||||
|
ini.SetValue("Ports", "MemoryCard2Path", memory_card_2_path.c_str());
|
||||||
|
else
|
||||||
|
ini.DeleteValue("Ports", "MemoryCard2Path", nullptr);
|
||||||
|
|
||||||
err = ini.SaveFile(filename, false);
|
err = ini.SaveFile(filename, false);
|
||||||
if (err != SI_OK)
|
if (err != SI_OK)
|
||||||
|
|
|
@ -45,11 +45,11 @@ struct Settings
|
||||||
bool bios_patch_tty_enable = false;
|
bool bios_patch_tty_enable = false;
|
||||||
bool bios_patch_fast_boot = false;
|
bool bios_patch_fast_boot = false;
|
||||||
|
|
||||||
ControllerType controller_a_type = ControllerType::None;
|
ControllerType controller_1_type = ControllerType::None;
|
||||||
ControllerType controller_b_type = ControllerType::None;
|
ControllerType controller_2_type = ControllerType::None;
|
||||||
|
|
||||||
std::string memory_card_a_path;
|
std::string memory_card_1_path;
|
||||||
std::string memory_card_b_path;
|
std::string memory_card_2_path;
|
||||||
|
|
||||||
void SetDefaults();
|
void SetDefaults();
|
||||||
void Load(const char* filename);
|
void Load(const char* filename);
|
||||||
|
|
|
@ -463,16 +463,16 @@ void System::UpdateControllers()
|
||||||
m_pad->SetController(1, nullptr);
|
m_pad->SetController(1, nullptr);
|
||||||
|
|
||||||
const Settings& settings = m_host_interface->GetSettings();
|
const Settings& settings = m_host_interface->GetSettings();
|
||||||
if (settings.controller_a_type != ControllerType::None)
|
if (settings.controller_1_type != ControllerType::None)
|
||||||
{
|
{
|
||||||
std::unique_ptr<Controller> controller = Controller::Create(settings.controller_a_type);
|
std::unique_ptr<Controller> controller = Controller::Create(settings.controller_1_type);
|
||||||
if (controller)
|
if (controller)
|
||||||
m_pad->SetController(0, std::move(controller));
|
m_pad->SetController(0, std::move(controller));
|
||||||
}
|
}
|
||||||
|
|
||||||
if (settings.controller_b_type != ControllerType::None)
|
if (settings.controller_2_type != ControllerType::None)
|
||||||
{
|
{
|
||||||
std::unique_ptr<Controller> controller = Controller::Create(settings.controller_b_type);
|
std::unique_ptr<Controller> controller = Controller::Create(settings.controller_2_type);
|
||||||
if (controller)
|
if (controller)
|
||||||
m_pad->SetController(1, std::move(controller));
|
m_pad->SetController(1, std::move(controller));
|
||||||
}
|
}
|
||||||
|
@ -484,16 +484,16 @@ void System::UpdateMemoryCards()
|
||||||
m_pad->SetMemoryCard(1, nullptr);
|
m_pad->SetMemoryCard(1, nullptr);
|
||||||
|
|
||||||
const Settings& settings = m_host_interface->GetSettings();
|
const Settings& settings = m_host_interface->GetSettings();
|
||||||
if (!settings.memory_card_a_path.empty())
|
if (!settings.memory_card_1_path.empty())
|
||||||
{
|
{
|
||||||
std::unique_ptr<MemoryCard> card = MemoryCard::Open(this, settings.memory_card_a_path);
|
std::unique_ptr<MemoryCard> card = MemoryCard::Open(this, settings.memory_card_1_path);
|
||||||
if (card)
|
if (card)
|
||||||
m_pad->SetMemoryCard(0, std::move(card));
|
m_pad->SetMemoryCard(0, std::move(card));
|
||||||
}
|
}
|
||||||
|
|
||||||
if (!settings.memory_card_b_path.empty())
|
if (!settings.memory_card_2_path.empty())
|
||||||
{
|
{
|
||||||
std::unique_ptr<MemoryCard> card = MemoryCard::Open(this, settings.memory_card_b_path);
|
std::unique_ptr<MemoryCard> card = MemoryCard::Open(this, settings.memory_card_2_path);
|
||||||
if (card)
|
if (card)
|
||||||
m_pad->SetMemoryCard(1, std::move(card));
|
m_pad->SetMemoryCard(1, std::move(card));
|
||||||
}
|
}
|
||||||
|
|
|
@ -51,7 +51,8 @@ enum class ControllerType
|
||||||
{
|
{
|
||||||
None,
|
None,
|
||||||
DigitalController,
|
DigitalController,
|
||||||
AnalogController
|
AnalogController,
|
||||||
|
Count
|
||||||
};
|
};
|
||||||
|
|
||||||
enum : u32
|
enum : u32
|
||||||
|
|
|
@ -1109,19 +1109,42 @@ void SDLHostInterface::DrawSettingsWindow()
|
||||||
ImGui::EndTabItem();
|
ImGui::EndTabItem();
|
||||||
}
|
}
|
||||||
|
|
||||||
if (ImGui::BeginTabItem("Memory Cards"))
|
if (ImGui::BeginTabItem("Ports"))
|
||||||
{
|
{
|
||||||
for (int i = 0; i < 2; i++)
|
for (int i = 0; i < 2; i++)
|
||||||
{
|
{
|
||||||
if (!DrawSettingsSectionHeader(TinyString::FromFormat("Card %c", 'A' + i)))
|
if (DrawSettingsSectionHeader(TinyString::FromFormat("Front Port %d", 1 + i)))
|
||||||
continue;
|
{
|
||||||
|
ImGui::Text("Controller:");
|
||||||
|
ImGui::SameLine(indent);
|
||||||
|
|
||||||
ImGui::Text("Card %c", 'A' + i);
|
int controller_type = static_cast<int>((i == 0) ? m_settings.controller_1_type : m_settings.controller_2_type);
|
||||||
|
if (ImGui::Combo(
|
||||||
|
"##controller_type", &controller_type,
|
||||||
|
[](void*, int index, const char** out_text) {
|
||||||
|
*out_text = Settings::GetControllerTypeDisplayName(static_cast<ControllerType>(index));
|
||||||
|
return true;
|
||||||
|
},
|
||||||
|
nullptr, static_cast<int>(ControllerType::Count)))
|
||||||
|
{
|
||||||
|
if (i == 0)
|
||||||
|
m_settings.controller_1_type = static_cast<ControllerType>(controller_type);
|
||||||
|
else
|
||||||
|
m_settings.controller_2_type = static_cast<ControllerType>(controller_type);
|
||||||
|
|
||||||
ImGui::Text("Path:");
|
settings_changed = true;
|
||||||
|
if (m_system)
|
||||||
|
{
|
||||||
|
m_system->UpdateControllers();
|
||||||
|
UpdateControllerControllerMapping();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
ImGui::Text("Memory Card Path:");
|
||||||
ImGui::SameLine(indent);
|
ImGui::SameLine(indent);
|
||||||
|
|
||||||
std::string* path_ptr = (i == 0) ? &m_settings.memory_card_a_path : &m_settings.memory_card_b_path;
|
std::string* path_ptr = (i == 0) ? &m_settings.memory_card_1_path : &m_settings.memory_card_2_path;
|
||||||
if (DrawFileChooser(TinyString::FromFormat("##memcard_%c_path", 'a' + i), path_ptr))
|
if (DrawFileChooser(TinyString::FromFormat("##memcard_%c_path", 'a' + i), path_ptr))
|
||||||
{
|
{
|
||||||
settings_changed = true;
|
settings_changed = true;
|
||||||
|
@ -1129,7 +1152,7 @@ void SDLHostInterface::DrawSettingsWindow()
|
||||||
m_system->UpdateMemoryCards();
|
m_system->UpdateMemoryCards();
|
||||||
}
|
}
|
||||||
|
|
||||||
if (ImGui::Button("Eject"))
|
if (ImGui::Button("Eject Memory Card"))
|
||||||
{
|
{
|
||||||
path_ptr->clear();
|
path_ptr->clear();
|
||||||
settings_changed = true;
|
settings_changed = true;
|
||||||
|
|
Loading…
Reference in New Issue