mirror of
https://github.com/libretro/RetroArch
synced 2025-04-16 08:43:10 +00:00
(macOS) Fixed cocoa keyboard not allowing to map Analog stick (#14701)
This commit is contained in:
parent
573a82c0c8
commit
a22bac091c
@ -431,7 +431,36 @@ static int16_t cocoa_input_state(
|
|||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
case RETRO_DEVICE_ANALOG:
|
case RETRO_DEVICE_ANALOG:
|
||||||
|
{
|
||||||
|
int16_t ret = 0;
|
||||||
|
int id_minus_key = 0;
|
||||||
|
int id_plus_key = 0;
|
||||||
|
unsigned id_minus = 0;
|
||||||
|
unsigned id_plus = 0;
|
||||||
|
bool id_plus_valid = false;
|
||||||
|
bool id_minus_valid = false;
|
||||||
|
|
||||||
|
input_conv_analog_id_to_bind_id(idx, id, id_minus, id_plus);
|
||||||
|
|
||||||
|
id_minus_valid = binds[port][id_minus].valid;
|
||||||
|
id_plus_valid = binds[port][id_plus].valid;
|
||||||
|
id_minus_key = binds[port][id_minus].key;
|
||||||
|
id_plus_key = binds[port][id_plus].key;
|
||||||
|
|
||||||
|
if (id_plus_valid && id_plus_key < RETROK_LAST)
|
||||||
|
{
|
||||||
|
if (apple_key_state[rarch_keysym_lut[(enum retro_key)id_plus_key]])
|
||||||
|
ret = 0x7fff;
|
||||||
|
}
|
||||||
|
if (id_minus_valid && id_minus_key < RETROK_LAST)
|
||||||
|
{
|
||||||
|
if (apple_key_state[rarch_keysym_lut[(enum retro_key)id_minus_key]])
|
||||||
|
ret += -0x7fff;
|
||||||
|
}
|
||||||
|
return ret;
|
||||||
|
}
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case RETRO_DEVICE_KEYBOARD:
|
case RETRO_DEVICE_KEYBOARD:
|
||||||
return (id < RETROK_LAST) && apple_key_state[rarch_keysym_lut[(enum retro_key)id]];
|
return (id < RETROK_LAST) && apple_key_state[rarch_keysym_lut[(enum retro_key)id]];
|
||||||
case RETRO_DEVICE_MOUSE:
|
case RETRO_DEVICE_MOUSE:
|
||||||
|
Loading…
x
Reference in New Issue
Block a user