From ecd7db99c185295a9a4d7b1611ba46e65047068e Mon Sep 17 00:00:00 2001 From: Stefanos A Date: Wed, 18 Dec 2013 14:51:00 +0100 Subject: [PATCH] Replace Wgl.GetCurrentDC with cached dc with --- Source/OpenTK/Platform/Windows/WinGLContext.cs | 10 +++++++--- 1 file changed, 7 insertions(+), 3 deletions(-) diff --git a/Source/OpenTK/Platform/Windows/WinGLContext.cs b/Source/OpenTK/Platform/Windows/WinGLContext.cs index 9d4bf4c5..0e727df7 100644 --- a/Source/OpenTK/Platform/Windows/WinGLContext.cs +++ b/Source/OpenTK/Platform/Windows/WinGLContext.cs @@ -29,6 +29,7 @@ namespace OpenTK.Platform.Windows { static readonly object LoadLock = new object(); + IntPtr device_context; bool vsync_supported; readonly WinGraphicsMode ModeSelector; @@ -210,7 +211,7 @@ namespace OpenTK.Platform.Windows // side-effects (i.e. the old contexts can still be handled // using the new entry points.) // Sigh... - Wgl.MakeCurrent(window.DeviceContext, Handle.Handle); + MakeCurrent(window); Wgl.LoadAll(); if (sharedContext != null) @@ -284,9 +285,13 @@ namespace OpenTK.Platform.Windows success = Wgl.MakeCurrent(IntPtr.Zero, IntPtr.Zero); } + device_context = wnd.DeviceContext; + if (!success) + { throw new GraphicsContextException(String.Format( "Failed to make context {0} current. Error: {1}", this, Marshal.GetLastWin32Error())); + } } } @@ -435,11 +440,10 @@ namespace OpenTK.Platform.Windows { get { - return Wgl.GetCurrentDC(); + return device_context; } } - #endregion #endregion