mirror of
https://github.com/Ryujinx/Opentk.git
synced 2025-02-03 18:01:04 +00:00
Implemented mouse and keyboard driver.
This commit is contained in:
parent
8d6872f8b8
commit
b71519eac5
|
@ -1,4 +1,10 @@
|
||||||
using System;
|
#region --- License ---
|
||||||
|
/* Copyright (c) 2007 Stefanos Apostolopoulos
|
||||||
|
* See license.txt for license information
|
||||||
|
*/
|
||||||
|
#endregion
|
||||||
|
|
||||||
|
using System;
|
||||||
using System.Collections.Generic;
|
using System.Collections.Generic;
|
||||||
using System.Text;
|
using System.Text;
|
||||||
using System.Windows.Forms;
|
using System.Windows.Forms;
|
||||||
|
@ -18,6 +24,7 @@ namespace OpenTK.Platform.Windows
|
||||||
MouseDevice mouse = new MouseDevice();
|
MouseDevice mouse = new MouseDevice();
|
||||||
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);
|
||||||
|
internal static readonly KeyMap KeyMap = new KeyMap();
|
||||||
|
|
||||||
#region --- Constructor ---
|
#region --- Constructor ---
|
||||||
|
|
||||||
|
@ -50,16 +57,83 @@ namespace OpenTK.Platform.Windows
|
||||||
{
|
{
|
||||||
switch ((WindowMessage)msg.Msg)
|
switch ((WindowMessage)msg.Msg)
|
||||||
{
|
{
|
||||||
|
// Mouse events:
|
||||||
case WindowMessage.MOUSEMOVE:
|
case WindowMessage.MOUSEMOVE:
|
||||||
break;
|
//case WindowMessage.NCMOUSEMOVE:
|
||||||
|
mouse.X = msg.LParam.ToInt32() & 0x0000FFFF;
|
||||||
|
mouse.Y = (int)(msg.LParam.ToInt32() & 0xFFFF0000) >> 16;
|
||||||
|
|
||||||
|
return;
|
||||||
|
|
||||||
case WindowMessage.MOUSEWHEEL:
|
case WindowMessage.MOUSEWHEEL:
|
||||||
break;
|
mouse.Wheel += (int)(msg.WParam.ToInt32() >> 16) / 120;
|
||||||
|
return;
|
||||||
|
|
||||||
|
case WindowMessage.LBUTTONDOWN:
|
||||||
|
mouse[MouseButton.Left] = true;
|
||||||
|
return;
|
||||||
|
|
||||||
|
case WindowMessage.MBUTTONDOWN:
|
||||||
|
mouse[MouseButton.Middle] = true;
|
||||||
|
return;
|
||||||
|
|
||||||
|
case WindowMessage.RBUTTONDOWN:
|
||||||
|
mouse[MouseButton.Right] = true;
|
||||||
|
return;
|
||||||
|
|
||||||
|
case WindowMessage.XBUTTONDOWN:
|
||||||
|
mouse[((msg.WParam.ToInt32() & 0xFFFF0000) >> 16) != (int)MouseKeys.XButton1 ? MouseButton.Button1 : MouseButton.Button2] = true;
|
||||||
|
return;
|
||||||
|
|
||||||
|
case WindowMessage.LBUTTONUP:
|
||||||
|
mouse[MouseButton.Left] = false;
|
||||||
|
return;
|
||||||
|
|
||||||
|
case WindowMessage.MBUTTONUP:
|
||||||
|
mouse[MouseButton.Middle] = false;
|
||||||
|
return;
|
||||||
|
|
||||||
|
case WindowMessage.RBUTTONUP:
|
||||||
|
mouse[MouseButton.Right] = false;
|
||||||
|
return;
|
||||||
|
|
||||||
|
case WindowMessage.XBUTTONUP:
|
||||||
|
mouse[((msg.WParam.ToInt32() & 0xFFFF0000) >> 16) != (int)MouseKeys.XButton1 ? MouseButton.Button1 : MouseButton.Button2] = false;
|
||||||
|
return;
|
||||||
|
|
||||||
|
// Keyboard events:
|
||||||
case WindowMessage.KEYDOWN:
|
case WindowMessage.KEYDOWN:
|
||||||
break;
|
|
||||||
|
|
||||||
case WindowMessage.KEYUP:
|
case WindowMessage.KEYUP:
|
||||||
|
case WindowMessage.SYSKEYDOWN:
|
||||||
|
case WindowMessage.SYSKEYUP:
|
||||||
|
bool pressed = (WindowMessage)msg.Msg == WindowMessage.KEYDOWN ||
|
||||||
|
(WindowMessage)msg.Msg == WindowMessage.SYSKEYDOWN;
|
||||||
|
switch ((VirtualKeys)msg.WParam)
|
||||||
|
{
|
||||||
|
case VirtualKeys.SHIFT:
|
||||||
|
keyboard[Input.Key.ShiftLeft] = keyboard[Input.Key.ShiftRight] = pressed;
|
||||||
|
return;
|
||||||
|
|
||||||
|
case VirtualKeys.CONTROL:
|
||||||
|
keyboard[Input.Key.ControlLeft] = keyboard[Input.Key.ControlRight] = pressed;
|
||||||
|
return;
|
||||||
|
|
||||||
|
case VirtualKeys.MENU:
|
||||||
|
keyboard[Input.Key.AltLeft] = keyboard[Input.Key.AltRight] = pressed;
|
||||||
|
return;
|
||||||
|
|
||||||
|
default:
|
||||||
|
if (!WMInput.KeyMap.ContainsKey((VirtualKeys)msg.WParam))
|
||||||
|
{
|
||||||
|
Debug.Print("Virtual key {0} ({1}) not mapped.", (VirtualKeys)msg.WParam, (int)msg.WParam);
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
keyboard[WMInput.KeyMap[(VirtualKeys)msg.WParam]] = pressed;
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
}
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -93,11 +167,30 @@ namespace OpenTK.Platform.Windows
|
||||||
|
|
||||||
#endregion
|
#endregion
|
||||||
|
|
||||||
#region IDisposable Members
|
#region --- IDisposable Members ---
|
||||||
|
|
||||||
|
private bool disposed;
|
||||||
|
|
||||||
public void Dispose()
|
public void Dispose()
|
||||||
{
|
{
|
||||||
|
Dispose(true);
|
||||||
|
GC.SuppressFinalize(this);
|
||||||
|
}
|
||||||
|
|
||||||
|
private void Dispose(bool manual)
|
||||||
|
{
|
||||||
|
if (!disposed)
|
||||||
|
{
|
||||||
|
if (manual)
|
||||||
|
this.ReleaseHandle();
|
||||||
|
|
||||||
|
disposed = true;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
~WMInput()
|
||||||
|
{
|
||||||
|
Dispose(false);
|
||||||
}
|
}
|
||||||
|
|
||||||
#endregion
|
#endregion
|
||||||
|
|
Loading…
Reference in a new issue