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:
the_fiddler 2007-08-22 00:30:16 +00:00
parent 83ff6b5310
commit 6ae06d82bd
9 changed files with 174 additions and 77 deletions

View file

@ -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);

View file

@ -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; }
} }
} }

View file

@ -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
} }
} }

View file

@ -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

View file

@ -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()
{ {

View file

@ -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

View file

@ -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

View file

@ -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
} }
} }

View file

@ -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
} }
} }