/ThirdParty/OpenTK.1.0/Source/OpenTK/Platform/Windows/WinWindowInfo.cs
https://github.com/virtualglobebook/OpenGlobe · C# · 173 lines · 90 code · 30 blank · 53 comment · 16 complexity · 8be974f0943338ce273b1e30540320e1 MD5 · raw file
- #region License
- //
- // The Open Toolkit Library License
- //
- // Copyright (c) 2006 - 2009 the Open Toolkit library.
- //
- // Permission is hereby granted, free of charge, to any person obtaining a copy
- // of this software and associated documentation files (the "Software"), to deal
- // in the Software without restriction, including without limitation the rights to
- // 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
- // so, subject to the following conditions:
- //
- // The above copyright notice and this permission notice shall be included in all
- // copies or substantial portions of the Software.
- //
- // THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
- // EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES
- // OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
- // NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT
- // HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY,
- // WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING
- // FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR
- // OTHER DEALINGS IN THE SOFTWARE.
- //
- #endregion
-
- using System;
- using System.Collections.Generic;
- using System.Text;
- using System.Diagnostics;
- using System.Runtime.InteropServices;
-
- namespace OpenTK.Platform.Windows
- {
- /// \internal
- /// <summary>Describes a win32 window.</summary>
- sealed class WinWindowInfo : IWindowInfo
- {
- IntPtr handle, dc;
- WinWindowInfo parent;
- bool disposed;
-
- #region --- Constructors ---
-
- /// <summary>
- /// Constructs a new instance.
- /// </summary>
- public WinWindowInfo()
- {
- }
-
- /// <summary>
- /// Constructs a new instance with the specified window handle and paren.t
- /// </summary>
- /// <param name="handle">The window handle for this instance.</param>
- /// <param name="parent">The parent window of this instance (may be null).</param>
- public WinWindowInfo(IntPtr handle, WinWindowInfo parent)
- {
- this.handle = handle;
- this.parent = parent;
- }
-
- #endregion
-
- #region --- Public Methods ---
-
- /// <summary>
- /// Gets or sets the handle of the window.
- /// </summary>
- public IntPtr WindowHandle { get { return handle; } set { handle = value; } }
-
- /// <summary>
- /// Gets or sets the Parent of the window (may be null).
- /// </summary>
- public WinWindowInfo Parent { get { return parent; } set { parent = value; } }
-
- /// <summary>
- /// Gets the device context for this window instance.
- /// </summary>
- public IntPtr DeviceContext
- {
- get
- {
- if (dc == IntPtr.Zero)
- dc = Functions.GetDC(this.WindowHandle);
- //dc = Functions.GetWindowDC(this.WindowHandle);
- return dc;
- }
- }
-
- #region public override string ToString()
-
- /// <summary>Returns a System.String that represents the current window.</summary>
- /// <returns>A System.String that represents the current window.</returns>
- public override string ToString()
- {
- return String.Format("Windows.WindowInfo: Handle {0}, Parent ({1})",
- this.WindowHandle, this.Parent != null ? this.Parent.ToString() : "null");
- }
-
- /// <summary>Checks if <c>this</c> and <c>obj</c> reference the same win32 window.</summary>
- /// <param name="obj">The object to check against.</param>
- /// <returns>True if <c>this</c> and <c>obj</c> reference the same win32 window; false otherwise.</returns>
- public override bool Equals(object obj)
- {
- if (obj == null) return false;
- if (this.GetType() != obj.GetType()) return false;
- WinWindowInfo info = (WinWindowInfo)obj;
-
- if (info == null) return false;
- // TODO: Assumes windows will always have unique handles.
- return handle.Equals(info.handle);
- }
-
- /// <summary>Returns the hash code for this instance.</summary>
- /// <returns>A hash code for the current <c>WinWindowInfo</c>.</returns>
- public override int GetHashCode()
- {
- return handle.GetHashCode();
- }
-
- #endregion
-
- #endregion
-
- #region --- IDisposable ---
-
- #region public void Dispose()
-
- /// <summary>Releases the unmanaged resources consumed by this instance.</summary>
- public void Dispose()
- {
- this.Dispose(true);
- GC.SuppressFinalize(this);
- }
-
- #endregion
-
- #region void Dispose(bool manual)
-
- void Dispose(bool manual)
- {
- if (!disposed)
- {
- if (this.dc != IntPtr.Zero)
- if (!Functions.ReleaseDC(this.handle, this.dc))
- Debug.Print("[Warning] Failed to release device context {0}. Windows error: {1}.", this.dc, Marshal.GetLastWin32Error());
-
- if (manual)
- {
- if (parent != null)
- parent.Dispose();
- }
-
- disposed = true;
- }
- }
-
- #endregion
-
- #region ~WinWindowInfo()
-
- ~WinWindowInfo()
- {
- this.Dispose(false);
- }
-
- #endregion
-
- #endregion
- }
- }