diff options
Diffstat (limited to 'src/net/java/games/jogl/impl')
-rw-r--r-- | src/net/java/games/jogl/impl/windows/WindowsOffscreenGLContext.java | 28 |
1 files changed, 14 insertions, 14 deletions
diff --git a/src/net/java/games/jogl/impl/windows/WindowsOffscreenGLContext.java b/src/net/java/games/jogl/impl/windows/WindowsOffscreenGLContext.java index 68a5655da..9e871caba 100644 --- a/src/net/java/games/jogl/impl/windows/WindowsOffscreenGLContext.java +++ b/src/net/java/games/jogl/impl/windows/WindowsOffscreenGLContext.java @@ -118,7 +118,7 @@ public class WindowsOffscreenGLContext extends WindowsGLContext { if (pendingOffscreenResize) { if (pendingOffscreenWidth != width || pendingOffscreenHeight != height) { if (hglrc != 0) { - destroy(); + destroyImpl(); } width = pendingOffscreenWidth; height = pendingOffscreenHeight; @@ -128,6 +128,19 @@ public class WindowsOffscreenGLContext extends WindowsGLContext { return super.makeCurrent(initAction); } + protected void destroyImpl() { + if (hglrc != 0) { + super.destroyImpl(); + // Must destroy OpenGL context, bitmap and device context + WGL.SelectObject(hdc, origbitmap); + WGL.DeleteObject(hbitmap); + WGL.DeleteDC(hdc); + origbitmap = 0; + hbitmap = 0; + hdc = 0; + } + } + public synchronized void swapBuffers() throws GLException { } @@ -167,17 +180,4 @@ public class WindowsOffscreenGLContext extends WindowsGLContext { choosePixelFormatAndCreateContext(false); } - - private void destroy() { - // Must destroy OpenGL context, bitmap and device context - WGL.wglDeleteContext(hglrc); - WGL.SelectObject(hdc, origbitmap); - WGL.DeleteObject(hbitmap); - WGL.DeleteDC(hdc); - hglrc = 0; - origbitmap = 0; - hbitmap = 0; - hdc = 0; - GLContextShareSet.contextDestroyed(this); - } } |