diff --git a/Source/Examples/Tutorial/T03_RotatingCube.cs b/Source/Examples/Tutorial/T03_RotatingCube.cs index 12d6a02c..bf542c50 100644 --- a/Source/Examples/Tutorial/T03_RotatingCube.cs +++ b/Source/Examples/Tutorial/T03_RotatingCube.cs @@ -80,7 +80,7 @@ namespace Examples.Tutorial /// public override void UpdateFrame() { - if (Key.Escape) + if (Key[OpenTK.Input.Keys.Escape]) { Quit = true; return; diff --git a/Source/Examples/Tutorial/T07_DisplayLists_Cube.cs b/Source/Examples/Tutorial/T07_DisplayLists_Cube.cs index cae35d41..17179d30 100644 --- a/Source/Examples/Tutorial/T07_DisplayLists_Cube.cs +++ b/Source/Examples/Tutorial/T07_DisplayLists_Cube.cs @@ -157,7 +157,7 @@ namespace Examples.Tutorial { base.UpdateFrame(); - if (Key.Escape) + if (Key[OpenTK.Input.Keys.Escape]) { this.Quit = true; } diff --git a/Source/Examples/Tutorial/T08_VBO.cs b/Source/Examples/Tutorial/T08_VBO.cs index 36fa5121..809ac3d6 100644 --- a/Source/Examples/Tutorial/T08_VBO.cs +++ b/Source/Examples/Tutorial/T08_VBO.cs @@ -131,7 +131,7 @@ namespace Examples.Tutorial /// public override void UpdateFrame() { - if (Key.Escape) + if (Key[OpenTK.Input.Keys.Escape]) { Quit = true; return; diff --git a/Source/Examples/Tutorial/T10_GLSL_Cube.cs b/Source/Examples/Tutorial/T10_GLSL_Cube.cs index 669bc6ae..512e233e 100644 --- a/Source/Examples/Tutorial/T10_GLSL_Cube.cs +++ b/Source/Examples/Tutorial/T10_GLSL_Cube.cs @@ -145,7 +145,7 @@ namespace Examples.Tutorial { base.UpdateFrame(); - if (Key.Escape) + if (Key[OpenTK.Input.Keys.Escape]) { this.Quit = true; } diff --git a/Source/OpenTK/GameWindow.cs b/Source/OpenTK/GameWindow.cs index 8a3dbb01..1b21e82d 100644 --- a/Source/OpenTK/GameWindow.cs +++ b/Source/OpenTK/GameWindow.cs @@ -7,18 +7,20 @@ using System; using System.Collections.Generic; using System.Text; - -using OpenTK.Platform; using System.Diagnostics; +using OpenTK.Input; +using OpenTK.Platform; + namespace OpenTK { public class GameWindow : OpenTK.Platform.IGLControl, OpenTK.Platform.IGameWindow { - INativeWindow glWindow; - + private INativeWindow glWindow; private ResizeEventArgs resizeEventArgs = new ResizeEventArgs(); + public Keyboard Key = new Keyboard(); + #region --- Contructors --- /// diff --git a/Source/OpenTK/Input/IKeyboard.cs b/Source/OpenTK/Input/IKeyboard.cs new file mode 100644 index 00000000..00f58e2a --- /dev/null +++ b/Source/OpenTK/Input/IKeyboard.cs @@ -0,0 +1,12 @@ +using System; +using System.Collections.Generic; +using System.Text; + +namespace OpenTK.Input +{ + interface IKeyboard + { + bool this[Keys k] { get; set; } + void Poll(); + } +} diff --git a/Source/OpenTK/Input/Key.cs b/Source/OpenTK/Input/Key.cs deleted file mode 100644 index 31bdbe39..00000000 --- a/Source/OpenTK/Input/Key.cs +++ /dev/null @@ -1,255 +0,0 @@ -using System; -using System.Collections.Generic; -using System.Text; - -namespace OpenTK.Input -{ - static public class Key - { - static private bool[] keys = new bool[(int)Keys.MaxKeys]; - - #region Modifiers - - static public bool LeftShift - { - get { return keys[(int)Keys.LeftShift]; } - internal set { keys[(int)Keys.LeftShift] = value; } - } - - static public bool RightShift - { - get { return keys[(int)Keys.RightShift]; } - internal set { keys[(int)Keys.RightShift] = value; } - } - - static public bool LeftControl - { - get { return keys[(int)Keys.LeftControl]; } - internal set { keys[(int)Keys.LeftControl] = value; } - } - - static public bool RightControl - { - get { return keys[(int)Keys.RightControl]; } - internal set { keys[(int)Keys.RightControl] = value; } - } - - static public bool LeftAlt - { - get { return keys[(int)Keys.LeftAlt]; } - internal set { keys[(int)Keys.LeftAlt] = value; } - } - - static public bool RightAlt - { - get { return keys[(int)Keys.RightAlt]; } - internal set { keys[(int)Keys.RightAlt] = value; } - } - - #endregion - - #region Function Keys - - static public bool F1 - { - get { return keys[(int)Keys.F1]; } - internal set { keys[(int)Keys.F1] = value; } - } - - static public bool F2 - { - get { return keys[(int)Keys.F2]; } - internal set { keys[(int)Keys.F2] = value; } - } - - static public bool F3 - { - get { return keys[(int)Keys.F3]; } - internal set { keys[(int)Keys.F3] = value; } - } - - static public bool F4 - { - get { return keys[(int)Keys.F4]; } - internal set { keys[(int)Keys.F4] = value; } - } - - static public bool F5 - { - get { return keys[(int)Keys.F5]; } - internal set { keys[(int)Keys.F5] = value; } - } - - static public bool F6 - { - get { return keys[(int)Keys.F6]; } - internal set { keys[(int)Keys.F6] = value; } - } - - static public bool F7 - { - get { return keys[(int)Keys.F7]; } - internal set { keys[(int)Keys.F7] = value; } - } - - static public bool F8 - { - get { return keys[(int)Keys.F8]; } - internal set { keys[(int)Keys.F8] = value; } - } - - static public bool F9 - { - get { return keys[(int)Keys.F9]; } - internal set { keys[(int)Keys.F9] = value; } - } - - static public bool F10 - { - get { return keys[(int)Keys.F10]; } - internal set { keys[(int)Keys.F10] = value; } - } - - static public bool F11 - { - get { return keys[(int)Keys.F11]; } - internal set { keys[(int)Keys.F11] = value; } - } - - static public bool F12 - { - get { return keys[(int)Keys.F12]; } - internal set { keys[(int)Keys.F12] = value; } - } - - static public bool F13 - { - get { return keys[(int)Keys.F13]; } - internal set { keys[(int)Keys.F13] = value; } - } - - static public bool F14 - { - get { return keys[(int)Keys.F14]; } - internal set { keys[(int)Keys.F14] = value; } - } - - static public bool F15 - { - get { return keys[(int)Keys.F15]; } - internal set { keys[(int)Keys.F15] = value; } - } - - static public bool F16 - { - get { return keys[(int)Keys.F16]; } - internal set { keys[(int)Keys.F16] = value; } - } - - #endregion - - static public bool Enter - { - get { return keys[(int)Keys.Enter]; } - internal set { keys[(int)Keys.Enter] = value; } - } - - static public bool Escape - { - get { return keys[(int)Keys.Escape]; } - internal set { keys[(int)Keys.Escape] = value; } - } - } - - enum Keys : int - { - // Modifiers - LeftShift = 0, - RightShift, - LeftControl, - RightControl, - LeftAlt, - RightAlt, - - // Function keys (hopefully enough for most keyboards - mine has 26) - F1, F2, F3, F4, - F5, F6, F7, F8, - F9, F10, F11, F12, - F13, F14, F15, F16, - F17, F18, F19, F20, - F21, F22, F23, F24, - F25, F26, F27, F28, - F29, F30, F31, F32, - - // Direction arrows - Up, - Down, - Left, - Right, - - // Special keys - Enter, - Escape, - Space, - Tab, - Backspace, - Insert, - Delete, - PageUp, - PageDown, - Home, - End, - CapsLock, - - // Keypad keys - Keypad0, - Keypad1, - Keypad2, - Keypad3, - Keypad4, - Keypad5, - Keypad6, - Keypad7, - Keypad8, - Keypad9, - KeypadDivide, - KeypadMultiply, - KeypadSubtract, - KeypadAdd, - KeypadDecimal, - KeypadEqual, - KeypadEnter, - - // Letters - A, B, C, D, E, F, G, - H, I, J, K, L, M, N, - O, P, Q, R, S, T, U, - V, W, X, Y, Z, - - // Numbers - Number0, - Number1, - Number2, - Number3, - Number4, - Number5, - Number6, - Number7, - Number8, - Number9, - - // Symbols - Minus, - Equal, - LeftBracket, - RightBracket, - Semicolon, - QuotationMark, - Comma, - FullStop, - Slash, - BackSlash, - - MaxKeys - } -} diff --git a/Source/OpenTK/Input/Keyboard.cs b/Source/OpenTK/Input/Keyboard.cs new file mode 100644 index 00000000..32c3c2de --- /dev/null +++ b/Source/OpenTK/Input/Keyboard.cs @@ -0,0 +1,134 @@ +using System; +using System.Collections.Generic; +using System.Text; + +namespace OpenTK.Input +{ + public class Keyboard : IKeyboard + { + private IKeyboard keyboard; + + public Keyboard() + { + if (Environment.OSVersion.Platform == PlatformID.Win32NT || + Environment.OSVersion.Platform == PlatformID.Win32Windows) + { + keyboard = new OpenTK.Platform.Windows.WinKeyboard(); + } + else if (Environment.OSVersion.Platform == PlatformID.Unix || + Environment.OSVersion.Platform == (PlatformID)128) // some older versions of Mono reported 128. + { + throw new NotImplementedException(); + } + else + { + throw new PlatformNotSupportedException( + "Your operating system is not currently supported. We are sorry for the inconvenience." + ); + } + } + + public bool this[Keys k] + { + get { return keyboard[k]; } + set { keyboard[k] = value; } + } + + public void Poll() + { + keyboard.Poll(); + } + } + + public enum Keys : int + { + // Modifiers + LeftShift = 0, + RightShift, + LeftControl, + RightControl, + LeftAlt, + RightAlt, + + // Function keys (hopefully enough for most keyboards - mine has 26) + F1, F2, F3, F4, + F5, F6, F7, F8, + F9, F10, F11, F12, + F13, F14, F15, F16, + F17, F18, F19, F20, + F21, F22, F23, F24, + F25, F26, F27, F28, + F29, F30, F31, F32, + + // Direction arrows + Up, + Down, + Left, + Right, + + // Special keys + Enter, + Escape, + Space, + Tab, + Backspace, + Insert, + Delete, + PageUp, + PageDown, + Home, + End, + CapsLock, + + // Keypad keys + Keypad0, + Keypad1, + Keypad2, + Keypad3, + Keypad4, + Keypad5, + Keypad6, + Keypad7, + Keypad8, + Keypad9, + KeypadDivide, + KeypadMultiply, + KeypadSubtract, + KeypadAdd, + KeypadDecimal, + KeypadEqual, + KeypadEnter, + + // Letters + A, B, C, D, E, F, G, + H, I, J, K, L, M, N, + O, P, Q, R, S, T, U, + V, W, X, Y, Z, + + // Numbers + Number0, + Number1, + Number2, + Number3, + Number4, + Number5, + Number6, + Number7, + Number8, + Number9, + + // Symbols + Minus, + Equal, + LeftBracket, + RightBracket, + Semicolon, + QuotationMark, + Comma, + FullStop, + Slash, + BackSlash, + + MaxKeys + } +} diff --git a/Source/OpenTK/Platform/Windows/API.cs b/Source/OpenTK/Platform/Windows/API.cs index 5b80ecd8..3ff33cdf 100644 --- a/Source/OpenTK/Platform/Windows/API.cs +++ b/Source/OpenTK/Platform/Windows/API.cs @@ -22,14 +22,26 @@ namespace OpenTK.Platform.Windows using HWND = System.IntPtr; using HINSTANCE = System.IntPtr; using HMENU = System.IntPtr; + + using LRESULT = System.IntPtr; using LPVOID = System.IntPtr; - using LONG = System.Int32; using LPCTSTR = System.String; - using DWORD = System.Int32; - using BOOL = System.Boolean; - using UINT = System.UInt32; + using WPARAM = System.IntPtr; using LPARAM = System.IntPtr; + using HANDLE = System.IntPtr; + using HRAWINPUT = System.IntPtr; + + using BYTE = System.Byte; + using SHORT = System.Int16; + using USHORT = System.UInt16; + using LONG = System.Int32; + using ULONG = System.UInt32; + using DWORD = System.Int32; + using BOOL = System.Boolean; + using INT = System.Int32; + using UINT = System.UInt32; + #endregion @@ -140,6 +152,8 @@ namespace OpenTK.Platform.Windows #region WINAPI methods + #region Message handling + #region PeekMessage [StructLayout(LayoutKind.Sequential)] @@ -245,6 +259,10 @@ namespace OpenTK.Platform.Windows #endregion + #endregion + + #region Timing + #region TimeBeginPeriod /// @@ -286,6 +304,10 @@ namespace OpenTK.Platform.Windows #endregion + #endregion + + #region Rendering + #region GetDC /// @@ -343,22 +365,6 @@ namespace OpenTK.Platform.Windows ); - #endregion - - #region SetWindowPos - - // WINUSERAPI BOOL WINAPI SetWindowPos(__in HWND hWnd, __in_opt HWND hWndInsertAfter, - // __in int X, __in int Y, __in int cx, __in int cy, __in UINT uFlags); - - [DllImport("user32.dll")] - [return: MarshalAs(UnmanagedType.Bool)] - internal static extern bool SetWindowPos( - IntPtr handle, - WindowPlacementOptions placement, - int x, int y, int cx, int cy, - SetWindowPosFlags flags - ); - #endregion #region SwapBuffers @@ -386,6 +392,17 @@ namespace OpenTK.Platform.Windows #endregion + #endregion + + #region DLL handling + + #region GetModuleHandle + + [DllImport("kernel32.dll")] + internal static extern IntPtr GetModuleHandle([MarshalAs(UnmanagedType.LPTStr)]string module_name); + + #endregion + #region LoadLibrary /// @@ -411,6 +428,26 @@ namespace OpenTK.Platform.Windows #endregion + #endregion + + #region Window Creation + + #region SetWindowPos + + // WINUSERAPI BOOL WINAPI SetWindowPos(__in HWND hWnd, __in_opt HWND hWndInsertAfter, + // __in int X, __in int Y, __in int cx, __in int cy, __in UINT uFlags); + + [DllImport("user32.dll")] + [return: MarshalAs(UnmanagedType.Bool)] + internal static extern bool SetWindowPos( + IntPtr handle, + WindowPlacementOptions placement, + int x, int y, int cx, int cy, + SetWindowPosFlags flags + ); + + #endregion + #region CreateWindowEx [DllImport("user32.dll", SetLastError = true, CharSet = CharSet.Auto)] @@ -548,13 +585,6 @@ namespace OpenTK.Platform.Windows #endregion - #region GetModuleHandle - - [DllImport("kernel32.dll")] - internal static extern IntPtr GetModuleHandle([MarshalAs(UnmanagedType.LPTStr)]string module_name); - - #endregion - #region RegisterClass [DllImport("user32.dll", SetLastError = true)] @@ -562,7 +592,7 @@ namespace OpenTK.Platform.Windows #endregion - #region + #region UnregisterClass [DllImport("user32.dll", SetLastError = true)] internal static extern short UnregisterClass(string className, IntPtr instance); @@ -572,6 +602,10 @@ namespace OpenTK.Platform.Windows #endregion + #endregion + + #region Display settings + #region int ChangeDisplaySettings(ref Gdi.DEVMODE devMode, int flags) /// /// @@ -591,28 +625,249 @@ namespace OpenTK.Platform.Windows #endregion + #endregion - // *********** Never use GetLastError! ************ + #region GetASsyncKeyState - //#region GetLastError + [System.Security.SuppressUnmanagedCodeSecurity] + [DllImport("user32.dll", SetLastError = true)] + public static extern SHORT GetAsyncKeyState(int vKey); - //[DllImport("kernel32.dll")] - //internal static extern int GetLastError(); + #endregion - //#endregion + #region Raw Input - //#region SetLastError + #region DefRawInputProc - //[DllImport("kernel32.dll")] - //internal static extern void SetLastError(int error_code); + /// + /// calls the default raw input procedure to provide default processing for + /// any raw input messages that an application does not process. + /// This function ensures that every message is processed. + /// DefRawInputProc is called with the same parameters received by the window procedure. + /// + /// Pointer to an array of RawInput structures. + /// Number of RawInput structures pointed to by paRawInput. + /// Size, in bytes, of the RawInputHeader structure. + /// If successful, the function returns S_OK. Otherwise it returns an error value. + [System.Security.SuppressUnmanagedCodeSecurity] + [DllImport("user32.dll", SetLastError = true)] + public static extern LRESULT DefRawInputProc( + RawInput[] RawInput, + INT Input, + UINT SizeHeader + ); - //#endregion + #endregion - //#region FormatMessage + #region RegisterRawInputDevices - //#endregion + /// + /// Registers the devices that supply the raw input data. + /// + /// + /// Pointer to an array of RawInputDevice structures that represent the devices that supply the raw input. + /// + /// + /// Number of RawInputDevice structures pointed to by RawInputDevices. + /// + /// + /// Size, in bytes, of a RAWINPUTDEVICE structure. + /// + /// + /// TRUE if the function succeeds; otherwise, FALSE. If the function fails, call GetLastError for more information. + /// + [DllImport("user32.dll", SetLastError = true)] + public static extern BOOL RegisterRawInputDevices( + RawInputDevice[] RawInputDevices, + UINT NumDevices, + UINT Size + ); + + #endregion + + #region GetRawInputBuffer + + /// + /// Does a buffered read of the raw input data. + /// + /// + /// Pointer to a buffer of RawInput structures that contain the raw input data. + /// If NULL, the minimum required buffer, in bytes, is returned in Size. + /// + /// Pointer to a variable that specifies the size, in bytes, of a RawInput structure. + /// Size, in bytes, of RawInputHeader. + /// + /// If Data is NULL and the function is successful, the return value is zero. + /// If Data is not NULL and the function is successful, the return value is the number + /// of RawInput structures written to Data. + /// If an error occurs, the return value is (UINT)-1. Call GetLastError for the error code. + /// + [System.Security.SuppressUnmanagedCodeSecurity] + [DllImport("user32.dll", SetLastError = true)] + public static extern UINT GetRawInputBuffer( + [Out] RawInput[] Data, + [In, Out] ref UINT Size, + [In] UINT SizeHeader + ); + + #endregion + + #region GetRegisteredRawInputDevices + + /// + /// Gets the information about the raw input devices for the current application. + /// + /// + /// Pointer to an array of RawInputDevice structures for the application. + /// + /// + /// Number of RawInputDevice structures in RawInputDevices. + /// + /// + /// Size, in bytes, of a RawInputDevice structure. + /// + /// + /// + /// If successful, the function returns a non-negative number that is + /// the number of RawInputDevice structures written to the buffer. + /// + /// + /// If the pRawInputDevices buffer is too small or NULL, the function sets + /// the last error as ERROR_INSUFFICIENT_BUFFER, returns -1, + /// and sets NumDevices to the required number of devices. + /// + /// + /// If the function fails for any other reason, it returns -1. For more details, call GetLastError. + /// + /// + [DllImport("user32.dll", SetLastError = true)] + public static extern UINT GetRegisteredRawInputDevices( + [Out] RawInput[] RawInputDevices, + [In, Out] ref UINT NumDevices, + UINT cbSize + ); + + #endregion + + #region GetRawInputDeviceList + + /// + /// Enumerates the raw input devices attached to the system. + /// + /// + /// ointer to buffer that holds an array of RawInputDeviceList structures + /// for the devices attached to the system. + /// If NULL, the number of devices are returned in NumDevices. + /// + /// + /// Pointer to a variable. If RawInputDeviceList is NULL, it specifies the number + /// of devices attached to the system. Otherwise, it contains the size, in bytes, + /// of the preallocated buffer pointed to by pRawInputDeviceList. + /// However, if NumDevices is smaller than needed to contain RawInputDeviceList structures, + /// the required buffer size is returned here. + /// + /// + /// Size of a RawInputDeviceList structure. + /// + /// + /// If the function is successful, the return value is the number of devices stored in the buffer + /// pointed to by RawInputDeviceList. + /// If RawInputDeviceList is NULL, the return value is zero. + /// If NumDevices is smaller than needed to contain all the RawInputDeviceList structures, + /// the return value is (UINT) -1 and the required buffer is returned in NumDevices. + /// Calling GetLastError returns ERROR_INSUFFICIENT_BUFFER. + /// On any other error, the function returns (UINT) -1 and GetLastError returns the error indication. + /// + [DllImport("user32.dll", SetLastError = true)] + public static extern UINT GetRawInputDeviceList( + [Out] RawInputDeviceList[] RawInputDeviceList, + [In, Out] ref UINT NumDevices, + UINT Size + ); + + #endregion + + #region GetRawInputDeviceInfo + + /// + /// Gets information about the raw input device. + /// + /// + /// Handle to the raw input device. This comes from the lParam of the WM_INPUT message, + /// from RawInputHeader.Device, or from GetRawInputDeviceList. + /// It can also be NULL if an application inserts input data, for example, by using SendInput. + /// + /// + /// Specifies what data will be returned in pData. It can be one of the following values. + /// RIDI_PREPARSEDDATA + /// Data points to the previously parsed data. + /// RIDI_DEVICENAME + /// Data points to a string that contains the device name. + /// For this Command only, the value in Size is the character count (not the byte count). + /// RIDI_DEVICEINFO + /// Data points to an RID_DEVICE_INFO structure. + /// + /// + /// ointer to a buffer that contains the information specified by Command. + /// If Command is RIDI_DEVICEINFO, set RawInputDeviceInfo.Size to sizeof(RawInputDeviceInfo) + /// before calling GetRawInputDeviceInfo. (This is done automatically in OpenTK) + /// + /// + /// Pointer to a variable that contains the size, in bytes, of the data in Data. + /// + /// + /// If successful, this function returns a non-negative number indicating the number of bytes copied to Data. + /// If Data is not large enough for the data, the function returns -1. If Data is NULL, the function returns a value of zero. In both of these cases, Size is set to the minimum size required for the Data buffer. + /// Call GetLastError to identify any other errors. + /// + [System.Security.SuppressUnmanagedCodeSecurity] + [DllImport("user32.dll", SetLastError = true)] + public static extern UINT GetRawInputDeviceInfo( + HANDLE Device, + UINT Command, + [In, Out] LPVOID Data, + [In, Out] ref UINT Size + ); + + #endregion + + #region GetRawInputData + + /// + /// Gets the raw input from the specified device. + /// + /// Handle to the RawInput structure. This comes from the lParam in WM_INPUT. + /// + /// Command flag. This parameter can be one of the following values. + /// RID_INPUT + /// Get the raw data from the RAWINPUT structure. + /// RID_HEADER + /// Get the header information from the RAWINPUT structure. + /// + /// Pointer to the data that comes from the RawInput structure. This depends on the value of uiCommand. If Data is NULL, the required size of the buffer is returned in Size. + /// Pointer to a variable that specifies the size, in bytes, of the data in Data. + /// Size, in bytes, of RawInputHeader. + /// + /// If Data is NULL and the function is successful, the return value is 0. If Data is not NULL and the function is successful, the return value is the number of bytes copied into Data. + /// If there is an error, the return value is (UINT)-1. + /// + /// + /// GetRawInputData gets the raw input one RawInput structure at a time. In contrast, GetRawInputBuffer gets an array of RawInput structures. + /// + [System.Security.SuppressUnmanagedCodeSecurity] + [DllImport("user32.dll", SetLastError = true)] + public static extern UINT GetRawInputData( + HRAWINPUT RawInput, + UINT Command, + [Out] LPVOID Data, + [In, Out] ref UINT Size, + UINT SizeHeader + ); + + #endregion + + #endregion - // ************************************************ #endregion #region WINAPI structs @@ -1071,6 +1326,455 @@ namespace OpenTK.Platform.Windows #endregion + #region Raw Input structures + + #region RawInputDevice + + /// + /// Defines information for the raw input devices. + /// + /// + /// If RIDEV_NOLEGACY is set for a mouse or a keyboard, the system does not generate any legacy message for that device for the application. For example, if the mouse TLC is set with RIDEV_NOLEGACY, WM_LBUTTONDOWN and related legacy mouse messages are not generated. Likewise, if the keyboard TLC is set with RIDEV_NOLEGACY, WM_KEYDOWN and related legacy keyboard messages are not generated. + /// + [StructLayout(LayoutKind.Sequential)] + public class RawInputDevice + { + /// + /// Top level collection Usage page for the raw input device. + /// + public USHORT UsagePage; + /// + /// Top level collection Usage for the raw input device. + /// + public USHORT Usage; + /// + /// Mode flag that specifies how to interpret the information provided by usUsagePage and usUsage. It can be zero (the default) or one of the following values. By default, the operating system sends raw input from devices with the specified top level collection (TLC) to the registered application as long as it has the window focus. + /// RIDEV_APPKEYS + /// Microsoft Windows XP Service Pack 1 (SP1): If set, the application command keys are handled. RIDEV_APPKEYS can be specified only if RIDEV_NOLEGACY is specified for a keyboard device. + /// RIDEV_CAPTUREMOUSE + /// If set, the mouse button click does not activate the other window. + /// RIDEV_EXCLUDE + /// If set, this specifies the top level collections to exclude when reading a complete usage page. This flag only affects a TLC whose usage page is already specified with RIDEV_PAGEONLY. + /// RIDEV_EXINPUTSINK + /// If set, this enables the caller to receive input in the background only if the foreground application does not process it. In other words, if the foreground application is not registered for raw input, then the background application that is registered will receive the input. + /// RIDEV_INPUTSINK + /// If set, this enables the caller to receive the input even when the caller is not in the foreground. Note that hwndTarget must be specified. + /// RIDEV_NOHOTKEYS + /// If set, the application-defined keyboard device hotkeys are not handled. However, the system hotkeys; for example, ALT+TAB and CTRL+ALT+DEL, are still handled. By default, all keyboard hotkeys are handled. RIDEV_NOHOTKEYS can be specified even if RIDEV_NOLEGACY is not specified and hwndTarget is NULL. + /// RIDEV_NOLEGACY + /// If set, this prevents any devices specified by usUsagePage or usUsage from generating legacy messages. This is only for the mouse and keyboard. See Remarks. + /// RIDEV_PAGEONLY + /// If set, this specifies all devices whose top level collection is from the specified usUsagePage. Note that usUsage must be zero. To exclude a particular top level collection, use RIDEV_EXCLUDE. + /// RIDEV_REMOVE + /// If set, this removes the top level collection from the inclusion list. This tells the operating system to stop reading from a device which matches the top level collection. + /// + public INT Flags; + /// + /// Handle to the target window. If NULL it follows the keyboard focus. + /// + public HWND Target; + } + + #endregion + + #region RawInputDeviceList + + /// + /// Contains information about a raw input device. + /// + [StructLayout(LayoutKind.Sequential)] + public class RawInputDeviceList + { + /// + /// Handle to the raw input device. + /// + public HANDLE Device; + /// + /// Type of device. This can be one of the following values. + /// RIM_TYPEHID + /// The device is an Human Interface Device (HID) that is not a keyboard and not a mouse. + /// RIM_TYPEKEYBOARD + /// The device is a keyboard. + /// RIM_TYPEMOUSE + /// The device is a mouse. + /// + public DWORD Type; + } + + #endregion + + #region RawInput + + /// + /// Contains the raw input from a device. + /// + /// + /// The handle to this structure is passed in the lParam parameter of WM_INPUT. + /// To get detailed information -- such as the header and the content of the raw input -- call GetRawInputData. + /// To get device specific information, call GetRawInputDeviceInfo with the hDevice from RAWINPUTHEADER. + /// Raw input is available only when the application calls RegisterRawInputDevices with valid device specifications. + /// + [StructLayout(LayoutKind.Sequential)] + public class RawInput + { + public RawInputHeader Header; + [StructLayout(LayoutKind.Explicit)] + public struct Data + { + [FieldOffset(0)] + public RawMouse Mouse; + [FieldOffset(0)] + public RawKeyboard Keyboard; + [FieldOffset(0)] + public RawHID HID; + } + } + + #endregion + + #region RawInputHeader + + /// + /// Contains the header information that is part of the raw input data. + /// + /// + /// To get more information on the device, use hDevice in a call to GetRawInputDeviceInfo. + /// + [StructLayout(LayoutKind.Sequential)] + public struct RawInputHeader + { + /// + /// Type of raw input. It can be one of the following values. + /// RIM_TYPEHID + /// Raw input comes from some device that is not a keyboard or a mouse. + /// RIM_TYPEKEYBOARD + /// Raw input comes from the keyboard. + /// RIM_TYPEMOUSE + /// Raw input comes from the mouse. + /// + public DWORD Type; + /// + /// Size, in bytes, of the entire input packet of data. This includesRAWINPUT plus possible extra input reports in the RAWHID variable length array. + /// + public DWORD Size; + /// + /// Handle to the device generating the raw input data. + /// + public HANDLE Device; + /// + /// Value passed in the wParam parameter of the WM_INPUT message. + /// + public WPARAM Param; + } + + #endregion + + #region RawKeyboard + + /// + /// Contains information about the state of the keyboard. + /// + [StructLayout(LayoutKind.Sequential)] + public struct RawKeyboard + { + /// + /// Scan code from the key depression. The scan code for keyboard overrun is KEYBOARD_OVERRUN_MAKE_CODE. + /// + public USHORT MakeCode; + /// + /// Flags for scan code information. It can be one or more of the following. + /// RI_KEY_MAKE + /// RI_KEY_BREAK + /// RI_KEY_E0 + /// RI_KEY_E1 + /// RI_KEY_TERMSRV_SET_LED + /// RI_KEY_TERMSRV_SHADOW + /// + public USHORT Flags; + /// + /// Reserved; must be zero. + /// + USHORT Reserved; + /// + /// Microsoft Windows message compatible virtual-key code. For more information, see Virtual-Key Codes. + /// + public USHORT VKey; + /// + /// Corresponding window message, for example WM_KEYDOWN, WM_SYSKEYDOWN, and so forth. + /// + public UINT Message; + /// + /// Device-specific additional information for the event. + /// + public ULONG ExtraInformation; + } + + #endregion + + #region RawMouse + + /// + /// Contains information about the state of the mouse. + /// + [StructLayout(LayoutKind.Explicit)] + public struct RawMouse + { + /// + /// Mouse state. This member can be any reasonable combination of the following. + /// MOUSE_ATTRIBUTES_CHANGED + /// Mouse attributes changed; application needs to query the mouse attributes. + /// MOUSE_MOVE_RELATIVE + /// Mouse movement data is relative to the last mouse position. + /// MOUSE_MOVE_ABSOLUTE + /// Mouse movement data is based on absolute position. + /// MOUSE_VIRTUAL_DESKTOP + /// Mouse coordinates are mapped to the virtual desktop (for a multiple monitor system). + /// + [FieldOffset(0)] + public USHORT Flags; + /// + /// Reserved. + /// + [FieldOffset(2)] + ULONG Buttons; + /// + /// Transition state of the mouse buttons. This member can be one or more of the following values. + /// RI_MOUSE_LEFT_BUTTON_DOWN + /// Left button changed to down. + /// RI_MOUSE_LEFT_BUTTON_UP + /// Left button changed to up. + /// RI_MOUSE_MIDDLE_BUTTON_DOWN + /// Middle button changed to down. + /// RI_MOUSE_MIDDLE_BUTTON_UP + /// Middle button changed to up. + /// RI_MOUSE_RIGHT_BUTTON_DOWN + /// Right button changed to down. + /// RI_MOUSE_RIGHT_BUTTON_UP + /// Right button changed to up. + /// RI_MOUSE_BUTTON_1_DOWN + /// RI_MOUSE_LEFT_BUTTON_DOWN + /// RI_MOUSE_BUTTON_1_UP + /// RI_MOUSE_LEFT_BUTTON_UP + /// RI_MOUSE_BUTTON_2_DOWN + /// RI_MOUSE_RIGHT_BUTTON_DOWN + /// RI_MOUSE_BUTTON_2_UP + /// RI_MOUSE_RIGHT_BUTTON_UP + /// RI_MOUSE_BUTTON_3_DOWN + /// RI_MOUSE_MIDDLE_BUTTON_DOWN + /// RI_MOUSE_BUTTON_3_UP + /// RI_MOUSE_MIDDLE_BUTTON_UP + /// RI_MOUSE_BUTTON_4_DOWN + /// XBUTTON1 changed to down. + /// RI_MOUSE_BUTTON_4_UP + /// XBUTTON1 changed to up. + /// RI_MOUSE_BUTTON_5_DOWN + /// XBUTTON2 changed to down. + /// RI_MOUSE_BUTTON_5_UP + /// XBUTTON2 changed to up. + /// RI_MOUSE_WHEEL + /// Raw input comes from a mouse wheel. The wheel delta is stored in usButtonData. + /// + [FieldOffset(2)] + public USHORT ButtonFlags; + /// + /// If usButtonFlags is RI_MOUSE_WHEEL, this member is a signed value that specifies the wheel delta. + /// + [FieldOffset(4)] + public USHORT ButtonData; + /// + /// Raw state of the mouse buttons. + /// + [FieldOffset(6)] + public ULONG RawButtons; + /// + /// Motion in the X direction. This is signed relative motion or absolute motion, depending on the value of usFlags. + /// + [FieldOffset(10)] + public LONG LastX; + /// + /// Motion in the Y direction. This is signed relative motion or absolute motion, depending on the value of usFlags. + /// + [FieldOffset(14)] + public LONG LastY; + /// + /// Device-specific additional information for the event. + /// + [FieldOffset(18)] + public ULONG ExtraInformation; + } + + #endregion + + #region RawHID + + /// + /// The RawHID structure describes the format of the raw input + /// from a Human Interface Device (HID). + /// + /// + /// Each WM_INPUT can indicate several inputs, but all of the inputs + /// come from the same HID. The size of the bRawData array is + /// dwSizeHid * dwCount. + /// + [StructLayout(LayoutKind.Sequential)] + public struct RawHID + { + /// + /// Size, in bytes, of each HID input in bRawData. + /// + public DWORD SizeHid; + /// + /// Number of HID inputs in bRawData. + /// + public DWORD Count; + /// + /// Raw input data as an array of bytes. + /// + public BYTE RawData; + } + + #endregion + + #region RawInputDeviceInfo + + /// + /// Defines the raw input data coming from any device. + /// + [StructLayout(LayoutKind.Sequential)] + public class RawInputDeviceInfo + { + /// + /// Size, in bytes, of the RawInputDeviceInfo structure. + /// + DWORD Size = Marshal.SizeOf(typeof(RawInputDeviceInfo)); + /// + /// Type of raw input data. This member can be one of the following values. + /// RIM_TYPEHID + /// Data comes from an HID that is not a keyboard or a mouse. + /// RIM_TYPEKEYBOARD + /// Data comes from a keyboard. + /// RIM_TYPEMOUSE + /// Data comes from a mouse. + /// + public DWORD Type; + [StructLayout(LayoutKind.Explicit)] + public struct Device + { + [FieldOffset(0)]RawInputMouseDeviceInfo Mouse; + [FieldOffset(0)]RawInputKeyboardDeviceInfo Keyboard; + [FieldOffset(0)]RawInputHIDDeviceInfo HID; + }; + } + + #endregion + + #region RawInputHIDDeviceInfo + + /// + /// Defines the raw input data coming from the specified Human Interface Device (HID). + /// + [StructLayout(LayoutKind.Sequential)] + public struct RawInputHIDDeviceInfo + { + /// + /// Vendor ID for the HID. + /// + public DWORD VendorId; + /// + /// Product ID for the HID. + /// + public DWORD ProductId; + /// + /// Version number for the HID. + /// + public DWORD VersionNumber; + /// + /// Top-level collection Usage Page for the device. + /// + public USHORT UsagePage; + /// + /// Top-level collection Usage for the device. + /// + public USHORT Usage; + } + + #endregion + + #region RawInputKeyboardDeviceInfo + + /// + /// Defines the raw input data coming from the specified keyboard. + /// + /// + /// For the keyboard, the Usage Page is 1 and the Usage is 6. + /// + [StructLayout(LayoutKind.Sequential)] + public struct RawInputKeyboardDeviceInfo + { + /// + /// Type of the keyboard. + /// + public DWORD Type; + /// + /// Subtype of the keyboard. + /// + public DWORD SubType; + /// + /// Scan code mode. + /// + public DWORD KeyboardMode; + /// + /// Number of function keys on the keyboard. + /// + public DWORD NumberOfFunctionKeys; + /// + /// Number of LED indicators on the keyboard. + /// + public DWORD NumberOfIndicators; + /// + /// Total number of keys on the keyboard. + /// + public DWORD NumberOfKeysTotal; + } + + #endregion + + #region RawInputMouseDeviceInfo + + /// + /// Defines the raw input data coming from the specified mouse. + /// + /// + /// For the keyboard, the Usage Page is 1 and the Usage is 2. + /// + [StructLayout(LayoutKind.Sequential)] + public struct RawInputMouseDeviceInfo + { + /// + /// ID for the mouse device. + /// + public DWORD Id; + /// + /// Number of buttons for the mouse. + /// + public DWORD NumberOfButtons; + /// + /// Number of data points per second. This information may not be applicable for every mouse device. + /// + public DWORD SampleRate; + /// + /// TRUE if the mouse has a wheel for horizontal scrolling; otherwise, FALSE. + /// + /// + /// This member is only supported under Microsoft Windows Vista and later versions. + /// + public BOOL HasHorizontalWheel; + } + + #endregion + + #endregion + #endregion #region Callbacks diff --git a/Source/OpenTK/Platform/Windows/WinGLNative.cs b/Source/OpenTK/Platform/Windows/WinGLNative.cs index e741ed61..1f66a509 100644 --- a/Source/OpenTK/Platform/Windows/WinGLNative.cs +++ b/Source/OpenTK/Platform/Windows/WinGLNative.cs @@ -191,7 +191,7 @@ namespace OpenTK.Platform.Windows switch ((int)m.WParam) { case API.Constants.VK_ESCAPE: - Key.Escape = (m.Msg == API.Constants.WM_KEYDOWN) ? true : false; + //= (m.Msg == API.Constants.WM_KEYDOWN) ? true : false; return true; }