#region --- License --- /* Copyright (c) 2007 Stefanos Apostolopoulos * See license.txt for license info */ #endregion #region --- Using directives --- using System; using OpenTK.Input; using System.Diagnostics; #endregion namespace OpenTK.Input { /// /// Represents a keyboard device and provides methods to query its status. /// public sealed class KeyboardDevice : IInputDevice { //private IKeyboard keyboard; private bool[] keys = new bool[Enum.GetValues(typeof(Key)).Length]; private string description; private int numKeys, numFKeys, numLeds; private IntPtr devID; private bool repeat; #region --- Constructors --- internal KeyboardDevice() { } #endregion #region --- IKeyboard members --- /// /// Gets a value indicating the status of the specified Key. /// /// The Key to check. /// True if the Key is pressed, false otherwise. public bool this[Key key] { get { return keys[(int)key]; } internal set { if (keys[(int)key] != value || KeyRepeat) { keys[(int)key] = value; if (value && KeyDown != null) KeyDown(this, key); else if (!value && KeyUp != null) KeyUp(this, key); } } } /// /// Gets an integer representing the number of keys on this KeyboardDevice. /// public int NumberOfKeys { get { return numKeys; } internal set { numKeys = value; } } /// /// Gets an integer representing the number of function keys (F-keys) on this KeyboardDevice. /// public int NumberOfFunctionKeys { get { return numFKeys; } internal set { numFKeys = value; } } /// /// Gets a value indicating the number of led indicators on this KeyboardDevice. /// public int NumberOfLeds { get { return numLeds; } internal set { numLeds = value; } } /// /// Gets an IntPtr representing a device dependent ID. /// public IntPtr DeviceID { get { return devID; } internal set { devID = value; } } #region public bool KeyRepeat /// /// Gets or sets a System.Boolean indicating key repeat status. /// /// /// If KeyRepeat is true, multiple KeyDown events will be generated while a key is being held. /// Otherwise only one KeyDown event will be reported. /// /// The rate of the generated KeyDown events is controlled by the Operating System. Usually, /// one KeyDown event will be reported, followed by a small (250-1000ms) pause and several /// more KeyDown events (6-30 events per second). /// /// /// Set to true to handle text input (where keyboard repeat is desirable), but set to false /// for game input. /// /// public bool KeyRepeat { get { return repeat; } set { repeat = value; } } #endregion #region public event KeyDownEvent KeyDown; /// /// Occurs when a key is pressed. /// public event KeyDownEvent KeyDown; #endregion #region public event KeyUpEvent KeyUp; /// /// Occurs when a key is released. /// public event KeyUpEvent KeyUp; #endregion #endregion #region --- IInputDevice Members --- public string Description { get { return description; } internal set { description = value; } } public InputDeviceType DeviceType { get { return InputDeviceType.Keyboard; } } #endregion #region --- Public Methods --- /// Returns the hash code for this KeyboardDevice. /// A 32-bit signed integer hash code. public override int GetHashCode() { //return base.GetHashCode(); return (int)(numKeys ^ numFKeys ^ numLeds ^ devID.GetHashCode() ^ description.GetHashCode()); } /// /// Returns a System.String representing this KeyboardDevice. /// /// A System.String representing this KeyboardDevice. public override string ToString() { //return base.ToString(); return String.Format("ID: {0} ({1}). Keys: {2}, Function keys: {3}, Leds: {4}", DeviceID, Description, NumberOfKeys, NumberOfFunctionKeys, NumberOfLeds); } #endregion #region --- Internal Methods --- #region internal void ClearKeys() internal void ClearKeys() { for (int i = 0; i < keys.Length; i++) if (this[(Key)i]) // Make sure KeyUp events are *not* raised for keys that are up, even if key repeat is on. this[(Key)i] = false; } #endregion #endregion } public delegate void KeyDownEvent(KeyboardDevice sender, Key key); public delegate void KeyUpEvent(KeyboardDevice sender, Key key); #region public enum Key : int /// /// The available keyboard keys. /// public enum Key : int { /// A key outside the known keys. Unknown = 0, // Modifiers /// The left shift key. ShiftLeft, /// The left shift key (equivalent to ShiftLeft). LShift = ShiftLeft, /// The right shift key. ShiftRight, /// The right shift key (equivalent to ShiftRight). RShift = ShiftRight, /// The left control key. ControlLeft, /// The left control key (equivalent to ControlLeft). LControl = ControlLeft, /// The right control key. ControlRight, /// The right control key (equivalent to ControlRight). RControl = ControlRight, /// The left alt key. AltLeft, /// The left alt key (equivalent to AltLeft. LAlt = AltLeft, /// The right alt key. AltRight, /// The right alt key (equivalent to AltRight). RAlt = AltRight, /// The left win key. WinLeft, /// The left win key (equivalent to WinLeft). LWin = WinLeft, /// The right win key. WinRight, /// The right win key (equivalent to WinRight). RWin = WinRight, /// The menu key. Menu, // Function keys (hopefully enough for most keyboards - mine has 26) // on X11 reports up to 35 function keys. /// The F1 key. F1, /// The F2 key. F2, /// The F3 key. F3, /// The F4 key. F4, /// The F5 key. F5, /// The F6 key. F6, /// The F7 key. F7, /// The F8 key. F8, /// The F9 key. F9, /// The F10 key. F10, /// The F11 key. F11, /// The F12 key. F12, /// The F13 key. F13, /// The F14 key. F14, /// The F15 key. F15, /// The F16 key. F16, /// The F17 key. F17, /// The F18 key. F18, /// The F19 key. F19, /// The F20 key. F20, /// The F21 key. F21, /// The F22 key. F22, /// The F23 key. F23, /// The F24 key. F24, /// The F25 key. F25, /// The F26 key. F26, /// The F27 key. F27, /// The F28 key. F28, /// The F29 key. F29, /// The F30 key. F30, /// The F31 key. F31, /// The F32 key. F32, /// The F33 key. F33, /// The F34 key. F34, /// The F35 key. F35, // Direction arrows /// The up arrow key. Up, /// The down arrow key. Down, /// The left arrow key. Left, /// The right arrow key. Right, /// The enter key. Enter, /// The escape key. Escape, /// The space key. Space, /// The tab key. Tab, /// The backspace key. BackSpace, /// The backspace key (equivalent to BackSpace). Back = BackSpace, /// The insert key. Insert, /// The delete key. Delete, /// The page up key. PageUp, /// The page down key. PageDown, /// The home key. Home, /// The end key. End, /// The caps lock key. CapsLock, /// The scroll lock key. ScrollLock, /// The print screen key. PrintScreen, /// The pause key. Pause, /// The num lock key. NumLock, // Special keys /// The clear key (Keypad5 with NumLock disabled, on typical keyboards). Clear, /// The sleep key. Sleep, /*LogOff, Help, Undo, Redo, New, Open, Close, Reply, Forward, Send, Spell, Save, Calculator, // Folders and applications Documents, Pictures, Music, MediaPlayer, Mail, Browser, Messenger, // Multimedia keys Mute, PlayPause, Stop, VolumeUp, VolumeDown, TrackPrevious, TrackNext,*/ // Keypad keys /// The keypad 0 key. Keypad0, /// The keypad 1 key. Keypad1, /// The keypad 2 key. Keypad2, /// The keypad 3 key. Keypad3, /// The keypad 4 key. Keypad4, /// The keypad 5 key. Keypad5, /// The keypad 6 key. Keypad6, /// The keypad 7 key. Keypad7, /// The keypad 8 key. Keypad8, /// The keypad 9 key. Keypad9, /// The keypad divide key. KeypadDivide, /// The keypad multiply key. KeypadMultiply, /// The keypad subtract key. KeypadSubtract, /// The keypad minus key (equivalent to KeypadSubtract). KeypadMinus = KeypadSubtract, /// The keypad add key. KeypadAdd, /// The keypad plus key (equivalent to KeypadAdd). KeypadPlus = KeypadAdd, /// The keypad decimal key. KeypadDecimal, /// The keypad enter key. KeypadEnter, // Letters /// The A key. A, /// The B key. B, /// The C key. C, /// The D key. D, /// The E key. E, /// The F key. F, /// The G key. G, /// The H key. H, /// The I key. I, /// The J key. J, /// The K key. K, /// The L key. L, /// The M key. M, /// The N key. N, /// The O key. O, /// The P key. P, /// The Q key. Q, /// The R key. R, /// The S key. S, /// The T key. T, /// The U key. U, /// The V key. V, /// The W key. W, /// The X key. X, /// The Y key. Y, /// The Z key. Z, // Numbers /// The number 0 key. Number0, /// The number 1 key. Number1, /// The number 2 key. Number2, /// The number 3 key. Number3, /// The number 4 key. Number4, /// The number 5 key. Number5, /// The number 6 key. Number6, /// The number 7 key. Number7, /// The number 8 key. Number8, /// The number 9 key. Number9, // Symbols /// The tilde key. Tilde, /// The minus key. Minus, //Equal, /// The plus key. Plus, /// The left bracket key. BracketLeft, /// The left bracket key (equivalent to BracketLeft). LBracket = BracketLeft, /// The right bracket key. BracketRight, /// The right bracket key (equivalent to BracketRight). RBracket = BracketRight, /// The semicolon key. Semicolon, /// The quote key. Quote, /// The comma key. Comma, /// The period key. Period, /// The slash key. Slash, /// The backslash key. BackSlash, } #endregion }