From 7cf8aa3d958481eba3b68b76ad7c623b0e5f506c Mon Sep 17 00:00:00 2001
From: the_fiddler <the_fiddler@ebc5dd9b-fb1d-0410-b6f8-d24c324e9604>
Date: Tue, 21 Aug 2007 12:04:01 +0000
Subject: [PATCH] Added AdjustWindowRect to Windows.API. The client are in
 WinGLNative is now correctly specified.

---
 Source/Examples/Tutorial/T03_RotatingCube.cs  |   2 +-
 .../Tutorial/T07_DisplayLists_Cube.cs         |   2 +-
 Source/Examples/Tutorial/T08_VBO.cs           |   2 +-
 Source/Examples/Tutorial/T10_GLSL_Cube.cs     |   2 +-
 Source/OpenTK/GameWindow.cs                   |  38 ++
 Source/OpenTK/Platform/IResizable.cs          |   7 +-
 Source/OpenTK/Platform/Windows/API.cs         | 485 ++++++++++--------
 .../OpenTK/Platform/Windows/WinGLControl.cs   |   6 +-
 Source/OpenTK/Platform/Windows/WinGLNative.cs |  72 ++-
 Source/OpenTK/Platform/X11/X11GLNative.cs     |  30 ++
 10 files changed, 411 insertions(+), 235 deletions(-)

diff --git a/Source/Examples/Tutorial/T03_RotatingCube.cs b/Source/Examples/Tutorial/T03_RotatingCube.cs
index 27bba48c..f80a0145 100644
--- a/Source/Examples/Tutorial/T03_RotatingCube.cs
+++ b/Source/Examples/Tutorial/T03_RotatingCube.cs
@@ -65,7 +65,7 @@ namespace Examples.Tutorial
         {
             base.OnResize(e);
 
-            GL.Viewport(0, 0, e.Width, e.Height);
+            GL.Viewport(0, 0, Width, Height);
 
             double ratio = e.Width / (double)e.Height;
 
diff --git a/Source/Examples/Tutorial/T07_DisplayLists_Cube.cs b/Source/Examples/Tutorial/T07_DisplayLists_Cube.cs
index f831be7e..56340fd2 100644
--- a/Source/Examples/Tutorial/T07_DisplayLists_Cube.cs
+++ b/Source/Examples/Tutorial/T07_DisplayLists_Cube.cs
@@ -104,7 +104,7 @@ namespace Examples.Tutorial
         {
             base.OnResize(e);
 
-            GL.Viewport(0, 0, this.Width, this.Height);
+            GL.Viewport(0, 0, Width, Height);
 
             double ratio = 0.0;
             ratio = this.Width / (double)this.Height;
diff --git a/Source/Examples/Tutorial/T08_VBO.cs b/Source/Examples/Tutorial/T08_VBO.cs
index 0f53cdb4..2bee47d8 100644
--- a/Source/Examples/Tutorial/T08_VBO.cs
+++ b/Source/Examples/Tutorial/T08_VBO.cs
@@ -109,7 +109,7 @@ namespace Examples.Tutorial
         {
             base.OnResize(e);
 
-            GL.Viewport(0, 0, e.Width, e.Height);
+            GL.Viewport(0, 0, Width, Height);
 
             double ratio = e.Width / (double)e.Height;
 
diff --git a/Source/Examples/Tutorial/T10_GLSL_Cube.cs b/Source/Examples/Tutorial/T10_GLSL_Cube.cs
index 77abcd52..4815cd23 100644
--- a/Source/Examples/Tutorial/T10_GLSL_Cube.cs
+++ b/Source/Examples/Tutorial/T10_GLSL_Cube.cs
@@ -162,7 +162,7 @@ namespace Examples.Tutorial
         {
             base.OnResize(e);
 
-            GL.Viewport(0, 0, this.Width, this.Height);
+            GL.Viewport(0, 0, Width, Height);
 
             double ratio = 0.0;
             ratio = this.Width / (double)this.Height;
diff --git a/Source/OpenTK/GameWindow.cs b/Source/OpenTK/GameWindow.cs
index 368654fd..6dce8472 100644
--- a/Source/OpenTK/GameWindow.cs
+++ b/Source/OpenTK/GameWindow.cs
@@ -470,6 +470,9 @@ namespace OpenTK
 
         #region public int Width, Height
 
+        /// <summary>
+        /// Gets or sets the Width of the GameWindow's rendering area, in pixels.
+        /// </summary>
         public int Width
         {
             get { return glWindow.Width; }
@@ -494,6 +497,9 @@ namespace OpenTK
             }
         }
 
+        /// <summary>
+        /// Gets or sets the Height of the GameWindow's rendering area, in pixels.
+        /// </summary>
         public int Height
         {
             get { return glWindow.Height; }
@@ -536,7 +542,39 @@ namespace OpenTK
         }
 
         #endregion
+        /*
+        /// <summary>
+        /// Gets the Top coordinate of the GameWindow's rendering area, in pixel coordinates relative to the GameWindow's top left point.
+        /// </summary>
+        public int Top
+        {
+            get { return glWindow.Top; }
+        }
 
+        /// <summary>
+        /// /// Gets the Bottom coordinate of the GameWindow's rendering area, in pixel coordinates relative to the GameWindow's top left point.
+        /// </summary>
+        public int Bottom
+        {
+            get { return glWindow.Bottom; }
+        }
+
+        /// <summary>
+        /// Gets the Left coordinate of the GameWindow's rendering area, in pixel coordinates relative to the GameWindow's top left point.
+        /// </summary>
+        public int Left
+        {
+            get { return glWindow.Left; }
+        }
+
+        /// <summary>
+        /// Gets the Right coordinate of the GameWindow's rendering area, in pixel coordinates relative to the GameWindow's top left point.
+        /// </summary>
+        public int Right
+        {
+            get { return glWindow.Right; }
+        }
+        */
         #endregion
 
         #region --- IDisposable Members ---
diff --git a/Source/OpenTK/Platform/IResizable.cs b/Source/OpenTK/Platform/IResizable.cs
index 7e66ed48..1c2b1580 100644
--- a/Source/OpenTK/Platform/IResizable.cs
+++ b/Source/OpenTK/Platform/IResizable.cs
@@ -14,7 +14,12 @@ namespace OpenTK.Platform
     {
         int Height { get; set; }
         int Width { get; set; }
-
+        /*
+        int Top { get; }
+        int Bottom { get; }
+        int Left { get; }
+        int Right { get; }
+        */
         event ResizeEvent Resize;
     }
 
diff --git a/Source/OpenTK/Platform/Windows/API.cs b/Source/OpenTK/Platform/Windows/API.cs
index 177aafa4..9dad08d4 100644
--- a/Source/OpenTK/Platform/Windows/API.cs
+++ b/Source/OpenTK/Platform/Windows/API.cs
@@ -43,9 +43,11 @@ namespace OpenTK.Platform.Windows
     using BOOL = System.Boolean;
     using INT = System.Int32;
     using UINT = System.UInt32;
-    using COLORREF = System.Int32;
     using LONG_PTR = System.IntPtr;
-    
+
+    using COLORREF = System.Int32;
+    using RECT = OpenTK.Platform.Windows.API.Rectangle;
+
     using WNDPROC = System.IntPtr;
 
     #endregion
@@ -174,6 +176,239 @@ namespace OpenTK.Platform.Windows
 
         #region --- Functions ---
 
+        #region Window Creation
+
+        #region SetWindowPos
+
+        // WINUSERAPI BOOL WINAPI SetWindowPos(__in HWND hWnd, __in_opt HWND hWndInsertAfter,
+        //                                     __in int X, __in int Y, __in int cx, __in int cy, __in UINT uFlags);
+
+        [DllImport("user32.dll")]
+        [return: MarshalAs(UnmanagedType.Bool)]
+        public static extern bool SetWindowPos(
+            IntPtr handle,
+            WindowPlacementOptions placement,
+            int x, int y, int cx, int cy,
+            SetWindowPosFlags flags
+        );
+
+        #endregion
+
+        #region AdjustWindowRect
+
+        /// <summary>
+        /// Calculates the required size of the window rectangle, based on the desired client-rectangle size. The window rectangle can then be passed to the CreateWindow function to create a window whose client area is the desired size.
+        /// </summary>
+        /// <param name="lpRect">[in, out] Pointer to a RECT structure that contains the coordinates of the top-left and bottom-right corners of the desired client area. When the function returns, the structure contains the coordinates of the top-left and bottom-right corners of the window to accommodate the desired client area.</param>
+        /// <param name="dwStyle">[in] Specifies the window style of the window whose required size is to be calculated. Note that you cannot specify the WS_OVERLAPPED style.</param>
+        /// <param name="bMenu">[in] Specifies whether the window has a menu.</param>
+        /// <returns>
+        /// If the function succeeds, the return value is nonzero.
+        /// If the function fails, the return value is zero. To get extended error information, call GetLastError.
+        /// </returns>
+        /// <remarks>
+        /// A client rectangle is the smallest rectangle that completely encloses a client area. A window rectangle is the smallest rectangle that completely encloses the window, which includes the client area and the nonclient area. 
+        /// The AdjustWindowRect function does not add extra space when a menu bar wraps to two or more rows. 
+        /// The AdjustWindowRect function does not take the WS_VSCROLL or WS_HSCROLL styles into account. To account for the scroll bars, call the GetSystemMetrics function with SM_CXVSCROLL or SM_CYHSCROLL.
+        /// Found Winuser.h, user32.dll
+        /// </remarks>
+        [DllImport("user32.dll", SetLastError = true), SuppressUnmanagedCodeSecurity]
+        public static extern BOOL AdjustWindowRect([In, Out] ref RECT lpRect, WindowStyle dwStyle, BOOL bMenu);
+
+        #endregion
+
+        #region CreateWindowEx
+
+        [DllImport("user32.dll", SetLastError = true, CharSet = CharSet.Auto)]
+        public static extern IntPtr CreateWindowEx(
+            [In]ExtendedWindowStyle ExStyle,
+            [In]string className,
+            [In]string windowName,
+            [In]WindowStyle Style,
+            [In]int X, int Y,
+            [In]int Width, int Height,
+            [In]IntPtr HandleToParentWindow,
+            [In]IntPtr Menu,
+            [In]IntPtr Instance,
+            [In]IntPtr Param);
+        /*
+        [DllImport("user32.dll", SetLastError = true)]
+        public static extern int CreateWindowEx(
+            [In]ExtendedWindowStyle ExStyle,
+            [In]IntPtr ClassName,
+            [In]IntPtr WindowName,
+            [In]WindowStyle Style,
+            [In]int X, [In]int Y,
+            [In]int Width, [In]int Height,
+            [In]IntPtr HandleToParentWindow,
+            [In]IntPtr Menu,
+            [In]IntPtr Instance,
+            [In]IntPtr Param);
+        */
+        [DllImport("user32.dll", SetLastError = true, CharSet = CharSet.Auto)]
+        public static extern IntPtr CreateWindowEx(
+            ExtendedWindowStyle ExStyle,
+            IntPtr ClassName,
+            IntPtr WindowName,
+            WindowStyle Style,
+            int X, int Y,
+            int Width, int Height,
+            IntPtr HandleToParentWindow,
+            IntPtr Menu,
+            IntPtr Instance,
+            IntPtr Param);
+
+        public enum WindowStyle : int
+        {
+            Overlapped = 0x00000000,
+            Popup = unchecked((int)0x80000000),
+            Child = 0x40000000,
+            Minimize = 0x20000000,
+            Visible = 0x10000000,
+            Disabled = 0x08000000,
+            ClipSiblings = 0x04000000,
+            ClipChildren = 0x02000000,
+            Maximize = 0x01000000,
+            Caption = 0x00C00000,    // Border | DialogFrame
+            Border = 0x00800000,
+            DialogFrame = 0x00400000,
+            VScroll = 0x00200000,
+            HScreen = 0x00100000,
+            SystemMenu = 0x00080000,
+            ThickFrame = 0x00040000,
+            Group = 0x00020000,
+            TabStop = 0x00010000,
+
+            MinimizeBox = 0x00020000,
+            MaximizeBox = 0x00010000,
+
+            Tiled = Overlapped,
+            Iconic = Minimize,
+            SizeBox = ThickFrame,
+            TiledWindow = OverlappedWindow,
+
+            // Common window styles:
+            OverlappedWindow = Overlapped | Caption | SystemMenu | ThickFrame | MinimizeBox | MaximizeBox,
+            PopupWindow = Popup | Border | SystemMenu,
+            ChildWindow = Child
+        }
+
+        [Flags]
+        public enum ExtendedWindowStyle : int
+        {
+            DialogModalFrame = 0x00000001,
+            NoParentNotify = 0x00000004,
+            Topmost = 0x00000008,
+            AcceptFiles = 0x00000010,
+            Transparent = 0x00000020,
+
+            // #if(WINVER >= 0x0400)
+            MdiChild = 0x00000040,
+            ToolWindow = 0x00000080,
+            WindowEdge = 0x00000100,
+            ClientEdge = 0x00000200,
+            ContextHelp = 0x00000400,
+            // #endif
+
+            // #if(WINVER >= 0x0400)
+            Right = 0x00001000,
+            Left = 0x00000000,
+            RightToLeftReading = 0x00002000,
+            LeftToRightReading = 0x00000000,
+            LeftScrollbar = 0x00004000,
+            RightScrollbar = 0x00000000,
+
+            ControlParent = 0x00010000,
+            StaticEdge = 0x00020000,
+            ApplicationWindow = 0x00040000,
+
+            OverlappedWindow = WindowEdge | ClientEdge,
+            PaletteWindow = WindowEdge | ToolWindow | Topmost,
+            // #endif
+
+            // #if(_WIN32_WINNT >= 0x0500)
+            Layered = 0x00080000,
+            // #endif
+
+            // #if(WINVER >= 0x0500)
+            NoInheritLayout = 0x00100000, // Disable inheritence of mirroring by children
+            RightToLeftLayout = 0x00400000, // Right to left mirroring
+            // #endif /* WINVER >= 0x0500 */
+
+            // #if(_WIN32_WINNT >= 0x0501)
+            Composited = 0x02000000,
+            // #endif /* _WIN32_WINNT >= 0x0501 */
+
+            // #if(_WIN32_WINNT >= 0x0500)
+            NoActivate = 0x08000000
+            // #endif /* _WIN32_WINNT >= 0x0500 */
+        }
+
+        #endregion
+
+        #region DestroyWindow
+
+        [DllImport("user32.dll", SetLastError = true)]
+        [return: MarshalAs(UnmanagedType.Bool)]
+        public static extern bool DestroyWindow(IntPtr windowHandle);
+
+        #endregion
+
+        #region RegisterClass
+
+        [DllImport("user32.dll", SetLastError = true)]
+        public static extern short RegisterClass(WindowClass window_class);
+
+        #endregion
+
+        #region UnregisterClass
+
+        [DllImport("user32.dll", SetLastError = true)]
+        public static extern short UnregisterClass(string className, IntPtr instance);
+
+        [DllImport("user32.dll", SetLastError = true)]
+        public static extern short UnregisterClass(IntPtr className, IntPtr instance);
+
+        #endregion
+
+        [CLSCompliant(false)]
+        [SuppressUnmanagedCodeSecurity]
+        [DllImport("user32.dll", SetLastError = true)]
+        public static extern LRESULT CallWindowProc(
+            WNDPROC lpPrevWndFunc,
+            HWND hWnd,
+            UINT Msg,
+            WPARAM wParam,
+            LPARAM lParam
+        );
+
+        [SuppressUnmanagedCodeSecurity]
+        [DllImport("user32.dll", SetLastError = true)]
+        public static extern LRESULT CallWindowProc(
+            WNDPROC lpPrevWndFunc,
+            HWND hWnd,
+            INT Msg,
+            WPARAM wParam,
+            LPARAM lParam
+        );
+
+        [SuppressUnmanagedCodeSecurity]
+        [DllImport("user32.dll", SetLastError = true)]
+        public static extern LONG_PTR SetWindowLongPtr(
+            HWND hWnd,
+            GetWindowLongOffsets nIndex,
+            LONG_PTR dwNewLong
+        );
+
+        [SuppressUnmanagedCodeSecurity]
+        [DllImport("user32.dll", SetLastError = true)]
+        public static extern LONG_PTR GetWindowLongPtr(
+            HWND hWnd,
+            GetWindowLongOffsets nIndex
+        );
+
+        #endregion
+
         #region Message handling
 
         #region PeekMessage
@@ -485,216 +720,6 @@ namespace OpenTK.Platform.Windows
 
         #endregion
 
-        #region Window Creation
-
-        #region SetWindowPos
-
-        // WINUSERAPI BOOL WINAPI SetWindowPos(__in HWND hWnd, __in_opt HWND hWndInsertAfter,
-        //                                     __in int X, __in int Y, __in int cx, __in int cy, __in UINT uFlags);
-
-        [DllImport("user32.dll")]
-        [return: MarshalAs(UnmanagedType.Bool)]
-        public static extern bool SetWindowPos(
-            IntPtr handle,
-            WindowPlacementOptions placement,
-            int x, int y, int cx, int cy,
-            SetWindowPosFlags flags
-        );
-
-        #endregion
-
-        #region CreateWindowEx
-
-        [DllImport("user32.dll", SetLastError = true, CharSet = CharSet.Auto)]
-        public static extern IntPtr CreateWindowEx(
-            [In]ExtendedWindowStyle ExStyle,
-            [In]string className,
-            [In]string windowName,
-            [In]WindowStyle Style,
-            [In]int X, int Y,
-            [In]int Width, int Height,
-            [In]IntPtr HandleToParentWindow,
-            [In]IntPtr Menu,
-            [In]IntPtr Instance,
-            [In]IntPtr Param);
-        /*
-        [DllImport("user32.dll", SetLastError = true)]
-        public static extern int CreateWindowEx(
-            [In]ExtendedWindowStyle ExStyle,
-            [In]IntPtr ClassName,
-            [In]IntPtr WindowName,
-            [In]WindowStyle Style,
-            [In]int X, [In]int Y,
-            [In]int Width, [In]int Height,
-            [In]IntPtr HandleToParentWindow,
-            [In]IntPtr Menu,
-            [In]IntPtr Instance,
-            [In]IntPtr Param);
-        */
-        [DllImport("user32.dll", SetLastError = true, CharSet = CharSet.Auto)]
-        public static extern IntPtr CreateWindowEx(
-            ExtendedWindowStyle ExStyle,
-            IntPtr ClassName,
-            IntPtr WindowName,
-            WindowStyle Style,
-            int X, int Y,
-            int Width, int Height,
-            IntPtr HandleToParentWindow,
-            IntPtr Menu,
-            IntPtr Instance,
-            IntPtr Param);
-
-        public enum WindowStyle : int
-        {
-            Overlapped = 0x00000000,
-            Popup = unchecked((int)0x80000000),
-            Child = 0x40000000,
-            Minimize = 0x20000000,
-            Visible = 0x10000000,
-            Disabled = 0x08000000,
-            ClipSiblings = 0x04000000,
-            ClipChildren = 0x02000000,
-            Maximize = 0x01000000,
-            Caption = 0x00C00000,    // Border | DialogFrame
-            Border = 0x00800000,
-            DialogFrame = 0x00400000,
-            VScroll = 0x00200000,
-            HScreen = 0x00100000,
-            SystemMenu = 0x00080000,
-            ThickFrame = 0x00040000,
-            Group = 0x00020000,
-            TabStop = 0x00010000,
-
-            MinimizeBox = 0x00020000,
-            MaximizeBox = 0x00010000,
-
-            Tiled = Overlapped,
-            Iconic = Minimize,
-            SizeBox = ThickFrame,
-            TiledWindow = OverlappedWindow,
-
-            // Common window styles:
-            OverlappedWindow = Overlapped | Caption | SystemMenu | ThickFrame | MinimizeBox | MaximizeBox,
-            PopupWindow = Popup | Border | SystemMenu,
-            ChildWindow = Child
-        }
-
-        [Flags]
-        public enum ExtendedWindowStyle : int
-        {
-            DialogModalFrame = 0x00000001,
-            NoParentNotify = 0x00000004,
-            Topmost = 0x00000008,
-            AcceptFiles = 0x00000010,
-            Transparent = 0x00000020,
-
-            // #if(WINVER >= 0x0400)
-            MdiChild = 0x00000040,
-            ToolWindow = 0x00000080,
-            WindowEdge = 0x00000100,
-            ClientEdge = 0x00000200,
-            ContextHelp = 0x00000400,
-            // #endif
-
-            // #if(WINVER >= 0x0400)
-            Right = 0x00001000,
-            Left = 0x00000000,
-            RightToLeftReading = 0x00002000,
-            LeftToRightReading = 0x00000000,
-            LeftScrollbar = 0x00004000,
-            RightScrollbar = 0x00000000,
-
-            ControlParent = 0x00010000,
-            StaticEdge = 0x00020000,
-            ApplicationWindow = 0x00040000,
-
-            OverlappedWindow = WindowEdge | ClientEdge,
-            PaletteWindow = WindowEdge | ToolWindow | Topmost,
-            // #endif
-
-            // #if(_WIN32_WINNT >= 0x0500)
-            Layered = 0x00080000,
-            // #endif
-
-            // #if(WINVER >= 0x0500)
-            NoInheritLayout = 0x00100000, // Disable inheritence of mirroring by children
-            RightToLeftLayout = 0x00400000, // Right to left mirroring
-            // #endif /* WINVER >= 0x0500 */
-
-            // #if(_WIN32_WINNT >= 0x0501)
-            Composited = 0x02000000,
-            // #endif /* _WIN32_WINNT >= 0x0501 */
-
-            // #if(_WIN32_WINNT >= 0x0500)
-            NoActivate = 0x08000000
-            // #endif /* _WIN32_WINNT >= 0x0500 */
-        }
-
-        #endregion
-
-        #region DestroyWindow
-
-        [DllImport("user32.dll", SetLastError = true)]
-        [return: MarshalAs(UnmanagedType.Bool)]
-        public static extern bool DestroyWindow(IntPtr windowHandle);
-
-        #endregion
-
-        #region RegisterClass
-
-        [DllImport("user32.dll", SetLastError = true)]
-        public static extern short RegisterClass(WindowClass window_class);
-
-        #endregion
-
-        #region UnregisterClass
-
-        [DllImport("user32.dll", SetLastError = true)]
-        public static extern short UnregisterClass(string className, IntPtr instance);
-
-        [DllImport("user32.dll", SetLastError = true)]
-        public static extern short UnregisterClass(IntPtr className, IntPtr instance);
-
-        #endregion
-
-        [CLSCompliant(false)]
-        [SuppressUnmanagedCodeSecurity]
-        [DllImport("user32.dll", SetLastError = true)]
-        public static extern LRESULT CallWindowProc(
-            WNDPROC lpPrevWndFunc,
-            HWND hWnd,
-            UINT Msg,
-            WPARAM wParam,
-            LPARAM lParam
-        );
-
-        [SuppressUnmanagedCodeSecurity]
-        [DllImport("user32.dll", SetLastError = true)]
-        public static extern LRESULT CallWindowProc(
-            WNDPROC lpPrevWndFunc,
-            HWND hWnd,
-            INT Msg,
-            WPARAM wParam,
-            LPARAM lParam
-        );
-
-        [SuppressUnmanagedCodeSecurity]
-        [DllImport("user32.dll", SetLastError = true)]
-        public static extern LONG_PTR SetWindowLongPtr(
-            HWND hWnd,
-            GetWindowLongOffsets nIndex,
-            LONG_PTR dwNewLong
-        );
-
-        [SuppressUnmanagedCodeSecurity]
-        [DllImport("user32.dll", SetLastError = true)]
-        public static extern LONG_PTR GetWindowLongPtr(
-            HWND hWnd,
-            GetWindowLongOffsets nIndex
-        );
-
-        #endregion
-
         #region Display settings
 
         #region int ChangeDisplaySettings(ref Gdi.DEVMODE devMode, int flags)
@@ -2118,6 +2143,42 @@ namespace OpenTK.Platform.Windows
 
         #endregion
 
+        #region Rectangle
+
+        /// <summary>
+        /// Defines the coordinates of the upper-left and lower-right corners of a rectangle.
+        /// </summary>
+        /// <remarks>
+        /// By convention, the right and bottom edges of the rectangle are normally considered exclusive. In other words, the pixel whose coordinates are (right, bottom) lies immediately outside of the the rectangle. For example, when RECT is passed to the FillRect function, the rectangle is filled up to, but not including, the right column and bottom row of pixels. This structure is identical to the RECTL structure.
+        /// </remarks>
+        [StructLayout(LayoutKind.Sequential)]
+        public struct Rectangle
+        {
+            /// <summary>
+            /// Specifies the x-coordinate of the upper-left corner of the rectangle.
+            /// </summary>
+            public LONG left;
+            /// <summary>
+            /// Specifies the y-coordinate of the upper-left corner of the rectangle.
+            /// </summary>
+            public LONG top;
+            /// <summary>
+            /// Specifies the x-coordinate of the lower-right corner of the rectangle.
+            /// </summary>
+            public LONG right;
+            /// <summary>
+            /// Specifies the y-coordinate of the lower-right corner of the rectangle.
+            /// </summary>
+            public LONG bottom;
+
+            public override string ToString()
+            {
+                return String.Format("({0},{1})-({2},{3})", left, top, right, bottom);
+            }
+        }
+
+        #endregion
+
         #endregion
 
         #region --- Enums ---
diff --git a/Source/OpenTK/Platform/Windows/WinGLControl.cs b/Source/OpenTK/Platform/Windows/WinGLControl.cs
index 9dd9aa38..f9447f76 100644
--- a/Source/OpenTK/Platform/Windows/WinGLControl.cs
+++ b/Source/OpenTK/Platform/Windows/WinGLControl.cs
@@ -37,11 +37,6 @@ namespace OpenTK.Platform.Windows
             c.HandleDestroyed += new EventHandler(c_HandleDestroyed);
 
             glContext = new WinGLContext(mode);
-
-            // Create the actual context
-            c.Visible = true;
-            //c.CreateControl();
-            glContext.MakeCurrent();
         }
 
         void c_HandleCreated(object sender, EventArgs e)
@@ -53,6 +48,7 @@ namespace OpenTK.Platform.Windows
             {
                 glContext.PrepareContext((sender as Control).Handle);
                 glContext.CreateContext();
+                glContext.MakeCurrent();
             }
             catch (ApplicationException expt)
             {
diff --git a/Source/OpenTK/Platform/Windows/WinGLNative.cs b/Source/OpenTK/Platform/Windows/WinGLNative.cs
index adb5b37e..2ed8b978 100644
--- a/Source/OpenTK/Platform/Windows/WinGLNative.cs
+++ b/Source/OpenTK/Platform/Windows/WinGLNative.cs
@@ -33,11 +33,14 @@ namespace OpenTK.Platform.Windows
         private bool isExiting;
         private bool exists;
         private WindowInfo window;
+        private int top, bottom, left, right;
 
         /// <summary>
         /// For use in WndProc only.
         /// </summary>
-        private int width, height;
+        private int width = 0, height = 0;
+
+        private int left_border, right_border, top_border, bottom_border;
 
         #endregion
 
@@ -68,8 +71,10 @@ namespace OpenTK.Platform.Windows
                     // Get window size
                     width = Marshal.ReadInt32(m.LParam, (int)Marshal.OffsetOf(typeof(API.WindowPosition), "cx"));
                     height = Marshal.ReadInt32(m.LParam, (int)Marshal.OffsetOf(typeof(API.WindowPosition), "cy"));
+                    width -= (left_border + right_border);
+                    height -= (top_border + bottom_border);
                     //if (resizeEventArgs.Width != width || resizeEventArgs.Height != height)
-                    if (mode.Width != width || mode.Height != height)
+                    if (this.mode.Width != width || this.mode.Height != height)
                     {
                         // If the size has changed, raise the ResizeEvent.
                         resizeEventArgs.Width = width;
@@ -83,8 +88,10 @@ namespace OpenTK.Platform.Windows
 
                 case API.Constants.WM_CREATE:
                     // Set the window width and height:
-                    mode.Width = Marshal.ReadInt32(m.LParam, (int)Marshal.OffsetOf(typeof(API.CreateStruct), "cx"));
-                    mode.Height = Marshal.ReadInt32(m.LParam, (int)Marshal.OffsetOf(typeof(API.CreateStruct), "cy"));
+                    this.mode.Width = Marshal.ReadInt32(m.LParam, (int)Marshal.OffsetOf(typeof(API.CreateStruct), "cx"));
+                    this.mode.Height = Marshal.ReadInt32(m.LParam, (int)Marshal.OffsetOf(typeof(API.CreateStruct), "cy"));
+                    this.mode.Width -= (left_border + right_border);
+                    this.mode.Height -= (top_border + bottom_border);
 
                     // Raise the Create event
                     this.OnCreate(EventArgs.Empty);
@@ -206,7 +213,7 @@ namespace OpenTK.Platform.Windows
 
         #region private void CreateWindow(DisplayMode mode)
 
-        public void CreateWindow(DisplayMode mode)
+        public void CreateWindow(DisplayMode windowMode)
         {
             Debug.Print("Creating native window with mode: {0}", mode.ToString());
             Debug.Indent();
@@ -215,14 +222,34 @@ namespace OpenTK.Platform.Windows
             cp.ClassStyle =
                 (int)API.WindowClassStyle.OwnDC |
                 (int)API.WindowClassStyle.VRedraw |
-                (int)API.WindowClassStyle.HRedraw | (int)API.WindowClassStyle.Ime;
+                (int)API.WindowClassStyle.HRedraw |
+                (int)API.WindowClassStyle.Ime;
             cp.Style =
                 (int)API.WindowStyle.Visible |
                 (int)API.WindowStyle.ClipChildren |
                 (int)API.WindowStyle.ClipSiblings |
                 (int)API.WindowStyle.OverlappedWindow;
-            cp.Width = mode.Width;
-            cp.Height = mode.Height;
+
+            API.Rectangle rect = new API.Rectangle();
+            rect.top = rect.left = 0;
+            rect.bottom = windowMode.Height;
+            rect.right = windowMode.Width;
+            API.AdjustWindowRect(ref rect, API.WindowStyle.OverlappedWindow, false);
+
+            // Not used
+            Top = 0;
+            Left = 0;
+            Right = windowMode.Width;
+            Bottom = windowMode.Height;
+            // --------
+
+            top_border = -rect.top;
+            left_border = -rect.left;
+            bottom_border = rect.bottom - windowMode.Height;
+            right_border = rect.right - windowMode.Width;
+            
+            cp.Width = rect.right - rect.left;
+            cp.Height = rect.bottom - rect.top;
             cp.Caption = "OpenTK Game Window";
 
             // Keep in mind that some construction code runs in WM_CREATE,
@@ -360,11 +387,6 @@ namespace OpenTK.Platform.Windows
             set
             {
                 throw new NotImplementedException();
-                //WinApi.PostMessage(
-                //    this.Handle,
-                //    WinApi.Constants.WM_WINDOWPOSCHANGING,
-
-                //mode.Width = value;
             }
         }
 
@@ -404,6 +426,30 @@ namespace OpenTK.Platform.Windows
 
         #endregion
 
+        public int Top
+        {
+            get { return top; }
+            private set { top = value; }
+        }
+
+        public int Bottom
+        {
+            get { return bottom; }
+            private set { bottom = value; }
+        }
+
+        public int Left
+        {
+            get { return left; }
+            private set { left = value; }
+        }
+
+        public int Right
+        {
+            get { return right; }
+            private set { right = value; }
+        }
+
         #endregion
     }
 
diff --git a/Source/OpenTK/Platform/X11/X11GLNative.cs b/Source/OpenTK/Platform/X11/X11GLNative.cs
index 783059f4..355cd0bc 100644
--- a/Source/OpenTK/Platform/X11/X11GLNative.cs
+++ b/Source/OpenTK/Platform/X11/X11GLNative.cs
@@ -30,6 +30,8 @@ namespace OpenTK.Platform.X11
         // Number of pending events.
         private int pending = 0;
 
+        private int top, bottom, left, right;
+
         // C# ResizeEventArgs
         private ResizeEventArgs resizeEventArgs = new ResizeEventArgs();
 
@@ -288,6 +290,10 @@ namespace OpenTK.Platform.X11
                 hints.flags = (IntPtr)(XSizeHintsFlags.USSize | XSizeHintsFlags.USPosition);
                 Functions.XSetWMNormalHints(window.Display, window.Handle, ref hints);
 
+                Top = Left = 0;
+                Right = Width;
+                Bottom = Height;
+
                 //XTextProperty text = new XTextProperty();
                 //text.value = "OpenTK Game Window";
                 //text.format = 8;
@@ -439,6 +445,30 @@ namespace OpenTK.Platform.X11
 
         #endregion
 
+        public int Top
+        {
+            get { return top; }
+            private set { top = value; }
+        }
+
+        public int Bottom
+        {
+            get { return bottom; }
+            private set { bottom = value; }
+        }
+
+        public int Left
+        {
+            get { return left; }
+            private set { left = value; }
+        }
+
+        public int Right
+        {
+            get { return right; }
+            private set { right = value; }
+        }
+
         #endregion
 
         #region --- IDisposable Members ---