Merge pull request #485 from leezer3/develop

Fix: Joystick hats sticking in last position on Linux
This commit is contained in:
varon 2017-03-19 12:29:00 +02:00 committed by GitHub
commit a21313b41b

View file

@ -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
{ {