summaryrefslogtreecommitdiffstats
path: root/src/net/java
diff options
context:
space:
mode:
Diffstat (limited to 'src/net/java')
-rw-r--r--src/net/java/games/jogl/impl/windows/WindowsOffscreenGLContext.java28
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);
- }
}