mirror of
https://github.com/Ryujinx/Opentk.git
synced 2025-01-25 09:21:02 +00:00
Merge pull request #485 from leezer3/develop
Fix: Joystick hats sticking in last position on Linux
This commit is contained in:
commit
a21313b41b
|
@ -54,6 +54,14 @@ namespace OpenTK.Platform.Linux
|
||||||
new Dictionary<EvdevAxis, AxisInfo>();
|
new Dictionary<EvdevAxis, AxisInfo>();
|
||||||
public readonly Dictionary<EvdevButton, int> ButtonMap =
|
public readonly Dictionary<EvdevButton, int> ButtonMap =
|
||||||
new Dictionary<EvdevButton, int>();
|
new Dictionary<EvdevButton, int>();
|
||||||
|
|
||||||
|
internal int[,] hatStates =
|
||||||
|
{
|
||||||
|
{0, 0},
|
||||||
|
{0, 0},
|
||||||
|
{0, 0},
|
||||||
|
{0, 0}
|
||||||
|
};
|
||||||
}
|
}
|
||||||
|
|
||||||
sealed class LinuxJoystick : IJoystickDriver2
|
sealed class LinuxJoystick : IJoystickDriver2
|
||||||
|
@ -398,27 +406,22 @@ namespace OpenTK.Platform.Linux
|
||||||
// We currently treat analogue hats as digital hats
|
// We currently treat analogue hats as digital hats
|
||||||
// to maintain compatibility with SDL2. We can do
|
// to maintain compatibility with SDL2. We can do
|
||||||
// better than this, however.
|
// better than this, however.
|
||||||
JoystickHat hat = JoystickHat.Hat0 + (e->Code - (int)EvdevAxis.HAT0X) / 2;
|
int hat = (e->Code - (int)EvdevAxis.HAT0X) / 2;
|
||||||
JoystickHatState pos = js.State.GetHat(hat);
|
|
||||||
int xy_axis = (int)axis.Axis & 0x1;
|
int xy_axis = (int)axis.Axis & 0x1;
|
||||||
|
int value = e->Value.CompareTo(0) + 1;
|
||||||
switch (xy_axis)
|
switch (xy_axis)
|
||||||
{
|
{
|
||||||
case 0:
|
case 0:
|
||||||
// X-axis
|
// X-axis
|
||||||
pos = TranslateHat(
|
js.hatStates[hat, 1] = value;
|
||||||
e->Value.CompareTo(0) + 1,
|
|
||||||
pos.IsUp ? 0 : pos.IsDown ? 2 : 1);
|
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case 1:
|
case 1:
|
||||||
// Y-axis
|
// Y-axis
|
||||||
pos = TranslateHat(
|
js.hatStates[hat, 0] = value;
|
||||||
pos.IsLeft ? 0 : pos.IsRight ? 2 : 1,
|
|
||||||
e->Value.CompareTo(0) + 1);
|
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
js.State.SetHat((JoystickHat)hat, TranslateHat(js.hatStates[hat, 0], js.hatStates[hat, 1]));
|
||||||
js.State.SetHat(hat, pos);
|
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
|
|
Loading…
Reference in a new issue