[Win] Added collection id to dictionary keys

This commit is contained in:
thefiddler 2014-08-02 23:10:33 +02:00
parent a2d6f1801c
commit 8c762e56e3
2 changed files with 29 additions and 23 deletions

View file

@ -258,7 +258,7 @@ namespace OpenTK.Platform.Windows
[FieldOffset(2)] public byte ReportID; [FieldOffset(2)] public byte ReportID;
[FieldOffset(3), MarshalAs(UnmanagedType.U1)] public bool IsAlias; [FieldOffset(3), MarshalAs(UnmanagedType.U1)] public bool IsAlias;
[FieldOffset(4)] public ushort BitField; [FieldOffset(4)] public ushort BitField;
[FieldOffset(6)] public ushort LinkCollection; [FieldOffset(6)] public short LinkCollection;
[FieldOffset(8)] public ushort LinkUsage; [FieldOffset(8)] public ushort LinkUsage;
[FieldOffset(10)] public ushort LinkUsagePage; [FieldOffset(10)] public ushort LinkUsagePage;
[FieldOffset(12), MarshalAs(UnmanagedType.U1)] public bool IsRange; [FieldOffset(12), MarshalAs(UnmanagedType.U1)] public bool IsRange;

View file

@ -79,21 +79,21 @@ namespace OpenTK.Platform.Windows
State.ClearButtons(); State.ClearButtons();
} }
public void SetAxis(HIDPage page, short usage, short value) public void SetAxis(short collection, HIDPage page, short usage, short value)
{ {
JoystickAxis axis = GetAxis(page, usage); JoystickAxis axis = GetAxis(collection, page, usage);
State.SetAxis(axis, value); State.SetAxis(axis, value);
} }
public void SetButton(HIDPage page, short usage, bool value) public void SetButton(short collection, HIDPage page, short usage, bool value)
{ {
JoystickButton button = GetButton(page, usage); JoystickButton button = GetButton(collection, page, usage);
State.SetButton(button, value); State.SetButton(button, value);
} }
public void SetHat(HIDPage page, short usage, HatPosition pos) public void SetHat(short collection, HIDPage page, short usage, HatPosition pos)
{ {
JoystickHat hat = GetHat(page, usage); JoystickHat hat = GetHat(collection, page, usage);
State.SetHat(hat, new JoystickHatState(pos)); State.SetHat(hat, new JoystickHatState(pos));
} }
@ -130,14 +130,16 @@ namespace OpenTK.Platform.Windows
#region Private Members #region Private Members
static int MakeKey(HIDPage page, short usage) static int MakeKey(short collection, HIDPage page, short usage)
{ {
return ((ushort)page << 16) | unchecked((ushort)usage); byte coll_byte = unchecked((byte)collection);
byte page_byte = unchecked((byte)(((ushort)page & 0xff00) >> 8 | ((ushort)page & 0xff)));
return (coll_byte << 24) | (page_byte << 16) | unchecked((ushort)usage);
} }
JoystickAxis GetAxis(HIDPage page, short usage) JoystickAxis GetAxis(short collection, HIDPage page, short usage)
{ {
int key = MakeKey(page, usage); int key = MakeKey(collection, page, usage);
if (!axes.ContainsKey(key)) if (!axes.ContainsKey(key))
{ {
JoystickAxis axis = HidHelper.TranslateJoystickAxis(page, usage); JoystickAxis axis = HidHelper.TranslateJoystickAxis(page, usage);
@ -146,9 +148,9 @@ namespace OpenTK.Platform.Windows
return axes[key]; return axes[key];
} }
JoystickButton GetButton(HIDPage page, short usage) JoystickButton GetButton(short collection, HIDPage page, short usage)
{ {
int key = MakeKey(page, usage); int key = MakeKey(collection, page, usage);
if (!buttons.ContainsKey(key)) if (!buttons.ContainsKey(key))
{ {
buttons.Add(key, JoystickButton.Button0 + buttons.Count); buttons.Add(key, JoystickButton.Button0 + buttons.Count);
@ -156,9 +158,9 @@ namespace OpenTK.Platform.Windows
return buttons[key]; return buttons[key];
} }
JoystickHat GetHat(HIDPage page, short usage) JoystickHat GetHat(short collection, HIDPage page, short usage)
{ {
int key = MakeKey(page, usage); int key = MakeKey(collection, page, usage);
if (!hats.ContainsKey(key)) if (!hats.ContainsKey(key))
{ {
hats.Add(key, JoystickHat.Hat0 + hats.Count); hats.Add(key, JoystickHat.Hat0 + hats.Count);
@ -369,6 +371,7 @@ namespace OpenTK.Platform.Windows
HIDPage page = stick.AxisCaps[i].UsagePage; HIDPage page = stick.AxisCaps[i].UsagePage;
short usage = stick.AxisCaps[i].NotRange.Usage; short usage = stick.AxisCaps[i].NotRange.Usage;
uint value = 0; uint value = 0;
short collection = stick.AxisCaps[i].LinkCollection;
HidProtocolStatus status = HidProtocol.GetUsageValue( HidProtocolStatus status = HidProtocol.GetUsageValue(
HidProtocolReportType.Input, HidProtocolReportType.Input,
@ -386,7 +389,7 @@ namespace OpenTK.Platform.Windows
if (page == HIDPage.GenericDesktop && (HIDUsageGD)usage == HIDUsageGD.Hatswitch) if (page == HIDPage.GenericDesktop && (HIDUsageGD)usage == HIDUsageGD.Hatswitch)
{ {
stick.SetHat(page, usage, GetHatPosition(value, stick.AxisCaps[i])); stick.SetHat(collection, page, usage, GetHatPosition(value, stick.AxisCaps[i]));
} }
else else
{ {
@ -394,7 +397,7 @@ namespace OpenTK.Platform.Windows
(int)((long)value + stick.AxisCaps[i].LogicalMin), (int)((long)value + stick.AxisCaps[i].LogicalMin),
stick.AxisCaps[i].LogicalMin, stick.AxisCaps[i].LogicalMax, stick.AxisCaps[i].LogicalMin, stick.AxisCaps[i].LogicalMax,
Int16.MinValue, Int16.MaxValue); Int16.MinValue, Int16.MaxValue);
stick.SetAxis(page, usage, scaled_value); stick.SetAxis(collection, page, usage, scaled_value);
} }
} }
} }
@ -408,6 +411,7 @@ namespace OpenTK.Platform.Windows
short* usage_list = stackalloc short[(int)JoystickButton.Last + 1]; short* usage_list = stackalloc short[(int)JoystickButton.Last + 1];
int usage_length = (int)JoystickButton.Last; int usage_length = (int)JoystickButton.Last;
HIDPage page = stick.ButtonCaps[i].UsagePage; HIDPage page = stick.ButtonCaps[i].UsagePage;
short collection = stick.ButtonCaps[i].LinkCollection;
HidProtocolStatus status = HidProtocol.GetUsages( HidProtocolStatus status = HidProtocol.GetUsages(
HidProtocolReportType.Input, HidProtocolReportType.Input,
@ -426,7 +430,7 @@ namespace OpenTK.Platform.Windows
for (int j = 0; j < usage_length; j++) for (int j = 0; j < usage_length; j++)
{ {
short usage = *(usage_list + j); short usage = *(usage_list + j);
stick.SetButton(page, usage, true); stick.SetButton(collection, page, usage, true);
} }
} }
} }
@ -493,6 +497,7 @@ namespace OpenTK.Platform.Windows
} }
HIDPage page = stick.AxisCaps[i].UsagePage; HIDPage page = stick.AxisCaps[i].UsagePage;
short collection = stick.AxisCaps[i].LinkCollection;
switch (page) switch (page)
{ {
case HIDPage.GenericDesktop: case HIDPage.GenericDesktop:
@ -510,14 +515,14 @@ namespace OpenTK.Platform.Windows
Debug.Print("Found axis {0} ({1} / {2})", Debug.Print("Found axis {0} ({1} / {2})",
JoystickAxis.Axis0 + stick.GetCapabilities().AxisCount, JoystickAxis.Axis0 + stick.GetCapabilities().AxisCount,
page, (HIDUsageGD)stick.AxisCaps[i].NotRange.Usage); page, (HIDUsageGD)stick.AxisCaps[i].NotRange.Usage);
stick.SetAxis(page, stick.AxisCaps[i].NotRange.Usage, 0); stick.SetAxis(collection, page, stick.AxisCaps[i].NotRange.Usage, 0);
break; break;
case HIDUsageGD.Hatswitch: case HIDUsageGD.Hatswitch:
Debug.Print("Found hat {0} ({1} / {2})", Debug.Print("Found hat {0} ({1} / {2})",
JoystickHat.Hat0 + stick.GetCapabilities().HatCount, JoystickHat.Hat0 + stick.GetCapabilities().HatCount,
page, (HIDUsageGD)stick.AxisCaps[i].NotRange.Usage); page, (HIDUsageGD)stick.AxisCaps[i].NotRange.Usage);
stick.SetHat(page, stick.AxisCaps[i].NotRange.Usage, HatPosition.Centered); stick.SetHat(collection, page, stick.AxisCaps[i].NotRange.Usage, HatPosition.Centered);
break; break;
} }
break; break;
@ -530,7 +535,7 @@ namespace OpenTK.Platform.Windows
Debug.Print("Found simulation axis {0} ({1} / {2})", Debug.Print("Found simulation axis {0} ({1} / {2})",
JoystickAxis.Axis0 + stick.GetCapabilities().AxisCount, JoystickAxis.Axis0 + stick.GetCapabilities().AxisCount,
page, (HIDUsageSim)stick.AxisCaps[i].NotRange.Usage); page, (HIDUsageSim)stick.AxisCaps[i].NotRange.Usage);
stick.SetAxis(page, stick.AxisCaps[i].NotRange.Usage, 0); stick.SetAxis(collection, page, stick.AxisCaps[i].NotRange.Usage, 0);
break; break;
} }
break; break;
@ -552,6 +557,7 @@ namespace OpenTK.Platform.Windows
bool is_range = stick.ButtonCaps[i].IsRange; bool is_range = stick.ButtonCaps[i].IsRange;
HIDPage page = stick.ButtonCaps[i].UsagePage; HIDPage page = stick.ButtonCaps[i].UsagePage;
short collection = stick.ButtonCaps[i].LinkCollection;
switch (page) switch (page)
{ {
case HIDPage.Button: case HIDPage.Button:
@ -562,7 +568,7 @@ namespace OpenTK.Platform.Windows
Debug.Print("Found button {0} ({1} / {2})", Debug.Print("Found button {0} ({1} / {2})",
JoystickButton.Button0 + stick.GetCapabilities().ButtonCount, JoystickButton.Button0 + stick.GetCapabilities().ButtonCount,
page, usage); page, usage);
stick.SetButton(page, usage, false); stick.SetButton(collection, page, usage, false);
} }
} }
else else
@ -570,7 +576,7 @@ namespace OpenTK.Platform.Windows
Debug.Print("Found button {0} ({1} / {2})", Debug.Print("Found button {0} ({1} / {2})",
JoystickButton.Button0 + stick.GetCapabilities().ButtonCount, JoystickButton.Button0 + stick.GetCapabilities().ButtonCount,
page, stick.ButtonCaps[i].NotRange.Usage); page, stick.ButtonCaps[i].NotRange.Usage);
stick.SetButton(page, stick.ButtonCaps[i].NotRange.Usage, false); stick.SetButton(collection, page, stick.ButtonCaps[i].NotRange.Usage, false);
} }
break; break;