diff options
Diffstat (limited to 'plugins/OSX/src/java')
-rwxr-xr-x | plugins/OSX/src/java/net/java/games/input/OSXEnvironmentPlugin.java | 42 | ||||
-rw-r--r-- | plugins/OSX/src/java/net/java/games/input/OSXMouse.java | 32 |
2 files changed, 30 insertions, 44 deletions
diff --git a/plugins/OSX/src/java/net/java/games/input/OSXEnvironmentPlugin.java b/plugins/OSX/src/java/net/java/games/input/OSXEnvironmentPlugin.java index 8f6e5c8..a39e04b 100755 --- a/plugins/OSX/src/java/net/java/games/input/OSXEnvironmentPlugin.java +++ b/plugins/OSX/src/java/net/java/games/input/OSXEnvironmentPlugin.java @@ -53,21 +53,7 @@ import net.java.games.util.plugins.Plugin; */ public class OSXEnvironmentPlugin extends ControllerEnvironment implements Plugin { - static - { - System.loadLibrary("jinput"); - } - - public native void hidCreate(); - public native void hidDispose(); - public native void enumDevices(); - /** - * Opens an input device and returns the address of the input queue for that device - */ - public native long openDevice( long lpDevice, int queueDepth ); - public native void closeDevice( long lpDevice, long lpInputQueue ); - public native void pollDevice( long lpInputQueue ); public static final int HID_DEVICE_MOUSE = 0x02; public static final int HID_DEVICE_JOYSTICK = 0x04; @@ -125,6 +111,34 @@ public class OSXEnvironmentPlugin extends ControllerEnvironment implements Plugi public static final int HID_ELEMENTTYPE_COLLECTION = 513; + static + { + System.loadLibrary("jinput"); + } + + public native void hidCreate(); + public native void hidDispose(); + public native void enumDevices(); + + /** + * Opens an input device and returns the address of the input queue for that device + */ + public native long openDevice( long lpDevice, int queueDepth ); + public native void closeDevice( long lpDevice, long lpQueue ); + + + /** + * Polls a device and returns the element top most on the input queue. The elements that + * are returned are only those that have had their hidCookies registered with registerDeviceElement. + * @param lpQueue + * @return + */ + public native int pollDevice( long lpQueue ); + public native int pollElement( long lpDevice, long hidCookie ); + public native void registerDeviceElement( long lpQueue, long hidCookie ); + public native void deregisterDeviceElement( long lpQueue, long hidCookie ); + + private HashMap devices = new HashMap(); diff --git a/plugins/OSX/src/java/net/java/games/input/OSXMouse.java b/plugins/OSX/src/java/net/java/games/input/OSXMouse.java index 0c1fe1a..31e683e 100644 --- a/plugins/OSX/src/java/net/java/games/input/OSXMouse.java +++ b/plugins/OSX/src/java/net/java/games/input/OSXMouse.java @@ -181,18 +181,7 @@ public class OSXMouse extends Mouse implements InputController */ public float getPollData() { -/* // Mouse button - byte data = mouseData[index]; - if ((data & 0x80) != 0) - { - return 1.0f; - } - else - { - return 0.0f; - }*/ - - return 0.0f; + return (float) plugin.pollElement( lpDevice, hidCookie ); } /** Returns <code>true</code> if data returned from <code>poll</code> @@ -237,24 +226,7 @@ public class OSXMouse extends Mouse implements InputController */ public float getPollData() { -/* int data = ((int) mouseData[index] << 12) | - ((int) mouseData[index + 1] << 8) | - ((int) mouseData[index + 2] << 4) | - ((int) mouseData[index + 3]); - if (data == -1) - { - return -1.0f; - } - else if (data >= 1) - { - return 1.0f; - } - else - { - return 0.0f; - }*/ - - return 0.0f; + return (float) plugin.pollElement( lpDevice, hidCookie ); } /** Returns <code>true</code> if data returned from <code>poll</code> |