mirror of https://github.com/PCSX2/pcsx2.git
PAD: Make controller info public
This commit is contained in:
parent
9f09aa725b
commit
277706505e
|
@ -52,9 +52,8 @@ ControllerBindingWidget::~ControllerBindingWidget() = default;
|
||||||
|
|
||||||
void ControllerBindingWidget::populateControllerTypes()
|
void ControllerBindingWidget::populateControllerTypes()
|
||||||
{
|
{
|
||||||
m_ui.controllerType->addItem(tr("None (Not Connected)"), QStringLiteral("None"));
|
for (const auto& [name, display_name] : PAD::GetControllerTypeNames())
|
||||||
for (const std::string& type : PAD::GetControllerTypeNames())
|
m_ui.controllerType->addItem(QString::fromStdString(display_name), QString::fromStdString(name));
|
||||||
m_ui.controllerType->addItem(QString::fromStdString(type), QString::fromStdString(type));
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void ControllerBindingWidget::onTypeChanged()
|
void ControllerBindingWidget::onTypeChanged()
|
||||||
|
|
|
@ -43,7 +43,6 @@ namespace PAD
|
||||||
bool trigger_state; ///< Whether the macro button is active.
|
bool trigger_state; ///< Whether the macro button is active.
|
||||||
};
|
};
|
||||||
|
|
||||||
static const char* GetDefaultPadType(u32 pad);
|
|
||||||
static void LoadMacroButtonConfig(const SettingsInterface& si, u32 pad, const std::string_view& type, const std::string& section);
|
static void LoadMacroButtonConfig(const SettingsInterface& si, u32 pad, const std::string_view& type, const std::string& section);
|
||||||
static void ApplyMacroButton(u32 pad, const MacroButton& mb);
|
static void ApplyMacroButton(u32 pad, const MacroButton& mb);
|
||||||
static void UpdateMacroButtons();
|
static void UpdateMacroButtons();
|
||||||
|
@ -273,52 +272,42 @@ void PAD::Update()
|
||||||
UpdateMacroButtons();
|
UpdateMacroButtons();
|
||||||
}
|
}
|
||||||
|
|
||||||
struct ControllerBindingInfo
|
static const PAD::ControllerBindingInfo s_dualshock2_binds[] = {
|
||||||
{
|
{"Up", "D-Pad Up", PAD::ControllerBindingType::Button, GenericInputBinding::DPadUp},
|
||||||
const char* name;
|
{"Right", "D-Pad Right", PAD::ControllerBindingType::Button, GenericInputBinding::DPadRight},
|
||||||
GenericInputBinding generic_mapping;
|
{"Down", "D-Pad Down", PAD::ControllerBindingType::Button, GenericInputBinding::DPadDown},
|
||||||
};
|
{"Left", "D-Pad Left", PAD::ControllerBindingType::Button, GenericInputBinding::DPadLeft},
|
||||||
struct ControllerInfo
|
{"Triangle", "Triangle", PAD::ControllerBindingType::Button, GenericInputBinding::Triangle},
|
||||||
{
|
{"Circle", "Circle", PAD::ControllerBindingType::Button, GenericInputBinding::Circle},
|
||||||
const char* name;
|
{"Cross", "Cross", PAD::ControllerBindingType::Button, GenericInputBinding::Cross},
|
||||||
const ControllerBindingInfo* bindings;
|
{"Square", "Square", PAD::ControllerBindingType::Button, GenericInputBinding::Square},
|
||||||
u32 num_bindings;
|
{"Select", "Select", PAD::ControllerBindingType::Button, GenericInputBinding::Select},
|
||||||
PAD::VibrationCapabilities vibration_caps;
|
{"Start", "Start", PAD::ControllerBindingType::Button, GenericInputBinding::Start},
|
||||||
|
{"L1", "L1 (Left Bumper)", PAD::ControllerBindingType::Button, GenericInputBinding::L1},
|
||||||
|
{"L2", "L2 (Left Trigger)", PAD::ControllerBindingType::HalfAxis, GenericInputBinding::L2},
|
||||||
|
{"R1", "R1 (Right Bumper)", PAD::ControllerBindingType::Button, GenericInputBinding::R1},
|
||||||
|
{"R2", "R2 (Right Trigger)", PAD::ControllerBindingType::HalfAxis, GenericInputBinding::R2},
|
||||||
|
{"L3", "L3 (Left Stick Button)", PAD::ControllerBindingType::Button, GenericInputBinding::L3},
|
||||||
|
{"R3", "R3 (Right Stick Button)", PAD::ControllerBindingType::Button, GenericInputBinding::R3},
|
||||||
|
{"Analog", "Analog Toggle", PAD::ControllerBindingType::Button, GenericInputBinding::System},
|
||||||
|
{"LUp", "Left Stick Up", PAD::ControllerBindingType::HalfAxis, GenericInputBinding::LeftStickUp},
|
||||||
|
{"LRight", "Left Stick Right", PAD::ControllerBindingType::HalfAxis, GenericInputBinding::LeftStickRight},
|
||||||
|
{"LDown", "Left Stick Down", PAD::ControllerBindingType::HalfAxis, GenericInputBinding::LeftStickDown},
|
||||||
|
{"LLeft", "Left Stick Left", PAD::ControllerBindingType::HalfAxis, GenericInputBinding::LeftStickLeft},
|
||||||
|
{"RUp", "Right Stick Up", PAD::ControllerBindingType::HalfAxis, GenericInputBinding::RightStickUp},
|
||||||
|
{"RRight", "Right Stick Right", PAD::ControllerBindingType::HalfAxis, GenericInputBinding::RightStickRight},
|
||||||
|
{"RDown", "Right Stick Down", PAD::ControllerBindingType::HalfAxis, GenericInputBinding::RightStickDown},
|
||||||
|
{"RLeft", "Right Stick Left", PAD::ControllerBindingType::HalfAxis, GenericInputBinding::RightStickLeft},
|
||||||
|
{"LargeMotor", "Large (Low Frequency) Motor", PAD::ControllerBindingType::Motor, GenericInputBinding::LargeMotor},
|
||||||
|
{"SmallMotor", "Small (High Frequency) Motor", PAD::ControllerBindingType::Motor, GenericInputBinding::SmallMotor},
|
||||||
};
|
};
|
||||||
|
|
||||||
static const ControllerBindingInfo s_dualshock2_binds[] = {
|
static const PAD::ControllerInfo s_controller_info[] = {
|
||||||
{"Up", GenericInputBinding::DPadUp },
|
{"None", "Not Connected", nullptr, 0, PAD::VibrationCapabilities::NoVibration},
|
||||||
{"Right",GenericInputBinding::DPadRight },
|
{"DualShock2", "DuckShock 2", s_dualshock2_binds, std::size(s_dualshock2_binds), PAD::VibrationCapabilities::LargeSmallMotors},
|
||||||
{"Down", GenericInputBinding::DPadDown },
|
|
||||||
{"Left", GenericInputBinding::DPadLeft },
|
|
||||||
{"Triangle", GenericInputBinding::Triangle },
|
|
||||||
{"Circle", GenericInputBinding::Circle },
|
|
||||||
{"Cross", GenericInputBinding::Cross },
|
|
||||||
{"Square", GenericInputBinding::Square },
|
|
||||||
{"Select", GenericInputBinding::Select },
|
|
||||||
{"Start", GenericInputBinding::Start },
|
|
||||||
{"L1", GenericInputBinding::L1 },
|
|
||||||
{"L2", GenericInputBinding::L2 },
|
|
||||||
{"R1", GenericInputBinding::R1 },
|
|
||||||
{"R2", GenericInputBinding::R2 },
|
|
||||||
{"L3", GenericInputBinding::L3 },
|
|
||||||
{"R3", GenericInputBinding::R3 },
|
|
||||||
{"Analog", GenericInputBinding::System},
|
|
||||||
{"LUp", GenericInputBinding::LeftStickUp },
|
|
||||||
{"LRight", GenericInputBinding::LeftStickRight },
|
|
||||||
{"LDown", GenericInputBinding::LeftStickDown },
|
|
||||||
{"LLeft", GenericInputBinding::LeftStickLeft },
|
|
||||||
{"RUp", GenericInputBinding::RightStickUp },
|
|
||||||
{"RRight", GenericInputBinding::RightStickRight },
|
|
||||||
{"RDown", GenericInputBinding::RightStickDown },
|
|
||||||
{"RLeft", GenericInputBinding::RightStickLeft },
|
|
||||||
};
|
};
|
||||||
|
|
||||||
static const ControllerInfo s_controller_info[] = {
|
const PAD::ControllerInfo* PAD::GetControllerInfo(const std::string_view& name)
|
||||||
{ "DualShock2", s_dualshock2_binds, std::size(s_dualshock2_binds), PAD::VibrationCapabilities::LargeSmallMotors },
|
|
||||||
};
|
|
||||||
|
|
||||||
static const ControllerInfo* GetControllerInfo(const std::string_view& name)
|
|
||||||
{
|
{
|
||||||
for (const ControllerInfo& info : s_controller_info)
|
for (const ControllerInfo& info : s_controller_info)
|
||||||
{
|
{
|
||||||
|
@ -329,12 +318,11 @@ static const ControllerInfo* GetControllerInfo(const std::string_view& name)
|
||||||
return nullptr;
|
return nullptr;
|
||||||
}
|
}
|
||||||
|
|
||||||
std::vector<std::string> PAD::GetControllerTypeNames()
|
std::vector<std::pair<std::string, std::string>> PAD::GetControllerTypeNames()
|
||||||
{
|
{
|
||||||
std::vector<std::string> ret;
|
std::vector<std::pair<std::string, std::string>> ret;
|
||||||
|
|
||||||
for (const ControllerInfo& info : s_controller_info)
|
for (const ControllerInfo& info : s_controller_info)
|
||||||
ret.emplace_back(info.name);
|
ret.emplace_back(info.name, info.display_name);
|
||||||
|
|
||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
|
@ -347,8 +335,14 @@ std::vector<std::string> PAD::GetControllerBinds(const std::string_view& type)
|
||||||
if (info)
|
if (info)
|
||||||
{
|
{
|
||||||
for (u32 i = 0; i < info->num_bindings; i++)
|
for (u32 i = 0; i < info->num_bindings; i++)
|
||||||
|
{
|
||||||
|
const ControllerBindingInfo& bi = info->bindings[i];
|
||||||
|
if (bi.type == ControllerBindingType::Unknown || bi.type == ControllerBindingType::Motor)
|
||||||
|
continue;
|
||||||
|
|
||||||
ret.emplace_back(info->bindings[i].name);
|
ret.emplace_back(info->bindings[i].name);
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
|
||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
|
|
|
@ -37,7 +37,17 @@ u8 PADpoll(u8 value);
|
||||||
|
|
||||||
namespace PAD
|
namespace PAD
|
||||||
{
|
{
|
||||||
enum class VibrationCapabilities
|
enum class ControllerBindingType : u8
|
||||||
|
{
|
||||||
|
Unknown,
|
||||||
|
Button,
|
||||||
|
Axis,
|
||||||
|
HalfAxis,
|
||||||
|
Motor,
|
||||||
|
Macro
|
||||||
|
};
|
||||||
|
|
||||||
|
enum class VibrationCapabilities : u8
|
||||||
{
|
{
|
||||||
NoVibration,
|
NoVibration,
|
||||||
LargeSmallMotors,
|
LargeSmallMotors,
|
||||||
|
@ -45,9 +55,29 @@ namespace PAD
|
||||||
Count
|
Count
|
||||||
};
|
};
|
||||||
|
|
||||||
|
struct ControllerBindingInfo
|
||||||
|
{
|
||||||
|
const char* name;
|
||||||
|
const char* display_name;
|
||||||
|
ControllerBindingType type;
|
||||||
|
GenericInputBinding generic_mapping;
|
||||||
|
};
|
||||||
|
|
||||||
|
struct ControllerInfo
|
||||||
|
{
|
||||||
|
const char* name;
|
||||||
|
const char* display_name;
|
||||||
|
const ControllerBindingInfo* bindings;
|
||||||
|
u32 num_bindings;
|
||||||
|
PAD::VibrationCapabilities vibration_caps;
|
||||||
|
};
|
||||||
|
|
||||||
/// Number of macro buttons per controller.
|
/// Number of macro buttons per controller.
|
||||||
static constexpr u32 NUM_MACRO_BUTTONS_PER_CONTROLLER = 4;
|
static constexpr u32 NUM_MACRO_BUTTONS_PER_CONTROLLER = 4;
|
||||||
|
|
||||||
|
/// Returns the default type for the specified port.
|
||||||
|
const char* GetDefaultPadType(u32 pad);
|
||||||
|
|
||||||
/// Reloads configuration.
|
/// Reloads configuration.
|
||||||
void LoadConfig(const SettingsInterface& si);
|
void LoadConfig(const SettingsInterface& si);
|
||||||
|
|
||||||
|
@ -60,8 +90,8 @@ namespace PAD
|
||||||
/// Updates vibration and other internal state. Called at the *end* of a frame.
|
/// Updates vibration and other internal state. Called at the *end* of a frame.
|
||||||
void Update();
|
void Update();
|
||||||
|
|
||||||
/// Returns a list of controller type names.
|
/// Returns a list of controller type names. Pair of [name, display name].
|
||||||
std::vector<std::string> GetControllerTypeNames();
|
std::vector<std::pair<std::string, std::string>> GetControllerTypeNames();
|
||||||
|
|
||||||
/// Returns the list of binds for the specified controller type.
|
/// Returns the list of binds for the specified controller type.
|
||||||
std::vector<std::string> GetControllerBinds(const std::string_view& type);
|
std::vector<std::string> GetControllerBinds(const std::string_view& type);
|
||||||
|
@ -69,6 +99,9 @@ namespace PAD
|
||||||
/// Returns the vibration configuration for the specified controller type.
|
/// Returns the vibration configuration for the specified controller type.
|
||||||
VibrationCapabilities GetControllerVibrationCapabilities(const std::string_view& type);
|
VibrationCapabilities GetControllerVibrationCapabilities(const std::string_view& type);
|
||||||
|
|
||||||
|
/// Returns general information for the specified controller type.
|
||||||
|
const ControllerInfo* GetControllerInfo(const std::string_view& name);
|
||||||
|
|
||||||
/// Performs automatic controller mapping with the provided list of generic mappings.
|
/// Performs automatic controller mapping with the provided list of generic mappings.
|
||||||
bool MapController(SettingsInterface& si, u32 controller,
|
bool MapController(SettingsInterface& si, u32 controller,
|
||||||
const std::vector<std::pair<GenericInputBinding, std::string>>& mapping);
|
const std::vector<std::pair<GenericInputBinding, std::string>>& mapping);
|
||||||
|
|
Loading…
Reference in New Issue