mirror of
https://github.com/Ryujinx/Opentk.git
synced 2025-01-10 17:05:35 +00:00
Merge remote-tracking branch 'origin/ScanCodeKeyboardBranch'
This commit is contained in:
commit
6c35e8ef24
|
@ -52,6 +52,7 @@ namespace Examples
|
||||||
// The ExampleBrowser works pretty poorly on some platforms, so you may want to start examples directly.
|
// The ExampleBrowser works pretty poorly on some platforms, so you may want to start examples directly.
|
||||||
// for example: Examples.Tutorial.T12_GLSL_Parallax.Main ();
|
// for example: Examples.Tutorial.T12_GLSL_Parallax.Main ();
|
||||||
// Examples.Tutorial.T10_GLSL_Cube.Main ();
|
// Examples.Tutorial.T10_GLSL_Cube.Main ();
|
||||||
|
Examples.Tests.BasicMouseInput.Main ();
|
||||||
|
|
||||||
using (Form browser = new ExampleBrowser())
|
using (Form browser = new ExampleBrowser())
|
||||||
{
|
{
|
||||||
|
|
|
@ -25,7 +25,7 @@ namespace Examples.Tests
|
||||||
{
|
{
|
||||||
|
|
||||||
public BasicMouseInput()
|
public BasicMouseInput()
|
||||||
: base(800, 600, GraphicsMode.Default)
|
: base(800, 600)
|
||||||
{ }
|
{ }
|
||||||
|
|
||||||
protected override void OnLoad(EventArgs e)
|
protected override void OnLoad(EventArgs e)
|
||||||
|
@ -42,6 +42,8 @@ namespace Examples.Tests
|
||||||
|
|
||||||
protected override void OnUpdateFrame(FrameEventArgs e)
|
protected override void OnUpdateFrame(FrameEventArgs e)
|
||||||
{
|
{
|
||||||
|
base.OnUpdateFrame(e);
|
||||||
|
|
||||||
// Here's the big test!
|
// Here's the big test!
|
||||||
if(OpenTK.Input.Mouse.GetState()[MouseButton.Left]){
|
if(OpenTK.Input.Mouse.GetState()[MouseButton.Left]){
|
||||||
Console.WriteLine("The left mouse button is down!");
|
Console.WriteLine("The left mouse button is down!");
|
||||||
|
@ -66,7 +68,7 @@ namespace Examples.Tests
|
||||||
|
|
||||||
protected override void OnRenderFrame(FrameEventArgs e)
|
protected override void OnRenderFrame(FrameEventArgs e)
|
||||||
{
|
{
|
||||||
GL.Clear(ClearBufferMask.ColorBufferBit | ClearBufferMask.DepthBufferBit);
|
GL.Clear(ClearBufferMask.ColorBufferBit);
|
||||||
SwapBuffers();
|
SwapBuffers();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -78,7 +80,8 @@ namespace Examples.Tests
|
||||||
// Get the title and category of this example using reflection.
|
// Get the title and category of this example using reflection.
|
||||||
ExampleAttribute info = ((ExampleAttribute)example.GetType().GetCustomAttributes(false)[0]);
|
ExampleAttribute info = ((ExampleAttribute)example.GetType().GetCustomAttributes(false)[0]);
|
||||||
example.Title = String.Format("OpenTK | {0} {1}: {2}", info.Category, info.Difficulty, info.Title);
|
example.Title = String.Format("OpenTK | {0} {1}: {2}", info.Category, info.Difficulty, info.Title);
|
||||||
example.Run(30.0, 0.0);
|
|
||||||
|
example.Run(30.0);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -22,6 +22,7 @@ namespace OpenTK.Input
|
||||||
{
|
{
|
||||||
//private IKeyboard keyboard;
|
//private IKeyboard keyboard;
|
||||||
private bool[] keys = new bool[Enum.GetValues(typeof(Key)).Length];
|
private bool[] keys = new bool[Enum.GetValues(typeof(Key)).Length];
|
||||||
|
private bool[] scancodes = new bool[256];
|
||||||
private string description;
|
private string description;
|
||||||
private int numKeys, numFKeys, numLeds;
|
private int numKeys, numFKeys, numLeds;
|
||||||
private IntPtr devID;
|
private IntPtr devID;
|
||||||
|
@ -44,24 +45,16 @@ namespace OpenTK.Input
|
||||||
public bool this[Key key]
|
public bool this[Key key]
|
||||||
{
|
{
|
||||||
get { return keys[(int)key]; }
|
get { return keys[(int)key]; }
|
||||||
internal set
|
}
|
||||||
{
|
|
||||||
if (keys[(int)key] != value || KeyRepeat)
|
|
||||||
{
|
|
||||||
keys[(int)key] = value;
|
|
||||||
|
|
||||||
if (value && KeyDown != null)
|
/// <summary>
|
||||||
{
|
/// Gets a value indicating the status of the specified Key.
|
||||||
args.Key = key;
|
/// </summary>
|
||||||
KeyDown(this, args);
|
/// <param name="scancode">The scancode to check.</param>
|
||||||
}
|
/// <returns>True if the scancode is pressed, false otherwise.</returns>
|
||||||
else if (!value && KeyUp != null)
|
public bool this[uint scancode]
|
||||||
{
|
{
|
||||||
args.Key = key;
|
get { return scancodes[scancode]; }
|
||||||
KeyUp(this, args);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/// <summary>
|
/// <summary>
|
||||||
|
@ -197,12 +190,34 @@ namespace OpenTK.Input
|
||||||
internal void ClearKeys()
|
internal void ClearKeys()
|
||||||
{
|
{
|
||||||
for (int i = 0; i < keys.Length; i++)
|
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.
|
keys[i] = false;
|
||||||
this[(Key)i] = false;
|
for (uint i = 0; i < scancodes.Length; i++)
|
||||||
|
scancodes[i] = false;
|
||||||
}
|
}
|
||||||
|
|
||||||
#endregion
|
#endregion
|
||||||
|
|
||||||
|
internal void SetKey(Key key, uint scancode, bool state)
|
||||||
|
{
|
||||||
|
if (keys[(int)key] != state || KeyRepeat)
|
||||||
|
{
|
||||||
|
keys[(int)key] = scancodes[scancode] = state;
|
||||||
|
|
||||||
|
if (state && KeyDown != null)
|
||||||
|
{
|
||||||
|
args.Key = key;
|
||||||
|
args.ScanCode = scancode;
|
||||||
|
KeyDown(this, args);
|
||||||
|
}
|
||||||
|
else if (!state && KeyUp != null)
|
||||||
|
{
|
||||||
|
args.Key = key;
|
||||||
|
args.ScanCode = scancode;
|
||||||
|
KeyUp(this, args);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
#endregion
|
#endregion
|
||||||
}
|
}
|
||||||
}
|
}
|
|
@ -1,83 +1,95 @@
|
||||||
#region License
|
#region License
|
||||||
//
|
//
|
||||||
// The Open Toolkit Library License
|
// The Open Toolkit Library License
|
||||||
//
|
//
|
||||||
// Copyright (c) 2006 - 2009 the Open Toolkit library.
|
// Copyright (c) 2006 - 2009 the Open Toolkit library.
|
||||||
//
|
//
|
||||||
// Permission is hereby granted, free of charge, to any person obtaining a copy
|
// Permission is hereby granted, free of charge, to any person obtaining a copy
|
||||||
// of this software and associated documentation files (the "Software"), to deal
|
// of this software and associated documentation files (the "Software"), to deal
|
||||||
// in the Software without restriction, including without limitation the rights to
|
// in the Software without restriction, including without limitation the rights to
|
||||||
// use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of
|
// use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of
|
||||||
// the Software, and to permit persons to whom the Software is furnished to do
|
// the Software, and to permit persons to whom the Software is furnished to do
|
||||||
// so, subject to the following conditions:
|
// so, subject to the following conditions:
|
||||||
//
|
//
|
||||||
// The above copyright notice and this permission notice shall be included in all
|
// The above copyright notice and this permission notice shall be included in all
|
||||||
// copies or substantial portions of the Software.
|
// copies or substantial portions of the Software.
|
||||||
//
|
//
|
||||||
// THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
|
// THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
|
||||||
// EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES
|
// EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES
|
||||||
// OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
|
// OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
|
||||||
// NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT
|
// NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT
|
||||||
// HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY,
|
// HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY,
|
||||||
// WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING
|
// WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING
|
||||||
// FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR
|
// FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR
|
||||||
// OTHER DEALINGS IN THE SOFTWARE.
|
// OTHER DEALINGS IN THE SOFTWARE.
|
||||||
//
|
//
|
||||||
#endregion
|
#endregion
|
||||||
|
|
||||||
using System;
|
using System;
|
||||||
using System.Collections.Generic;
|
using System.Collections.Generic;
|
||||||
using System.Text;
|
using System.Text;
|
||||||
|
|
||||||
namespace OpenTK.Input
|
namespace OpenTK.Input
|
||||||
{
|
{
|
||||||
/// <summary>
|
/// <summary>
|
||||||
/// Defines the event data for <see cref="KeyboardDevice"/> events.
|
/// Defines the event data for <see cref="KeyboardDevice"/> events.
|
||||||
/// </summary>
|
/// </summary>
|
||||||
/// <remarks>
|
/// <remarks>
|
||||||
/// <para>
|
/// <para>
|
||||||
/// Do not cache instances of this type outside their event handler.
|
/// Do not cache instances of this type outside their event handler.
|
||||||
/// If necessary, you can clone a KeyboardEventArgs instance using the
|
/// If necessary, you can clone a KeyboardEventArgs instance using the
|
||||||
/// <see cref="KeyboardKeyEventArgs(KeyboardKeyEventArgs)"/> constructor.
|
/// <see cref="KeyboardKeyEventArgs(KeyboardKeyEventArgs)"/> constructor.
|
||||||
/// </para>
|
/// </para>
|
||||||
/// </remarks>
|
/// </remarks>
|
||||||
public class KeyboardKeyEventArgs : EventArgs
|
public class KeyboardKeyEventArgs : EventArgs
|
||||||
{
|
{
|
||||||
#region Fields
|
#region Fields
|
||||||
|
|
||||||
Key key;
|
Key key;
|
||||||
|
uint scancode;
|
||||||
#endregion
|
|
||||||
|
#endregion
|
||||||
#region Constructors
|
|
||||||
|
#region Constructors
|
||||||
/// <summary>
|
|
||||||
/// Constructs a new KeyboardEventArgs instance.
|
/// <summary>
|
||||||
/// </summary>
|
/// Constructs a new KeyboardEventArgs instance.
|
||||||
public KeyboardKeyEventArgs() { }
|
/// </summary>
|
||||||
|
public KeyboardKeyEventArgs() { }
|
||||||
/// <summary>
|
|
||||||
/// Constructs a new KeyboardEventArgs instance.
|
/// <summary>
|
||||||
/// </summary>
|
/// Constructs a new KeyboardEventArgs instance.
|
||||||
/// <param name="args">An existing KeyboardEventArgs instance to clone.</param>
|
/// </summary>
|
||||||
public KeyboardKeyEventArgs(KeyboardKeyEventArgs args)
|
/// <param name="args">An existing KeyboardEventArgs instance to clone.</param>
|
||||||
{
|
public KeyboardKeyEventArgs(KeyboardKeyEventArgs args)
|
||||||
Key = args.Key;
|
{
|
||||||
}
|
Key = args.Key;
|
||||||
|
ScanCode = args.ScanCode;
|
||||||
#endregion
|
}
|
||||||
|
|
||||||
#region Public Members
|
#endregion
|
||||||
|
|
||||||
/// <summary>
|
#region Public Members
|
||||||
/// Gets the <see cref="Key"/> that generated this event.
|
|
||||||
/// </summary>
|
/// <summary>
|
||||||
public Key Key
|
/// Gets the <see cref="Key"/> that generated this event.
|
||||||
{
|
/// </summary>
|
||||||
get { return key; }
|
public Key Key
|
||||||
internal set { key = value; }
|
{
|
||||||
}
|
get { return key; }
|
||||||
|
internal set { key = value; }
|
||||||
#endregion
|
}
|
||||||
}
|
|
||||||
}
|
/// <summary>
|
||||||
|
/// Gets the scancode which generated this event.
|
||||||
|
/// </summary>
|
||||||
|
public uint ScanCode
|
||||||
|
{
|
||||||
|
get { return scancode; }
|
||||||
|
internal set { scancode = value; }
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
#endregion
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
|
@ -43,6 +43,7 @@ namespace OpenTK.Input
|
||||||
const int NumInts = ((int)Key.LastKey + IntSize - 1) / IntSize;
|
const int NumInts = ((int)Key.LastKey + IntSize - 1) / IntSize;
|
||||||
// The following line triggers bogus CS0214 in gmcs 2.0.1, sigh...
|
// The following line triggers bogus CS0214 in gmcs 2.0.1, sigh...
|
||||||
unsafe fixed int Keys[NumInts];
|
unsafe fixed int Keys[NumInts];
|
||||||
|
unsafe fixed int Codes[256];
|
||||||
bool is_connected;
|
bool is_connected;
|
||||||
|
|
||||||
#endregion
|
#endregion
|
||||||
|
@ -58,13 +59,17 @@ namespace OpenTK.Input
|
||||||
public bool this[Key key]
|
public bool this[Key key]
|
||||||
{
|
{
|
||||||
get { return IsKeyDown(key); }
|
get { return IsKeyDown(key); }
|
||||||
internal set
|
}
|
||||||
{
|
|
||||||
if (value)
|
/// <summary>
|
||||||
EnableBit((int)key);
|
/// Gets a <see cref="System.Boolean"/> indicating whether the specified
|
||||||
else
|
/// <see cref="OpenTK.Input.Key"/> is pressed.
|
||||||
DisableBit((int)key);
|
/// </summary>
|
||||||
}
|
/// <param name="key">The <see cref="OpenTK.Input.Key"/> to check.</param>
|
||||||
|
/// <returns>True if key is pressed; false otherwise.</returns>
|
||||||
|
public bool this[short code]
|
||||||
|
{
|
||||||
|
get { return IsKeyDown(code); }
|
||||||
}
|
}
|
||||||
|
|
||||||
/// <summary>
|
/// <summary>
|
||||||
|
@ -76,6 +81,15 @@ namespace OpenTK.Input
|
||||||
return ReadBit((int)key);
|
return ReadBit((int)key);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Gets a <see cref="System.Boolean"/> indicating whether this scan code is down.
|
||||||
|
/// </summary>
|
||||||
|
/// <param name="code">The scan code to check.</param>
|
||||||
|
public bool IsKeyDown(short code)
|
||||||
|
{
|
||||||
|
return ReadBit(code,true);
|
||||||
|
}
|
||||||
|
|
||||||
/// <summary>
|
/// <summary>
|
||||||
/// Gets a <see cref="System.Boolean"/> indicating whether this key is up.
|
/// Gets a <see cref="System.Boolean"/> indicating whether this key is up.
|
||||||
/// </summary>
|
/// </summary>
|
||||||
|
@ -85,6 +99,15 @@ namespace OpenTK.Input
|
||||||
return !ReadBit((int)key);
|
return !ReadBit((int)key);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Gets a <see cref="System.Boolean"/> indicating whether this scan code is down.
|
||||||
|
/// </summary>
|
||||||
|
/// <param name="code">The scan code to check.</param>
|
||||||
|
public bool IsKeyUp(short code)
|
||||||
|
{
|
||||||
|
return !ReadBit(code,true);
|
||||||
|
}
|
||||||
|
|
||||||
/// <summary>
|
/// <summary>
|
||||||
/// Gets a <see cref="System.Boolean"/> indicating whether this keyboard
|
/// Gets a <see cref="System.Boolean"/> indicating whether this keyboard
|
||||||
/// is connected.
|
/// is connected.
|
||||||
|
@ -187,48 +210,62 @@ namespace OpenTK.Input
|
||||||
|
|
||||||
#region Internal Members
|
#region Internal Members
|
||||||
|
|
||||||
internal bool ReadBit(int offset)
|
internal void SetKeyState(Key key, byte code, bool down)
|
||||||
{
|
{
|
||||||
ValidateOffset(offset);
|
if (down)
|
||||||
|
|
||||||
int int_offset = offset / 32;
|
|
||||||
int bit_offset = offset % 32;
|
|
||||||
unsafe
|
|
||||||
{
|
{
|
||||||
fixed (int* k = Keys)
|
EnableBit((int)key);
|
||||||
{
|
EnableBit(code,true);
|
||||||
return (*(k + int_offset) & (1 << bit_offset)) != 0u;
|
}
|
||||||
}
|
else
|
||||||
|
{
|
||||||
|
DisableBit((int)key);
|
||||||
|
DisableBit(code, true);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
internal void EnableBit(int offset)
|
internal bool ReadBit(int offset, bool ScanCode = false)
|
||||||
{
|
{
|
||||||
ValidateOffset(offset);
|
ValidateOffset(offset, ScanCode);
|
||||||
|
|
||||||
int int_offset = offset / 32;
|
int int_offset = offset / 32;
|
||||||
int bit_offset = offset % 32;
|
int bit_offset = offset % 32;
|
||||||
unsafe
|
unsafe
|
||||||
{
|
{
|
||||||
fixed (int* k = Keys)
|
if (ScanCode)
|
||||||
{
|
fixed (int* c = Codes) { return (*(c + int_offset) & (1 << bit_offset)) != 0u; }
|
||||||
*(k + int_offset) |= 1 << bit_offset;
|
else
|
||||||
}
|
fixed (int* k = Keys) { return (*(k + int_offset) & (1 << bit_offset)) != 0u; }
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
internal void DisableBit(int offset)
|
internal void EnableBit(int offset, bool ScanCode = false)
|
||||||
{
|
{
|
||||||
ValidateOffset(offset);
|
ValidateOffset(offset, ScanCode);
|
||||||
|
|
||||||
int int_offset = offset / 32;
|
int int_offset = offset / 32;
|
||||||
int bit_offset = offset % 32;
|
int bit_offset = offset % 32;
|
||||||
unsafe
|
unsafe
|
||||||
{
|
{
|
||||||
fixed (int* k = Keys)
|
if (ScanCode)
|
||||||
{
|
fixed (int* c = Codes) { *(c + int_offset) |= 1 << bit_offset; }
|
||||||
*(k + int_offset) &= ~(1 << bit_offset);
|
else
|
||||||
}
|
fixed (int* k = Keys) { *(k + int_offset) |= 1 << bit_offset; }
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
internal void DisableBit(int offset, bool ScanCode = false)
|
||||||
|
{
|
||||||
|
ValidateOffset(offset, ScanCode);
|
||||||
|
|
||||||
|
int int_offset = offset / 32;
|
||||||
|
int bit_offset = offset % 32;
|
||||||
|
unsafe
|
||||||
|
{
|
||||||
|
if (ScanCode)
|
||||||
|
fixed (int* c = Codes) { *(c + int_offset) &= ~(1 << bit_offset); }
|
||||||
|
else
|
||||||
|
fixed (int* k = Keys) { *(k + int_offset) &= ~(1 << bit_offset); }
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -242,6 +279,12 @@ namespace OpenTK.Input
|
||||||
for (int i = 0; i < NumInts; i++)
|
for (int i = 0; i < NumInts; i++)
|
||||||
*(k1 + i) |= *(k2 + i);
|
*(k1 + i) |= *(k2 + i);
|
||||||
}
|
}
|
||||||
|
int* c2 = other.Codes;
|
||||||
|
fixed (int* c1 = Codes)
|
||||||
|
{
|
||||||
|
for (int i = 0; i < short.MaxValue; i++)
|
||||||
|
*(c1 + i) |= *(c2 + i);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
IsConnected |= other.IsConnected;
|
IsConnected |= other.IsConnected;
|
||||||
}
|
}
|
||||||
|
@ -250,9 +293,9 @@ namespace OpenTK.Input
|
||||||
|
|
||||||
#region Private Members
|
#region Private Members
|
||||||
|
|
||||||
static void ValidateOffset(int offset)
|
static void ValidateOffset(int offset, bool ScanCode)
|
||||||
{
|
{
|
||||||
if (offset < 0 || offset >= NumInts * IntSize)
|
if (offset < 0 || offset >= (ScanCode ? 256 : NumInts * IntSize))
|
||||||
throw new ArgumentOutOfRangeException("offset");
|
throw new ArgumentOutOfRangeException("offset");
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -368,6 +368,7 @@ namespace OpenTK.Platform.MacOS
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
OpenTK.Input.Key key;
|
||||||
switch (evt.KeyboardEventKind)
|
switch (evt.KeyboardEventKind)
|
||||||
{
|
{
|
||||||
case KeyboardEventKind.RawKeyRepeat:
|
case KeyboardEventKind.RawKeyRepeat:
|
||||||
|
@ -376,25 +377,15 @@ namespace OpenTK.Platform.MacOS
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case KeyboardEventKind.RawKeyDown:
|
case KeyboardEventKind.RawKeyDown:
|
||||||
{
|
Keymap.TryGetValue(code, out key);
|
||||||
OpenTK.Input.Key key;
|
InputDriver.Keyboard[0].SetKey(key, (uint)code, true);
|
||||||
if (Keymap.TryGetValue(code, out key))
|
OnKeyPress(mKeyPressArgs);
|
||||||
{
|
|
||||||
InputDriver.Keyboard[0][key] = true;
|
|
||||||
OnKeyPress(mKeyPressArgs);
|
|
||||||
}
|
|
||||||
return OSStatus.NoError;
|
return OSStatus.NoError;
|
||||||
}
|
|
||||||
|
|
||||||
case KeyboardEventKind.RawKeyUp:
|
case KeyboardEventKind.RawKeyUp:
|
||||||
{
|
Keymap.TryGetValue(code, out key);
|
||||||
OpenTK.Input.Key key;
|
InputDriver.Keyboard[0].SetKey(key, (uint)code, false);
|
||||||
if (Keymap.TryGetValue(code, out key))
|
|
||||||
{
|
|
||||||
InputDriver.Keyboard[0][key] = false;
|
|
||||||
}
|
|
||||||
return OSStatus.NoError;
|
return OSStatus.NoError;
|
||||||
}
|
|
||||||
|
|
||||||
case KeyboardEventKind.RawKeyModifiersChanged:
|
case KeyboardEventKind.RawKeyModifiersChanged:
|
||||||
ProcessModifierKey(inEvent);
|
ProcessModifierKey(inEvent);
|
||||||
|
@ -614,21 +605,21 @@ namespace OpenTK.Platform.MacOS
|
||||||
Debug.Print("Modifiers Changed: {0}", modifiers);
|
Debug.Print("Modifiers Changed: {0}", modifiers);
|
||||||
|
|
||||||
Input.KeyboardDevice keyboard = InputDriver.Keyboard[0];
|
Input.KeyboardDevice keyboard = InputDriver.Keyboard[0];
|
||||||
|
|
||||||
if (keyboard[OpenTK.Input.Key.AltLeft] ^ option)
|
if (keyboard[OpenTK.Input.Key.AltLeft] ^ option)
|
||||||
keyboard[OpenTK.Input.Key.AltLeft] = option;
|
keyboard.SetKey(OpenTK.Input.Key.AltLeft, (uint)MacOSKeyModifiers.Option, option);
|
||||||
|
|
||||||
if (keyboard[OpenTK.Input.Key.ShiftLeft] ^ shift)
|
if (keyboard[OpenTK.Input.Key.ShiftLeft] ^ shift)
|
||||||
keyboard[OpenTK.Input.Key.ShiftLeft] = shift;
|
keyboard.SetKey(OpenTK.Input.Key.ShiftLeft, (uint)MacOSKeyModifiers.Shift, shift);
|
||||||
|
|
||||||
if (keyboard[OpenTK.Input.Key.WinLeft] ^ command)
|
if (keyboard[OpenTK.Input.Key.WinLeft] ^ command)
|
||||||
keyboard[OpenTK.Input.Key.WinLeft] = command;
|
keyboard.SetKey(OpenTK.Input.Key.WinLeft, (uint)MacOSKeyModifiers.Command, command);
|
||||||
|
|
||||||
if (keyboard[OpenTK.Input.Key.ControlLeft] ^ control)
|
if (keyboard[OpenTK.Input.Key.ControlLeft] ^ control)
|
||||||
keyboard[OpenTK.Input.Key.ControlLeft] = control;
|
keyboard.SetKey(OpenTK.Input.Key.ControlLeft, (uint)MacOSKeyModifiers.Control, control);
|
||||||
|
|
||||||
if (keyboard[OpenTK.Input.Key.CapsLock] ^ caps)
|
if (keyboard[OpenTK.Input.Key.CapsLock] ^ caps)
|
||||||
keyboard[OpenTK.Input.Key.CapsLock] = caps;
|
keyboard.SetKey(OpenTK.Input.Key.CapsLock, (uint)MacOSKeyModifiers.CapsLock, caps);
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -263,14 +263,12 @@ namespace OpenTK.Platform.MacOS
|
||||||
{
|
{
|
||||||
case HIDPage.GenericDesktop:
|
case HIDPage.GenericDesktop:
|
||||||
case HIDPage.KeyboardOrKeypad:
|
case HIDPage.KeyboardOrKeypad:
|
||||||
int raw = (int) usage;
|
if (usage >= RawKeyMap.Length)
|
||||||
if (raw >= RawKeyMap.Length)
|
|
||||||
{
|
{
|
||||||
Debug.Print("[Warning] Key {0} not mapped.", raw);
|
Debug.Print("[Warning] Key {0} not mapped.", usage);
|
||||||
return state;
|
return state;
|
||||||
}
|
}
|
||||||
Key key = RawKeyMap[raw];
|
state.SetKeyState(RawKeyMap[usage], (byte)usage, v_int != 0);
|
||||||
state[key] = v_int != 0;
|
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -70,14 +70,12 @@ namespace OpenTK.Platform.Windows
|
||||||
|
|
||||||
void UpdateKeyboard()
|
void UpdateKeyboard()
|
||||||
{
|
{
|
||||||
for (int i = 0; i < 256; i++)
|
for (byte i = 0; i < byte.MaxValue; i++)
|
||||||
{
|
{
|
||||||
VirtualKeys key = (VirtualKeys)i;
|
bool pressed = (Functions.GetAsyncKeyState((VirtualKeys)i) >> 8) != 0;
|
||||||
bool pressed = (Functions.GetAsyncKeyState(key) >> 8) != 0;
|
Key key;
|
||||||
if (KeyMap.ContainsKey(key))
|
KeyMap.TryGetValue((VirtualKeys)i,out key);
|
||||||
{
|
keyboard.SetKeyState(key, i, pressed);
|
||||||
keyboard[KeyMap[key]] = pressed;
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -89,7 +89,13 @@ namespace OpenTK.Platform.Windows
|
||||||
IList<KeyboardDevice> keyboards = new List<KeyboardDevice>(1);
|
IList<KeyboardDevice> keyboards = new List<KeyboardDevice>(1);
|
||||||
IList<MouseDevice> mice = new List<MouseDevice>(1);
|
IList<MouseDevice> mice = new List<MouseDevice>(1);
|
||||||
const long ExtendedBit = 1 << 24; // Used to distinguish left and right control, alt and enter keys.
|
const long ExtendedBit = 1 << 24; // Used to distinguish left and right control, alt and enter keys.
|
||||||
static readonly uint ShiftRightScanCode = Functions.MapVirtualKey(VirtualKeys.RSHIFT, 0); // Used to distinguish left and right shift keys.
|
|
||||||
|
public static readonly uint ShiftLeftScanCode = Functions.MapVirtualKey(VirtualKeys.LSHIFT, 0);
|
||||||
|
public static readonly uint ShiftRightScanCode = Functions.MapVirtualKey(VirtualKeys.RSHIFT, 0);
|
||||||
|
public static readonly uint ControlLeftScanCode = Functions.MapVirtualKey(VirtualKeys.LCONTROL, 0);
|
||||||
|
public static readonly uint ControlRightScanCode = Functions.MapVirtualKey(VirtualKeys.RCONTROL, 0);
|
||||||
|
public static readonly uint AltLeftScanCode = Functions.MapVirtualKey(VirtualKeys.LMENU, 0);
|
||||||
|
public static readonly uint AltRightScanCode = Functions.MapVirtualKey(VirtualKeys.RMENU, 0);
|
||||||
|
|
||||||
KeyPressEventArgs key_press = new KeyPressEventArgs((char)0);
|
KeyPressEventArgs key_press = new KeyPressEventArgs((char)0);
|
||||||
|
|
||||||
|
@ -369,6 +375,8 @@ namespace OpenTK.Platform.Windows
|
||||||
// In this case, both keys will be reported as pressed.
|
// In this case, both keys will be reported as pressed.
|
||||||
|
|
||||||
bool extended = (lParam.ToInt64() & ExtendedBit) != 0;
|
bool extended = (lParam.ToInt64() & ExtendedBit) != 0;
|
||||||
|
uint scancode = (uint)((lParam.ToInt64() >> 16) & 0xFF);
|
||||||
|
Key key = Key.Unknown;
|
||||||
switch ((VirtualKeys)wParam)
|
switch ((VirtualKeys)wParam)
|
||||||
{
|
{
|
||||||
case VirtualKeys.SHIFT:
|
case VirtualKeys.SHIFT:
|
||||||
|
@ -382,55 +390,50 @@ namespace OpenTK.Platform.Windows
|
||||||
// Otherwise, the state of one key might be stuck to pressed.
|
// Otherwise, the state of one key might be stuck to pressed.
|
||||||
if (ShiftRightScanCode != 0 && pressed)
|
if (ShiftRightScanCode != 0 && pressed)
|
||||||
{
|
{
|
||||||
unchecked
|
if (scancode == ShiftRightScanCode)
|
||||||
{
|
key = Input.Key.ShiftRight;
|
||||||
if (((lParam.ToInt64() >> 16) & 0xFF) == ShiftRightScanCode)
|
else
|
||||||
keyboard[Input.Key.ShiftRight] = pressed;
|
key = Input.Key.ShiftLeft;
|
||||||
else
|
|
||||||
keyboard[Input.Key.ShiftLeft] = pressed;
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
// Windows 9x and NT4.0 or key release event.
|
// Windows 9x and NT4.0 or key release event.
|
||||||
keyboard[Input.Key.ShiftLeft] = keyboard[Input.Key.ShiftRight] = pressed;
|
keyboard.SetKey(Input.Key.ShiftLeft, ShiftLeftScanCode, pressed);
|
||||||
|
keyboard.SetKey(Input.Key.ShiftRight, ShiftRightScanCode, pressed);
|
||||||
}
|
}
|
||||||
return IntPtr.Zero;
|
break;
|
||||||
|
|
||||||
case VirtualKeys.CONTROL:
|
case VirtualKeys.CONTROL:
|
||||||
if (extended)
|
if (extended)
|
||||||
keyboard[Input.Key.ControlRight] = pressed;
|
key = Input.Key.ControlRight;
|
||||||
else
|
else
|
||||||
keyboard[Input.Key.ControlLeft] = pressed;
|
key = Input.Key.ControlLeft;
|
||||||
return IntPtr.Zero;
|
break;
|
||||||
|
|
||||||
case VirtualKeys.MENU:
|
case VirtualKeys.MENU:
|
||||||
if (extended)
|
if (extended)
|
||||||
keyboard[Input.Key.AltRight] = pressed;
|
key = Input.Key.AltRight;
|
||||||
else
|
else
|
||||||
keyboard[Input.Key.AltLeft] = pressed;
|
key = Input.Key.AltLeft;
|
||||||
return IntPtr.Zero;
|
break;
|
||||||
|
|
||||||
case VirtualKeys.RETURN:
|
case VirtualKeys.RETURN:
|
||||||
if (extended)
|
if (extended)
|
||||||
keyboard[Key.KeypadEnter] = pressed;
|
key = Key.KeypadEnter;
|
||||||
else
|
else
|
||||||
keyboard[Key.Enter] = pressed;
|
key = Key.Enter;
|
||||||
return IntPtr.Zero;
|
break;
|
||||||
|
|
||||||
default:
|
default:
|
||||||
if (!KeyMap.ContainsKey((VirtualKeys)wParam))
|
if (!KeyMap.ContainsKey((VirtualKeys)wParam))
|
||||||
{
|
|
||||||
Debug.Print("Virtual key {0} ({1}) not mapped.", (VirtualKeys)wParam, (long)lParam);
|
Debug.Print("Virtual key {0} ({1}) not mapped.", (VirtualKeys)wParam, (long)lParam);
|
||||||
break;
|
|
||||||
}
|
|
||||||
else
|
else
|
||||||
{
|
key = KeyMap[(VirtualKeys)wParam];
|
||||||
keyboard[KeyMap[(VirtualKeys)wParam]] = pressed;
|
break;
|
||||||
}
|
|
||||||
return IntPtr.Zero;
|
|
||||||
}
|
}
|
||||||
break;
|
|
||||||
|
keyboard.SetKey(key, scancode, pressed);
|
||||||
|
return IntPtr.Zero;
|
||||||
|
|
||||||
case WindowMessage.SYSCHAR:
|
case WindowMessage.SYSCHAR:
|
||||||
return IntPtr.Zero;
|
return IntPtr.Zero;
|
||||||
|
|
|
@ -180,31 +180,30 @@ namespace OpenTK.Platform.Windows
|
||||||
switch (rin.Data.Keyboard.VKey)
|
switch (rin.Data.Keyboard.VKey)
|
||||||
{
|
{
|
||||||
case VirtualKeys.SHIFT:
|
case VirtualKeys.SHIFT:
|
||||||
keyboard[Input.Key.ShiftLeft] = keyboard[Input.Key.ShiftRight] = pressed;
|
keyboard.SetKeyState(Key.ShiftLeft, (byte)WinGLNative.ShiftLeftScanCode, pressed);
|
||||||
|
keyboard.SetKeyState(Key.ShiftRight, (byte)WinGLNative.ShiftRightScanCode, pressed);
|
||||||
processed = true;
|
processed = true;
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case VirtualKeys.CONTROL:
|
case VirtualKeys.CONTROL:
|
||||||
keyboard[Input.Key.ControlLeft] = keyboard[Input.Key.ControlRight] = pressed;
|
keyboard.SetKeyState(Key.ControlLeft, (byte)WinGLNative.ControlLeftScanCode, pressed);
|
||||||
|
keyboard.SetKeyState(Key.ControlRight, (byte)WinGLNative.ControlRightScanCode, pressed);
|
||||||
processed = true;
|
processed = true;
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case VirtualKeys.MENU:
|
case VirtualKeys.MENU:
|
||||||
keyboard[Input.Key.AltLeft] = keyboard[Input.Key.AltRight] = pressed;
|
keyboard.SetKeyState(Key.AltLeft, (byte)WinGLNative.AltLeftScanCode, pressed);
|
||||||
|
keyboard.SetKeyState(Key.AltRight, (byte)WinGLNative.AltRightScanCode, pressed);
|
||||||
processed = true;
|
processed = true;
|
||||||
break;
|
break;
|
||||||
|
|
||||||
default:
|
default:
|
||||||
if (!KeyMap.ContainsKey(rin.Data.Keyboard.VKey))
|
Key key;
|
||||||
{
|
KeyMap.TryGetValue(rin.Data.Keyboard.VKey, out key);
|
||||||
Debug.Print("Virtual key {0} ({1}) not mapped.",
|
if (key == Key.Unknown)
|
||||||
rin.Data.Keyboard.VKey, (int)rin.Data.Keyboard.VKey);
|
Debug.Print("Virtual key {0} ({1}) not mapped.", rin.Data.Keyboard.VKey, (int)rin.Data.Keyboard.VKey);
|
||||||
}
|
keyboard.SetKeyState(key, BitConverter.GetBytes(rin.Data.Keyboard.MakeCode)[0], pressed);
|
||||||
else
|
processed = true;
|
||||||
{
|
|
||||||
keyboard[KeyMap[rin.Data.Keyboard.VKey]] = pressed;
|
|
||||||
processed = true;
|
|
||||||
}
|
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -157,20 +157,22 @@ namespace OpenTK.Platform.X11
|
||||||
case XEventName.KeyPress:
|
case XEventName.KeyPress:
|
||||||
case XEventName.KeyRelease:
|
case XEventName.KeyRelease:
|
||||||
bool pressed = e.type == XEventName.KeyPress;
|
bool pressed = e.type == XEventName.KeyPress;
|
||||||
|
XKey keysym = (XKey)API.LookupKeysym(ref e.KeyEvent, 0);
|
||||||
|
XKey keysym2 = (XKey)API.LookupKeysym(ref e.KeyEvent, 1);
|
||||||
|
Key key = Key.Unknown;
|
||||||
|
|
||||||
IntPtr keysym = API.LookupKeysym(ref e.KeyEvent, 0);
|
if (keymap.ContainsKey(keysym))
|
||||||
IntPtr keysym2 = API.LookupKeysym(ref e.KeyEvent, 1);
|
key = keymap[keysym];
|
||||||
|
else if (keymap.ContainsKey(keysym2))
|
||||||
if (keymap.ContainsKey((XKey)keysym))
|
key = keymap[keysym2];
|
||||||
keyboard[keymap[(XKey)keysym]] = pressed;
|
|
||||||
else if (keymap.ContainsKey((XKey)keysym2))
|
|
||||||
keyboard[keymap[(XKey)keysym2]] = pressed;
|
|
||||||
else
|
else
|
||||||
Debug.Print("KeyCode {0} (Keysym: {1}, {2}) not mapped.", e.KeyEvent.keycode, (XKey)keysym, (XKey)keysym2);
|
Debug.Print("KeyCode {0} (Keysym: {1}, {2}) not mapped.", e.KeyEvent.keycode, (XKey)keysym, (XKey)keysym2);
|
||||||
|
|
||||||
|
keyboard.SetKey(key, (uint)e.KeyEvent.keycode, pressed);
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case XEventName.ButtonPress:
|
case XEventName.ButtonPress:
|
||||||
if (e.ButtonEvent.button == 1) mouse[OpenTK.Input.MouseButton.Left] = true;
|
if (e.ButtonEvent.button == 1) mouse[OpenTK.Input.MouseButton.Left] = true;
|
||||||
else if (e.ButtonEvent.button == 2) mouse[OpenTK.Input.MouseButton.Middle] = true;
|
else if (e.ButtonEvent.button == 2) mouse[OpenTK.Input.MouseButton.Middle] = true;
|
||||||
else if (e.ButtonEvent.button == 3) mouse[OpenTK.Input.MouseButton.Right] = true;
|
else if (e.ButtonEvent.button == 3) mouse[OpenTK.Input.MouseButton.Right] = true;
|
||||||
else if (e.ButtonEvent.button == 4) mouse.Wheel++;
|
else if (e.ButtonEvent.button == 4) mouse.Wheel++;
|
||||||
|
@ -190,7 +192,7 @@ namespace OpenTK.Platform.X11
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case XEventName.ButtonRelease:
|
case XEventName.ButtonRelease:
|
||||||
if (e.ButtonEvent.button == 1) mouse[OpenTK.Input.MouseButton.Left] = false;
|
if (e.ButtonEvent.button == 1) mouse[OpenTK.Input.MouseButton.Left] = false;
|
||||||
else if (e.ButtonEvent.button == 2) mouse[OpenTK.Input.MouseButton.Middle] = false;
|
else if (e.ButtonEvent.button == 2) mouse[OpenTK.Input.MouseButton.Middle] = false;
|
||||||
else if (e.ButtonEvent.button == 3) mouse[OpenTK.Input.MouseButton.Right] = false;
|
else if (e.ButtonEvent.button == 3) mouse[OpenTK.Input.MouseButton.Right] = false;
|
||||||
else if (e.ButtonEvent.button == 6) mouse[OpenTK.Input.MouseButton.Button1] = false;
|
else if (e.ButtonEvent.button == 6) mouse[OpenTK.Input.MouseButton.Button1] = false;
|
||||||
|
|
Loading…
Reference in a new issue