aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorKevin Rushforth <[email protected]>2004-11-03 00:24:11 +0000
committerKevin Rushforth <[email protected]>2004-11-03 00:24:11 +0000
commit2b8ae14735ffdea883a31120af4b31554f6d1498 (patch)
tree5f0bc555e3a531c430d2e1fa525a03863abc7b16
parent4fe2e6bd4f43e427b5880cce4f4bc6b0728ef764 (diff)
More fixes related to destruction of off-screen buffer; off-screen buffer
is now destroyed reliably when application calls setOffScreenBuffer(null) git-svn-id: https://svn.java.net/svn/j3d-core~svn/trunk@67 ba19aa83-45c5-6ac9-afd3-db810772062c
-rw-r--r--src/classes/share/javax/media/j3d/Canvas3D.java86
-rw-r--r--src/classes/share/javax/media/j3d/Renderer.java6
2 files changed, 74 insertions, 18 deletions
diff --git a/src/classes/share/javax/media/j3d/Canvas3D.java b/src/classes/share/javax/media/j3d/Canvas3D.java
index 943c9ad..5b2af1f 100644
--- a/src/classes/share/javax/media/j3d/Canvas3D.java
+++ b/src/classes/share/javax/media/j3d/Canvas3D.java
@@ -1,4 +1,3 @@
-
/*
* $RCSfile$
*
@@ -329,9 +328,11 @@ public class Canvas3D extends Canvas {
//
volatile boolean offScreenRendering = false;
- // Flag that indicates whether canvas is waiting for off-screen
- // rendering to be completed
- boolean waitingForOffScreenRendering = false;
+ //
+ // Flag that indicates we are waiting for an off-screen buffer to be
+ // created or destroyed by the Renderer.
+ //
+ volatile boolean offScreenBufferPending = false;
//
// ImageComponent used for off-screen rendering
@@ -1411,7 +1412,7 @@ public class Canvas3D extends Canvas {
validCanvas = false;
}
- removeCtx(false);
+ removeCtx();
synchronized (drawingSurfaceObject) {
@@ -1776,6 +1777,9 @@ public class Canvas3D extends Canvas {
if (offScreenRendering)
throw new RestrictedAccessException(J3dI18N.getString("Canvas3D2"));
+ // Check that offScreenBufferPending is not already set
+ J3dDebug.doAssert(!offScreenBufferPending, "!offScreenBufferPending");
+
if (buffer != null) {
ImageComponent2DRetained bufferRetained =
(ImageComponent2DRetained)buffer.retained;
@@ -1803,9 +1807,10 @@ public class Canvas3D extends Canvas {
(offScreenCanvasSize.height != height)) {
if (window != 0) {
+ removeCtx();
// Fix for Issue 18.
// Will do destroyOffScreenBuffer in the Renderer thread.
- removeCtx(true);
+ sendDestroyOffScreenBuffer();
window = 0;
}
@@ -1814,13 +1819,13 @@ public class Canvas3D extends Canvas {
this.setSize(offScreenCanvasSize);
if (width > 0 && height > 0) {
- VirtualUniverse.mc.sendCreateOffScreenBuffer(this);
+ sendCreateOffScreenBuffer();
}
ctx = 0;
}
else if (ctx != 0) {
- removeCtx(false);
+ removeCtx();
}
offScreenBuffer = buffer;
@@ -4023,25 +4028,76 @@ public class Canvas3D extends Canvas {
}
- private void removeCtx(boolean destroyOffscreen) {
+ // Send a createOffScreenBuffer message to Renderer (via
+ // MasterControl) and wait for it to be done
+ private void sendCreateOffScreenBuffer() {
+ // Wait for the buffer to be created unless called from
+ // a Behavior or from a Rendering thread
+ if (!(Thread.currentThread() instanceof BehaviorScheduler) &&
+ !(Thread.currentThread() instanceof Renderer)) {
+
+ offScreenBufferPending = true;
+ }
+
+ // Send message to Renderer thread to perform createOffScreenBuffer.
+ VirtualUniverse.mc.sendCreateOffScreenBuffer(this);
+
+ // Wait for off-screen buffer to be created
+ while (offScreenBufferPending) {
+ MasterControl.threadYield();
+ }
+ }
+
+ // Send a destroyOffScreenBuffer message to Renderer (via
+ // MasterControl) and wait for it to be done
+ private void sendDestroyOffScreenBuffer() {
+ // Nothing to do unless screen.renderer is non-null
+ if ((screen == null) || (screen.renderer == null)) {
+ return;
+ }
+
+ // Wait for the buffer to be destroyed unless called from
+ // a Behavior or from a Rendering thread
+ Thread currentThread = Thread.currentThread();
+ if (!(currentThread instanceof BehaviorScheduler) &&
+ !(currentThread instanceof Renderer)) {
+
+ offScreenBufferPending = true;
+ }
+
+ // Fix for Issue 18
+ // Send message to Renderer thread to perform destroyOffScreenBuffer.
+ VirtualUniverse.mc.postRequest(MasterControl.FREE_CONTEXT,
+ new Object[]{this,
+ new Long(screen.display),
+ new Integer(window),
+ new Long(0),
+ Boolean.TRUE});
+
+ // Wait for off-screen buffer to be destroyed
+ while (offScreenBufferPending) {
+ MasterControl.threadYield();
+ }
+ }
+
+ private void removeCtx() {
if ((screen != null) &&
(screen.renderer != null) &&
(ctx != 0)) {
- // Fix for Issue 18
- // Pass destroyOffscreen boolean Renderer thread to perform destroyOffScreenBuffer.
VirtualUniverse.mc.postRequest(MasterControl.FREE_CONTEXT,
new Object[]{this,
new Long(screen.display),
new Integer(window),
new Long(ctx),
- new Boolean(destroyOffscreen)});
-
+ Boolean.FALSE});
+
// Fix for Issue 19
// Wait for the context to be freed unless called from
// a Behavior or from a Rendering thread
- if (!(Thread.currentThread() instanceof BehaviorScheduler) &&
- !(Thread.currentThread() instanceof Renderer)) {
+ Thread currentThread = Thread.currentThread();
+ if (!(currentThread instanceof BehaviorScheduler) &&
+ !(currentThread instanceof Renderer)) {
while (ctxTimeStamp != 0) {
MasterControl.threadYield();
}
diff --git a/src/classes/share/javax/media/j3d/Renderer.java b/src/classes/share/javax/media/j3d/Renderer.java
index fd560cd..f05ebb0 100644
--- a/src/classes/share/javax/media/j3d/Renderer.java
+++ b/src/classes/share/javax/media/j3d/Renderer.java
@@ -445,8 +445,6 @@ class Renderer extends J3dThread {
if (renderType == J3dMessage.CREATE_OFFSCREENBUFFER) {
// Fix for issue 18.
// Fix for issue 20.
- /* System.out.println("Renderer offScreenBuffer - fbConfig = "
- + canvas.fbConfig); */
canvas.window =
canvas.createOffScreenBuffer(canvas.ctx,
canvas.screen.display,
@@ -454,6 +452,7 @@ class Renderer extends J3dThread {
canvas.fbConfig,
canvas.offScreenCanvasSize.width,
canvas.offScreenCanvasSize.height);
+ canvas.offScreenBufferPending = false;
m[nmesg++].decRefcount();
continue;
}
@@ -1495,9 +1494,10 @@ class Renderer extends J3dThread {
// Since we are now the renderer thread,
// we can safely execute destroyOffScreenBuffer.
if(destroyOffScreenBuffer) {
- cv.makeCtxCurrent();
cv.destroyOffScreenBuffer(ctx, display, cv.fbConfig, window);
+ cv.offScreenBufferPending = false;
}
+
if (ctx != 0) {
int idx = listOfCtxs.indexOf(new Long(ctx));
if (idx >= 0) {