mirror of
https://github.com/Ryujinx/Opentk.git
synced 2025-01-24 22:41:04 +00:00
Added IDisposable to all input drivers.
Updated Cube.cs to use System.Drawing.Colors. Improved DefRawInputProc in windows API.cs
This commit is contained in:
parent
83ff6b5310
commit
6ae06d82bd
|
@ -167,38 +167,38 @@ namespace Examples.WinForms
|
||||||
{
|
{
|
||||||
GL.Begin(GL.Enums.BeginMode.QUADS);
|
GL.Begin(GL.Enums.BeginMode.QUADS);
|
||||||
|
|
||||||
GL.Color3((byte)Color.Silver.R, (byte)Color.Silver.G, (byte)Color.Silver.B);
|
GL.Color3(Color.Silver);
|
||||||
GL.Vertex3(-1.0f, -1.0f, -1.0f);
|
GL.Vertex3(-1.0f, -1.0f, -1.0f);
|
||||||
GL.Vertex3(-1.0f, 1.0f, -1.0f);
|
GL.Vertex3(-1.0f, 1.0f, -1.0f);
|
||||||
GL.Vertex3(1.0f, 1.0f, -1.0f);
|
GL.Vertex3(1.0f, 1.0f, -1.0f);
|
||||||
GL.Vertex3(1.0f, -1.0f, -1.0f);
|
GL.Vertex3(1.0f, -1.0f, -1.0f);
|
||||||
|
|
||||||
GL.Color3((byte)Color.Honeydew.R, (byte)Color.Honeydew.G, (byte)Color.Honeydew.B);
|
GL.Color3(Color.Honeydew);
|
||||||
GL.Vertex3(-1.0f, -1.0f, -1.0f);
|
GL.Vertex3(-1.0f, -1.0f, -1.0f);
|
||||||
GL.Vertex3(1.0f, -1.0f, -1.0f);
|
GL.Vertex3(1.0f, -1.0f, -1.0f);
|
||||||
GL.Vertex3(1.0f, -1.0f, 1.0f);
|
GL.Vertex3(1.0f, -1.0f, 1.0f);
|
||||||
GL.Vertex3(-1.0f, -1.0f, 1.0f);
|
GL.Vertex3(-1.0f, -1.0f, 1.0f);
|
||||||
|
|
||||||
GL.Color3((byte)Color.Moccasin.R, (byte)Color.Moccasin.G, (byte)Color.Moccasin.B);
|
GL.Color3(Color.Moccasin);
|
||||||
|
|
||||||
GL.Vertex3(-1.0f, -1.0f, -1.0f);
|
GL.Vertex3(-1.0f, -1.0f, -1.0f);
|
||||||
GL.Vertex3(-1.0f, -1.0f, 1.0f);
|
GL.Vertex3(-1.0f, -1.0f, 1.0f);
|
||||||
GL.Vertex3(-1.0f, 1.0f, 1.0f);
|
GL.Vertex3(-1.0f, 1.0f, 1.0f);
|
||||||
GL.Vertex3(-1.0f, 1.0f, -1.0f);
|
GL.Vertex3(-1.0f, 1.0f, -1.0f);
|
||||||
|
|
||||||
GL.Color3((byte)Color.IndianRed.R, (byte)Color.IndianRed.G, (byte)Color.IndianRed.B);
|
GL.Color3(Color.IndianRed);
|
||||||
GL.Vertex3(-1.0f, -1.0f, 1.0f);
|
GL.Vertex3(-1.0f, -1.0f, 1.0f);
|
||||||
GL.Vertex3(1.0f, -1.0f, 1.0f);
|
GL.Vertex3(1.0f, -1.0f, 1.0f);
|
||||||
GL.Vertex3(1.0f, 1.0f, 1.0f);
|
GL.Vertex3(1.0f, 1.0f, 1.0f);
|
||||||
GL.Vertex3(-1.0f, 1.0f, 1.0f);
|
GL.Vertex3(-1.0f, 1.0f, 1.0f);
|
||||||
|
|
||||||
GL.Color3((byte)Color.PaleVioletRed.R, (byte)Color.PaleVioletRed.G, (byte)Color.PaleVioletRed.B);
|
GL.Color3(Color.PaleVioletRed);
|
||||||
GL.Vertex3(-1.0f, 1.0f, -1.0f);
|
GL.Vertex3(-1.0f, 1.0f, -1.0f);
|
||||||
GL.Vertex3(-1.0f, 1.0f, 1.0f);
|
GL.Vertex3(-1.0f, 1.0f, 1.0f);
|
||||||
GL.Vertex3(1.0f, 1.0f, 1.0f);
|
GL.Vertex3(1.0f, 1.0f, 1.0f);
|
||||||
GL.Vertex3(1.0f, 1.0f, -1.0f);
|
GL.Vertex3(1.0f, 1.0f, -1.0f);
|
||||||
|
|
||||||
GL.Color3((byte)Color.ForestGreen.R, (byte)Color.ForestGreen.G, (byte)Color.ForestGreen.B);
|
GL.Color3(Color.ForestGreen);
|
||||||
GL.Vertex3(1.0f, -1.0f, -1.0f);
|
GL.Vertex3(1.0f, -1.0f, -1.0f);
|
||||||
GL.Vertex3(1.0f, 1.0f, -1.0f);
|
GL.Vertex3(1.0f, 1.0f, -1.0f);
|
||||||
GL.Vertex3(1.0f, 1.0f, 1.0f);
|
GL.Vertex3(1.0f, 1.0f, 1.0f);
|
||||||
|
|
|
@ -10,11 +10,9 @@ using System.Text;
|
||||||
|
|
||||||
namespace OpenTK.Input
|
namespace OpenTK.Input
|
||||||
{
|
{
|
||||||
public interface IInputDriver : IKeyboardDriver, IMouseDriver
|
public interface IInputDriver : IKeyboardDriver, IMouseDriver, IDisposable
|
||||||
{
|
{
|
||||||
IList<IInputDevice> InputDevices { get; }
|
IList<IInputDevice> InputDevices { get; }
|
||||||
void ProcessEvents();
|
void ProcessEvents();
|
||||||
//IEnumerable<IMouse> Mice { get; }
|
|
||||||
//IEnumerable<IHid> Hids { get; }
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -15,7 +15,7 @@ namespace OpenTK
|
||||||
{
|
{
|
||||||
public class InputDriver : IInputDriver
|
public class InputDriver : IInputDriver
|
||||||
{
|
{
|
||||||
IInputDriver inputDriver;
|
private IInputDriver inputDriver;
|
||||||
|
|
||||||
#region --- Constructors ---
|
#region --- Constructors ---
|
||||||
|
|
||||||
|
@ -63,5 +63,35 @@ namespace OpenTK
|
||||||
}
|
}
|
||||||
|
|
||||||
#endregion
|
#endregion
|
||||||
|
|
||||||
|
#region --- IDisposable Members ---
|
||||||
|
|
||||||
|
private bool disposed;
|
||||||
|
|
||||||
|
public void Dispose()
|
||||||
|
{
|
||||||
|
this.Dispose(true);
|
||||||
|
GC.SuppressFinalize(this);
|
||||||
|
}
|
||||||
|
|
||||||
|
private void Dispose(bool manual)
|
||||||
|
{
|
||||||
|
if (!disposed)
|
||||||
|
{
|
||||||
|
if (manual)
|
||||||
|
{
|
||||||
|
inputDriver.Dispose();
|
||||||
|
}
|
||||||
|
|
||||||
|
disposed = true;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
~InputDriver()
|
||||||
|
{
|
||||||
|
this.Dispose(false);
|
||||||
|
}
|
||||||
|
|
||||||
|
#endregion
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -768,19 +768,28 @@ namespace OpenTK.Platform.Windows
|
||||||
[CLSCompliant(false)]
|
[CLSCompliant(false)]
|
||||||
[System.Security.SuppressUnmanagedCodeSecurity]
|
[System.Security.SuppressUnmanagedCodeSecurity]
|
||||||
[DllImport("user32.dll", SetLastError = true)]
|
[DllImport("user32.dll", SetLastError = true)]
|
||||||
public static extern LRESULT DefRawInputProc(
|
public static extern LRESULT DefRawInputProc(RawInput[] RawInput, INT Input, UINT SizeHeader);
|
||||||
RawInput[] RawInput,
|
|
||||||
INT Input,
|
|
||||||
UINT SizeHeader
|
|
||||||
);
|
|
||||||
|
|
||||||
|
/*
|
||||||
[System.Security.SuppressUnmanagedCodeSecurity]
|
[System.Security.SuppressUnmanagedCodeSecurity]
|
||||||
[DllImport("user32.dll", SetLastError = true)]
|
[DllImport("user32.dll", SetLastError = true)]
|
||||||
public static extern LRESULT DefRawInputProc(
|
public static extern LRESULT DefRawInputProc(RawInput[] RawInput, INT Input, INT SizeHeader);
|
||||||
RawInput[] RawInput,
|
*/
|
||||||
INT Input,
|
|
||||||
INT SizeHeader
|
/// <summary>
|
||||||
);
|
/// 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.
|
||||||
|
/// </summary>
|
||||||
|
/// <param name="RawInput">Pointer to an array of RawInput structures.</param>
|
||||||
|
/// <param name="Input">Number of RawInput structures pointed to by paRawInput.</param>
|
||||||
|
/// <param name="SizeHeader">Size, in bytes, of the RawInputHeader structure.</param>
|
||||||
|
/// <returns>If successful, the function returns S_OK. Otherwise it returns an error value.</returns>
|
||||||
|
[CLSCompliant(false)]
|
||||||
|
[System.Security.SuppressUnmanagedCodeSecurity]
|
||||||
|
[DllImport("user32.dll", SetLastError = true)]
|
||||||
|
unsafe public static extern LRESULT DefRawInputProc(ref RawInput RawInput, INT Input, UINT SizeHeader);
|
||||||
|
|
||||||
#endregion
|
#endregion
|
||||||
|
|
||||||
|
|
|
@ -281,7 +281,7 @@ namespace OpenTK.Platform.Windows
|
||||||
Dispose(false);
|
Dispose(false);
|
||||||
}
|
}
|
||||||
|
|
||||||
#region public void ReleaseResources()
|
#region private void ReleaseResources()
|
||||||
|
|
||||||
private void ReleaseResources()
|
private void ReleaseResources()
|
||||||
{
|
{
|
||||||
|
|
|
@ -333,9 +333,10 @@ namespace OpenTK.Platform.Windows
|
||||||
{
|
{
|
||||||
Debug.Print("Window handle {0} destroyed.", this.Handle);
|
Debug.Print("Window handle {0} destroyed.", this.Handle);
|
||||||
//this.DestroyHandle(); // Destroyed automatically by DefWndProc
|
//this.DestroyHandle(); // Destroyed automatically by DefWndProc
|
||||||
|
//this.Dispose();
|
||||||
exists = false;
|
exists = false;
|
||||||
}
|
}
|
||||||
API.PostQuitMessage(0);
|
//API.PostQuitMessage(0);
|
||||||
}
|
}
|
||||||
|
|
||||||
public event DestroyEvent Destroy;
|
public event DestroyEvent Destroy;
|
||||||
|
@ -344,38 +345,6 @@ namespace OpenTK.Platform.Windows
|
||||||
|
|
||||||
#endregion
|
#endregion
|
||||||
|
|
||||||
#region --- IDisposable Members ---
|
|
||||||
|
|
||||||
public void Dispose()
|
|
||||||
{
|
|
||||||
this.Dispose(true);
|
|
||||||
GC.SuppressFinalize(this);
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
private void Dispose(bool calledManually)
|
|
||||||
{
|
|
||||||
if (!disposed)
|
|
||||||
{
|
|
||||||
// Clean unmanaged resources here:
|
|
||||||
|
|
||||||
if (calledManually)
|
|
||||||
{
|
|
||||||
// Safe to clean managed resources
|
|
||||||
glContext.Dispose();
|
|
||||||
base.DestroyHandle();
|
|
||||||
}
|
|
||||||
disposed = true;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
~WinGLNative()
|
|
||||||
{
|
|
||||||
Dispose(false);
|
|
||||||
}
|
|
||||||
|
|
||||||
#endregion
|
|
||||||
|
|
||||||
#region --- IResizable Members ---
|
#region --- IResizable Members ---
|
||||||
|
|
||||||
#region public int Width
|
#region public int Width
|
||||||
|
@ -453,6 +422,37 @@ namespace OpenTK.Platform.Windows
|
||||||
}
|
}
|
||||||
|
|
||||||
#endregion
|
#endregion
|
||||||
|
|
||||||
|
#region --- IDisposable Members ---
|
||||||
|
|
||||||
|
public void Dispose()
|
||||||
|
{
|
||||||
|
this.Dispose(true);
|
||||||
|
GC.SuppressFinalize(this);
|
||||||
|
}
|
||||||
|
|
||||||
|
private void Dispose(bool calledManually)
|
||||||
|
{
|
||||||
|
if (!disposed)
|
||||||
|
{
|
||||||
|
// Clean unmanaged resources here:
|
||||||
|
|
||||||
|
if (calledManually)
|
||||||
|
{
|
||||||
|
// Safe to clean managed resources
|
||||||
|
glContext.Dispose();
|
||||||
|
base.DestroyHandle();
|
||||||
|
}
|
||||||
|
disposed = true;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
~WinGLNative()
|
||||||
|
{
|
||||||
|
Dispose(false);
|
||||||
|
}
|
||||||
|
|
||||||
|
#endregion
|
||||||
}
|
}
|
||||||
|
|
||||||
#region class WindowHandle : Microsoft.Win32.SafeHandles.SafeHandleZeroOrMinusOneIsInvalid
|
#region class WindowHandle : Microsoft.Win32.SafeHandles.SafeHandleZeroOrMinusOneIsInvalid
|
||||||
|
|
|
@ -89,16 +89,17 @@ namespace OpenTK.Platform.Windows
|
||||||
switch (data.Header.Type)
|
switch (data.Header.Type)
|
||||||
{
|
{
|
||||||
case API.RawInputDeviceType.KEYBOARD:
|
case API.RawInputDeviceType.KEYBOARD:
|
||||||
keyboardDriver.ProcessKeyboardEvent(data);
|
if (!keyboardDriver.ProcessKeyboardEvent(data))
|
||||||
break;
|
API.DefRawInputProc(ref data, 1, (uint)API.RawInputHeaderSize);
|
||||||
|
return;
|
||||||
|
|
||||||
case API.RawInputDeviceType.MOUSE:
|
case API.RawInputDeviceType.MOUSE:
|
||||||
//throw new NotImplementedException();
|
API.DefRawInputProc(ref data, 1, (uint)API.RawInputHeaderSize);
|
||||||
break;
|
return;
|
||||||
|
|
||||||
case API.RawInputDeviceType.HID:
|
case API.RawInputDeviceType.HID:
|
||||||
//throw new NotImplementedException();
|
API.DefRawInputProc(ref data, 1, (uint)API.RawInputHeaderSize);
|
||||||
break;
|
return;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
|
@ -111,13 +112,14 @@ namespace OpenTK.Platform.Windows
|
||||||
|
|
||||||
case API.Constants.WM_CLOSE:
|
case API.Constants.WM_CLOSE:
|
||||||
case API.Constants.WM_DESTROY:
|
case API.Constants.WM_DESTROY:
|
||||||
Debug.Print("Input window detached from parent {0}.", Handle);
|
Debug.Print("Input window detached from parent {0}.", Handle);
|
||||||
ReleaseHandle();
|
ReleaseHandle();
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case API.Constants.WM_QUIT:
|
case API.Constants.WM_QUIT:
|
||||||
Debug.WriteLine("Input window quit.");
|
Debug.WriteLine("Input window quit.");
|
||||||
break;
|
this.Dispose();
|
||||||
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
base.WndProc(ref msg);
|
base.WndProc(ref msg);
|
||||||
|
@ -137,7 +139,7 @@ namespace OpenTK.Platform.Windows
|
||||||
get { return keyboardDriver.Keyboard; }
|
get { return keyboardDriver.Keyboard; }
|
||||||
}
|
}
|
||||||
|
|
||||||
public IList<Keyboard> Mouse
|
public IList<Mouse> Mouse
|
||||||
{
|
{
|
||||||
get { throw new Exception("The method or operation is not implemented."); }
|
get { throw new Exception("The method or operation is not implemented."); }
|
||||||
}
|
}
|
||||||
|
@ -149,11 +151,32 @@ namespace OpenTK.Platform.Windows
|
||||||
|
|
||||||
#endregion
|
#endregion
|
||||||
|
|
||||||
#region IMouseDriver Members
|
#region --- IDisposable Members ---
|
||||||
|
|
||||||
IList<Mouse> IMouseDriver.Mouse
|
private bool disposed;
|
||||||
|
|
||||||
|
public void Dispose()
|
||||||
{
|
{
|
||||||
get { throw new Exception("The method or operation is not implemented."); }
|
Dispose(true);
|
||||||
|
GC.SuppressFinalize(this);
|
||||||
|
}
|
||||||
|
|
||||||
|
private void Dispose(bool manual)
|
||||||
|
{
|
||||||
|
if (!disposed)
|
||||||
|
{
|
||||||
|
if (manual)
|
||||||
|
{
|
||||||
|
keyboardDriver.Dispose();
|
||||||
|
}
|
||||||
|
|
||||||
|
disposed = true;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
~WinRawInput()
|
||||||
|
{
|
||||||
|
Dispose(false);
|
||||||
}
|
}
|
||||||
|
|
||||||
#endregion
|
#endregion
|
||||||
|
|
|
@ -18,7 +18,7 @@ using OpenTK.Input;
|
||||||
|
|
||||||
namespace OpenTK.Platform.Windows
|
namespace OpenTK.Platform.Windows
|
||||||
{
|
{
|
||||||
internal class WinRawKeyboard : IKeyboardDriver
|
internal class WinRawKeyboard : IKeyboardDriver, IDisposable
|
||||||
{
|
{
|
||||||
private List<Keyboard> keyboards = new List<Keyboard>();
|
private List<Keyboard> keyboards = new List<Keyboard>();
|
||||||
private IntPtr windowHandle;
|
private IntPtr windowHandle;
|
||||||
|
@ -175,9 +175,7 @@ namespace OpenTK.Platform.Windows
|
||||||
// This is a terminal services devices, skip it.
|
// This is a terminal services devices, skip it.
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
else if (
|
else if (ridl[i].Type == API.RawInputDeviceType.KEYBOARD || ridl[i].Type == API.RawInputDeviceType.HID)
|
||||||
ridl[i].Type == API.RawInputDeviceType.KEYBOARD ||
|
|
||||||
ridl[i].Type == API.RawInputDeviceType.HID)
|
|
||||||
{
|
{
|
||||||
//It's a keyboard – or a USB device that could be a keyboard
|
//It's a keyboard – or a USB device that could be a keyboard
|
||||||
|
|
||||||
|
@ -283,15 +281,15 @@ namespace OpenTK.Platform.Windows
|
||||||
{
|
{
|
||||||
case API.VirtualKeys.SHIFT:
|
case API.VirtualKeys.SHIFT:
|
||||||
keyboards[0][Input.Key.ShiftLeft] = keyboards[0][Input.Key.ShiftRight] = pressed;
|
keyboards[0][Input.Key.ShiftLeft] = keyboards[0][Input.Key.ShiftRight] = pressed;
|
||||||
return false;
|
return true;
|
||||||
|
|
||||||
case API.VirtualKeys.CONTROL:
|
case API.VirtualKeys.CONTROL:
|
||||||
keyboards[0][Input.Key.ControlLeft] = keyboards[0][Input.Key.ControlRight] = pressed;
|
keyboards[0][Input.Key.ControlLeft] = keyboards[0][Input.Key.ControlRight] = pressed;
|
||||||
return false;
|
return true;
|
||||||
|
|
||||||
case API.VirtualKeys.MENU:
|
case API.VirtualKeys.MENU:
|
||||||
keyboards[0][Input.Key.AltLeft] = keyboards[0][Input.Key.AltRight] = pressed;
|
keyboards[0][Input.Key.AltLeft] = keyboards[0][Input.Key.AltRight] = pressed;
|
||||||
return false;
|
return true;
|
||||||
|
|
||||||
default:
|
default:
|
||||||
if (!WinRawKeyboard.KeyMap.ContainsKey(rin.Data.Keyboard.VKey))
|
if (!WinRawKeyboard.KeyMap.ContainsKey(rin.Data.Keyboard.VKey))
|
||||||
|
@ -302,7 +300,7 @@ namespace OpenTK.Platform.Windows
|
||||||
{
|
{
|
||||||
keyboards[0][WinRawKeyboard.KeyMap[rin.Data.Keyboard.VKey]] = pressed;
|
keyboards[0][WinRawKeyboard.KeyMap[rin.Data.Keyboard.VKey]] = pressed;
|
||||||
}
|
}
|
||||||
break;
|
return false;
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
|
|
||||||
|
@ -336,5 +334,35 @@ namespace OpenTK.Platform.Windows
|
||||||
}
|
}
|
||||||
|
|
||||||
#endregion
|
#endregion
|
||||||
|
|
||||||
|
#region --- IDisposable Members ---
|
||||||
|
|
||||||
|
private bool disposed;
|
||||||
|
|
||||||
|
public void Dispose()
|
||||||
|
{
|
||||||
|
Dispose(true);
|
||||||
|
GC.SuppressFinalize(this);
|
||||||
|
}
|
||||||
|
|
||||||
|
private void Dispose(bool manual)
|
||||||
|
{
|
||||||
|
if (!disposed)
|
||||||
|
{
|
||||||
|
if (manual)
|
||||||
|
{
|
||||||
|
//keyboards.Clear();
|
||||||
|
}
|
||||||
|
|
||||||
|
disposed = true;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
~WinRawKeyboard()
|
||||||
|
{
|
||||||
|
Dispose(false);
|
||||||
|
}
|
||||||
|
|
||||||
|
#endregion
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -146,5 +146,14 @@ namespace OpenTK.Platform.X11
|
||||||
}
|
}
|
||||||
|
|
||||||
#endregion
|
#endregion
|
||||||
|
|
||||||
|
#region --- IDisposable Members ---
|
||||||
|
|
||||||
|
public void Dispose()
|
||||||
|
{
|
||||||
|
throw new Exception("The method or operation is not implemented.");
|
||||||
|
}
|
||||||
|
|
||||||
|
#endregion
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue