libretro: Use bitmasks for input
This commit is contained in:
parent
e1c29510f1
commit
f704cc64c3
|
@ -66,9 +66,18 @@ LibretroHostInterface::~LibretroHostInterface()
|
||||||
void LibretroHostInterface::InitInterfaces()
|
void LibretroHostInterface::InitInterfaces()
|
||||||
{
|
{
|
||||||
SetCoreOptions();
|
SetCoreOptions();
|
||||||
InitLogging();
|
|
||||||
InitDiskControlInterface();
|
InitDiskControlInterface();
|
||||||
InitRumbleInterface();
|
|
||||||
|
if (!m_interfaces_initialized)
|
||||||
|
{
|
||||||
|
InitLogging();
|
||||||
|
InitRumbleInterface();
|
||||||
|
|
||||||
|
unsigned dummy = 0;
|
||||||
|
m_supports_input_bitmasks = g_retro_environment_callback(RETRO_ENVIRONMENT_GET_INPUT_BITMASKS, &dummy);
|
||||||
|
|
||||||
|
m_interfaces_initialized = true;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
void LibretroHostInterface::InitLogging()
|
void LibretroHostInterface::InitLogging()
|
||||||
|
@ -711,10 +720,19 @@ void LibretroHostInterface::UpdateControllersDigitalController(u32 index)
|
||||||
{DigitalController::Button::R1, RETRO_DEVICE_ID_JOYPAD_R},
|
{DigitalController::Button::R1, RETRO_DEVICE_ID_JOYPAD_R},
|
||||||
{DigitalController::Button::R2, RETRO_DEVICE_ID_JOYPAD_R2}}};
|
{DigitalController::Button::R2, RETRO_DEVICE_ID_JOYPAD_R2}}};
|
||||||
|
|
||||||
for (const auto& it : mapping)
|
if (m_supports_input_bitmasks)
|
||||||
{
|
{
|
||||||
const int16_t state = g_retro_input_state_callback(index, RETRO_DEVICE_JOYPAD, 0, it.second);
|
const u16 active = g_retro_input_state_callback(index, RETRO_DEVICE_JOYPAD, 0, RETRO_DEVICE_ID_JOYPAD_MASK);
|
||||||
controller->SetButtonState(it.first, state != 0);
|
for (const auto& it : mapping)
|
||||||
|
controller->SetButtonState(it.first, (active & (static_cast<u16>(1u) << it.second)) != 0u);
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
for (const auto& it : mapping)
|
||||||
|
{
|
||||||
|
const int16_t state = g_retro_input_state_callback(index, RETRO_DEVICE_JOYPAD, 0, it.second);
|
||||||
|
controller->SetButtonState(it.first, state != 0);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -747,10 +765,19 @@ void LibretroHostInterface::UpdateControllersAnalogController(u32 index)
|
||||||
{AnalogController::Axis::RightX, {RETRO_DEVICE_INDEX_ANALOG_RIGHT, RETRO_DEVICE_ID_ANALOG_X}},
|
{AnalogController::Axis::RightX, {RETRO_DEVICE_INDEX_ANALOG_RIGHT, RETRO_DEVICE_ID_ANALOG_X}},
|
||||||
{AnalogController::Axis::RightY, {RETRO_DEVICE_INDEX_ANALOG_RIGHT, RETRO_DEVICE_ID_ANALOG_Y}}}};
|
{AnalogController::Axis::RightY, {RETRO_DEVICE_INDEX_ANALOG_RIGHT, RETRO_DEVICE_ID_ANALOG_Y}}}};
|
||||||
|
|
||||||
for (const auto& it : button_mapping)
|
if (m_supports_input_bitmasks)
|
||||||
{
|
{
|
||||||
const int16_t state = g_retro_input_state_callback(index, RETRO_DEVICE_JOYPAD, 0, it.second);
|
const u16 active = g_retro_input_state_callback(index, RETRO_DEVICE_JOYPAD, 0, RETRO_DEVICE_ID_JOYPAD_MASK);
|
||||||
controller->SetButtonState(it.first, state != 0);
|
for (const auto& it : button_mapping)
|
||||||
|
controller->SetButtonState(it.first, (active & (static_cast<u16>(1u) << it.second)) != 0u);
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
for (const auto& it : button_mapping)
|
||||||
|
{
|
||||||
|
const int16_t state = g_retro_input_state_callback(index, RETRO_DEVICE_JOYPAD, 0, it.second);
|
||||||
|
controller->SetButtonState(it.first, state != 0);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
for (const auto& it : axis_mapping)
|
for (const auto& it : axis_mapping)
|
||||||
|
|
|
@ -92,6 +92,8 @@ private:
|
||||||
|
|
||||||
retro_rumble_interface m_rumble_interface = {};
|
retro_rumble_interface m_rumble_interface = {};
|
||||||
bool m_rumble_interface_valid = false;
|
bool m_rumble_interface_valid = false;
|
||||||
|
bool m_supports_input_bitmasks = false;
|
||||||
|
bool m_interfaces_initialized = false;
|
||||||
};
|
};
|
||||||
|
|
||||||
extern LibretroHostInterface g_libretro_host_interface;
|
extern LibretroHostInterface g_libretro_host_interface;
|
||||||
|
|
Loading…
Reference in New Issue