mirror of
https://github.com/Ryujinx/Opentk.git
synced 2025-01-10 11:15:40 +00:00
Added KeyDown and KeyUp events to IKeyboard and Keyboard.
Improved input logger test to hook on the aforementioned events. Removed Debug printing of keys in OpenTK.Input.Keyboard. Beautified X11Keyboard.cs Added experimental code to handle X11 keyboard events (not used yet).
This commit is contained in:
parent
ffe8ce7795
commit
c689f50a21
|
@ -60,6 +60,24 @@ namespace Examples.Tests
|
||||||
public S02_RawInput_Logger()
|
public S02_RawInput_Logger()
|
||||||
{
|
{
|
||||||
this.CreateWindow(new OpenTK.Platform.DisplayMode(100, 100));
|
this.CreateWindow(new OpenTK.Platform.DisplayMode(100, 100));
|
||||||
|
|
||||||
|
foreach (OpenTK.Input.Keyboard k in this.Keyboard)
|
||||||
|
{
|
||||||
|
k.KeyDown += new OpenTK.Input.KeyDownEvent(LogKeyDown);
|
||||||
|
k.KeyUp += new OpenTK.Input.KeyUpEvent(LogKeyUp);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
void LogKeyDown(object sender, OpenTK.Input.Key key)
|
||||||
|
{
|
||||||
|
Trace.WriteLine(String.Format("OpenTK key {0} pressed on Keyboard: ({1}).",
|
||||||
|
key, sender as OpenTK.Input.Keyboard));
|
||||||
|
}
|
||||||
|
|
||||||
|
void LogKeyUp(object sender, OpenTK.Input.Key key)
|
||||||
|
{
|
||||||
|
Trace.WriteLine(String.Format("OpenTK key {0} released on Keyboard: ({1}).",
|
||||||
|
key, sender as OpenTK.Input.Keyboard));
|
||||||
}
|
}
|
||||||
|
|
||||||
public override void OnLoad(EventArgs e)
|
public override void OnLoad(EventArgs e)
|
||||||
|
@ -75,6 +93,7 @@ namespace Examples.Tests
|
||||||
|
|
||||||
GL.Clear(GL.Enums.ClearBufferMask.COLOR_BUFFER_BIT);
|
GL.Clear(GL.Enums.ClearBufferMask.COLOR_BUFFER_BIT);
|
||||||
Context.SwapBuffers();
|
Context.SwapBuffers();
|
||||||
|
Thread.Sleep(1);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -13,5 +13,17 @@ namespace OpenTK.Input
|
||||||
int NumberOfFunctionKeys { get; }
|
int NumberOfFunctionKeys { get; }
|
||||||
int NumberOfLeds { get; }
|
int NumberOfLeds { get; }
|
||||||
long DeviceID { get; }
|
long DeviceID { get; }
|
||||||
|
|
||||||
|
event KeyDownEvent KeyDown;
|
||||||
|
event KeyUpEvent KeyUp;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public delegate void KeyDownEvent(object sender, Key key);
|
||||||
|
public delegate void KeyUpEvent(object sender, Key key);
|
||||||
|
|
||||||
|
//public class KeyEventArgs : System.EventArgs
|
||||||
|
//{
|
||||||
|
// private Key key;
|
||||||
|
// public Key Key { get { return key; } }
|
||||||
|
//}
|
||||||
}
|
}
|
|
@ -15,7 +15,7 @@ using System.Diagnostics;
|
||||||
|
|
||||||
namespace OpenTK.Input
|
namespace OpenTK.Input
|
||||||
{
|
{
|
||||||
public class Keyboard : IKeyboard
|
public sealed class Keyboard : IKeyboard
|
||||||
{
|
{
|
||||||
//private IKeyboard keyboard;
|
//private IKeyboard keyboard;
|
||||||
private bool[] keys = new bool[(int)Key.MaxKeys];
|
private bool[] keys = new bool[(int)Key.MaxKeys];
|
||||||
|
@ -38,8 +38,16 @@ namespace OpenTK.Input
|
||||||
get { return keys[(int)k]; }
|
get { return keys[(int)k]; }
|
||||||
internal set
|
internal set
|
||||||
{
|
{
|
||||||
Debug.Print("OpenTK key {0} {1}.", k, value ? "pressed" : "released");
|
|
||||||
keys[(int)k] = value;
|
keys[(int)k] = value;
|
||||||
|
|
||||||
|
if (value && KeyDown != null)
|
||||||
|
{
|
||||||
|
KeyDown(this, k);
|
||||||
|
}
|
||||||
|
else if (!value && KeyUp != null)
|
||||||
|
{
|
||||||
|
KeyUp(this, k);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -70,6 +78,16 @@ namespace OpenTK.Input
|
||||||
internal set { devID = value; }
|
internal set { devID = value; }
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Occurs when a key is pressed.
|
||||||
|
/// </summary>
|
||||||
|
public event KeyDownEvent KeyDown;
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Occurs when a key is released.
|
||||||
|
/// </summary>
|
||||||
|
public event KeyUpEvent KeyUp;
|
||||||
|
|
||||||
#endregion
|
#endregion
|
||||||
|
|
||||||
#region --- IInputDevice Members ---
|
#region --- IInputDevice Members ---
|
||||||
|
@ -87,6 +105,8 @@ namespace OpenTK.Input
|
||||||
|
|
||||||
#endregion
|
#endregion
|
||||||
|
|
||||||
|
#region --- Public Methods ---
|
||||||
|
|
||||||
public override int GetHashCode()
|
public override int GetHashCode()
|
||||||
{
|
{
|
||||||
//return base.GetHashCode();
|
//return base.GetHashCode();
|
||||||
|
@ -96,9 +116,11 @@ namespace OpenTK.Input
|
||||||
public override string ToString()
|
public override string ToString()
|
||||||
{
|
{
|
||||||
//return base.ToString();
|
//return base.ToString();
|
||||||
return String.Format("Keyboard: '{0}', {1} keys, {2} function keys, {3} leds. Device ID: {4}",
|
return String.Format("ID: {0} (keys: {1}, function keys: {2}, leds: {3}",
|
||||||
description, NumberOfKeys, NumberOfFunctionKeys, NumberOfLeds, DeviceID);
|
DeviceID, NumberOfKeys, NumberOfFunctionKeys, NumberOfLeds);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#endregion
|
||||||
}
|
}
|
||||||
|
|
||||||
#region public enum Key : int
|
#region public enum Key : int
|
||||||
|
|
|
@ -133,6 +133,16 @@ namespace OpenTK.Platform.X11
|
||||||
{
|
{
|
||||||
keyboardDriver.ProcessKeyboardEvent(e.KeyEvent);
|
keyboardDriver.ProcessKeyboardEvent(e.KeyEvent);
|
||||||
}
|
}
|
||||||
|
/*
|
||||||
|
if (API.Pending(window.Display) > 0)
|
||||||
|
{
|
||||||
|
Functions.XPeekEvent(window.Display, ref e);
|
||||||
|
if (e.type == XEventName.KeyRelease || e.type == XEventName.KeyPress)
|
||||||
|
{
|
||||||
|
keyboardDriver.ProcessKeyboardEvent(e.KeyEvent);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
*/
|
||||||
}
|
}
|
||||||
|
|
||||||
#endregion
|
#endregion
|
||||||
|
|
|
@ -204,21 +204,20 @@ namespace OpenTK.Platform.X11
|
||||||
switch (keysym.ToInt64())
|
switch (keysym.ToInt64())
|
||||||
{
|
{
|
||||||
default:
|
default:
|
||||||
if (keymap.ContainsKey((XKey)keysym))
|
if (keymap.ContainsKey((XKey)keysym))
|
||||||
{
|
{
|
||||||
keyboards[0][keymap[(XKey)keysym]] = pressed;
|
keyboards[0][keymap[(XKey)keysym]] = pressed;
|
||||||
}
|
}
|
||||||
else if (keymap.ContainsKey((XKey)keysym2))
|
else if (keymap.ContainsKey((XKey)keysym2))
|
||||||
{
|
{
|
||||||
keyboards[0][keymap[(XKey)keysym2]] = pressed;
|
keyboards[0][keymap[(XKey)keysym2]] = pressed;
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
Debug.Print("KeyCode {0} (Keysym: {1}, {2}) not mapped.", e.keycode, (XKey)keysym, (XKey)keysym2);
|
Debug.Print("KeyCode {0} (Keysym: {1}, {2}) not mapped.", e.keycode, (XKey)keysym, (XKey)keysym2);
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
return true;
|
return true;
|
||||||
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue