summaryrefslogtreecommitdiffstats
path: root/src/demos
diff options
context:
space:
mode:
authorKenneth Russel <[email protected]>2008-10-30 00:36:37 +0000
committerKenneth Russel <[email protected]>2008-10-30 00:36:37 +0000
commit1d4b8640e128143707e6c19f6249d6b4dba0d2a0 (patch)
tree6e84ac75c88aee73b60255048a00cfd301f8db3f /src/demos
parent0df738664c9ade75e38c3982560b5cf3e4cdf3df (diff)
Incorporated patch from Michael Bien fixing roughly 80% of compilation errors
git-svn-id: file:///usr/local/projects/SUN/JOGL/git-svn/../svn-server-sync/jogl-demos/branches/JOGL_2_SANDBOX@287 3298f667-5e0e-4b4a-8ed4-a3559d26a5f4
Diffstat (limited to 'src/demos')
-rwxr-xr-xsrc/demos/applets/GearsApplet.java7
-rwxr-xr-xsrc/demos/applets/GearsJOALApplet.java18
-rw-r--r--src/demos/cg/runtime_ogl/cgGL_vertex_example.java2
-rw-r--r--src/demos/cg/runtime_ogl_vertex_fragment/runtime_ogl_vertex_fragment.java2
-rwxr-xr-xsrc/demos/context/DualContext.java25
-rwxr-xr-xsrc/demos/cubefbo/Main.java16
-rwxr-xr-xsrc/demos/fullscreen/GearsFullscreen.java4
-rwxr-xr-xsrc/demos/fullscreen/GearsFullscreen2.java22
-rwxr-xr-xsrc/demos/fullscreen/JGearsFullscreen.java24
-rwxr-xr-xsrc/demos/gamma/TestGamma.java14
-rw-r--r--src/demos/gears/Gears.java97
-rwxr-xr-xsrc/demos/hdr/HDR.java310
-rw-r--r--src/demos/hwShadowmapsSimple/HWShadowmapsSimple.java303
-rw-r--r--src/demos/infiniteShadowVolumes/InfiniteShadowVolumes.java381
-rwxr-xr-xsrc/demos/j2d/CustomText.java57
-rwxr-xr-xsrc/demos/j2d/FlyingText.java74
-rwxr-xr-xsrc/demos/j2d/TestOverlay.java29
-rwxr-xr-xsrc/demos/j2d/TestTextRenderer.java27
-rwxr-xr-xsrc/demos/j2d/TestTextureRenderer.java28
-rwxr-xr-xsrc/demos/j2d/TextCube.java43
-rwxr-xr-xsrc/demos/j2d/TextFlow.java32
-rw-r--r--src/demos/jgears/JGears.java40
-rwxr-xr-xsrc/demos/jrefract/JRefract.java50
-rwxr-xr-xsrc/demos/misc/GLCapsTableDemo.java28
-rwxr-xr-xsrc/demos/misc/Picking.java54
-rwxr-xr-xsrc/demos/misc/TiledRendering.java7
-rwxr-xr-xsrc/demos/multisample/Multisample.java9
-rwxr-xr-xsrc/demos/nurbs/icons/IconFactory.java4
-rwxr-xr-xsrc/demos/nurbs/surfaceapp/GLListener.java90
-rwxr-xr-xsrc/demos/nurbs/surfaceapp/SurfaceApp.java3
-rwxr-xr-xsrc/demos/particles/engine/Engine.java2
-rwxr-xr-xsrc/demos/particles/engine/GLComponent.java10
-rwxr-xr-xsrc/demos/particles/engine/Particle.java4
-rwxr-xr-xsrc/demos/printext/PrintExt.java9
-rw-r--r--src/demos/proceduralTexturePhysics/ProceduralTexturePhysics.java626
-rw-r--r--src/demos/proceduralTexturePhysics/Water.java465
-rw-r--r--src/demos/tess/Tess.java44
-rwxr-xr-xsrc/demos/testContextDestruction/TestContextDestruction.java88
-rw-r--r--src/demos/testContextSharing/TestContextSharing.java68
-rwxr-xr-xsrc/demos/texture/TestSubImage.java43
-rwxr-xr-xsrc/demos/texture/TestTexture.java45
-rwxr-xr-xsrc/demos/texture/TextureConvert.java16
-rw-r--r--src/demos/util/Bunny.java4
-rwxr-xr-xsrc/demos/util/Cubemap.java13
-rw-r--r--src/demos/util/DxTex.java4
-rwxr-xr-xsrc/demos/util/FPSCounter.java10
-rw-r--r--src/demos/util/ObjReader.java19
-rw-r--r--src/demos/util/Triceratops.java14
-rw-r--r--src/demos/vertexArrayRange/VertexArrayRange.java57
-rw-r--r--src/demos/vertexBufferObject/VertexBufferObject.java116
-rw-r--r--src/demos/vertexProgRefract/VertexProgRefract.java163
-rw-r--r--src/demos/vertexProgWarp/VertexProgWarp.java116
-rwxr-xr-xsrc/demos/xtrans/OffscreenComponentWrapper.java9
-rwxr-xr-xsrc/demos/xtrans/OffscreenDesktopManager.java29
-rwxr-xr-xsrc/demos/xtrans/XTBasicTransition.java8
-rwxr-xr-xsrc/demos/xtrans/XTDesktopManager.java69
-rwxr-xr-xsrc/demos/xtrans/XTDesktopPane.java36
-rwxr-xr-xsrc/demos/xtrans/XTTransition.java2
58 files changed, 2171 insertions, 1718 deletions
diff --git a/src/demos/applets/GearsApplet.java b/src/demos/applets/GearsApplet.java
index 15ea9c7..bc65d74 100755
--- a/src/demos/applets/GearsApplet.java
+++ b/src/demos/applets/GearsApplet.java
@@ -2,11 +2,10 @@ package demos.applets;
import java.applet.*;
import java.awt.*;
-import java.io.*;
-
-import javax.media.opengl.*;
-import com.sun.opengl.util.*;
import demos.gears.Gears;
+import javax.media.opengl.awt.GLCanvas;
+import javax.media.opengl.util.Animator;
+import javax.media.opengl.util.FPSAnimator;
/** Shows how to deploy an applet using JOGL. This demo must be
referenced from a web page via an &lt;applet&gt; tag. */
diff --git a/src/demos/applets/GearsJOALApplet.java b/src/demos/applets/GearsJOALApplet.java
index e33733a..9a1db8a 100755
--- a/src/demos/applets/GearsJOALApplet.java
+++ b/src/demos/applets/GearsJOALApplet.java
@@ -1,15 +1,15 @@
package demos.applets;
-import java.applet.*;
-import java.awt.*;
-import java.io.*;
-import javax.swing.*;
-
-import javax.media.opengl.*;
-import com.sun.opengl.util.*;
import demos.gears.Gears;
-import demos.devmaster.lesson1.*;
-import net.java.games.joal.util.*;
+import java.applet.Applet;
+import java.awt.EventQueue;
+import java.awt.GridLayout;
+import javax.media.opengl.awt.GLCanvas;
+import javax.media.opengl.util.Animator;
+import javax.media.opengl.util.FPSAnimator;
+import javax.swing.JPanel;
+
+
/** Shows how to deploy an applet using both JOGL and JOAL. This demo
must be referenced from a web page via an &lt;applet&gt; tag. */
diff --git a/src/demos/cg/runtime_ogl/cgGL_vertex_example.java b/src/demos/cg/runtime_ogl/cgGL_vertex_example.java
index f85e26c..2324e0e 100644
--- a/src/demos/cg/runtime_ogl/cgGL_vertex_example.java
+++ b/src/demos/cg/runtime_ogl/cgGL_vertex_example.java
@@ -284,6 +284,6 @@ public class cgGL_vertex_example implements GLEventListener
}).start();
}
});
- frame.show();
+ frame.setVisible(true);
}
}
diff --git a/src/demos/cg/runtime_ogl_vertex_fragment/runtime_ogl_vertex_fragment.java b/src/demos/cg/runtime_ogl_vertex_fragment/runtime_ogl_vertex_fragment.java
index afafd6f..da23072 100644
--- a/src/demos/cg/runtime_ogl_vertex_fragment/runtime_ogl_vertex_fragment.java
+++ b/src/demos/cg/runtime_ogl_vertex_fragment/runtime_ogl_vertex_fragment.java
@@ -88,7 +88,7 @@ public class runtime_ogl_vertex_fragment implements GLEventListener
}).start();
}
});
- frame.show();
+ frame.setVisible(true);
animator.start();
// and all the rest happens in the display function...
diff --git a/src/demos/context/DualContext.java b/src/demos/context/DualContext.java
index ae7865f..8e23f1b 100755
--- a/src/demos/context/DualContext.java
+++ b/src/demos/context/DualContext.java
@@ -39,13 +39,24 @@
package demos.context;
-import java.awt.*;
-import java.awt.event.*;
-import javax.swing.*;
+import com.sun.opengl.util.glut.gl2.GLUTgl2;
+import java.awt.BorderLayout;
+import java.awt.Canvas;
+import java.awt.Graphics;
+import java.awt.GraphicsConfiguration;
+import java.awt.event.ActionEvent;
+import java.awt.event.ActionListener;
+import javax.media.opengl.GL;
+import javax.media.opengl.GLCapabilities;
+import javax.media.opengl.GLContext;
+import javax.media.opengl.GLDrawable;
+import javax.media.opengl.GLDrawableFactory;
+import javax.media.opengl.awt.AWTGraphicsConfiguration;
+import javax.media.opengl.glu.GLU;
+import javax.swing.JButton;
+import javax.swing.JFrame;
+
-import javax.media.opengl.*;
-import javax.media.opengl.glu.*;
-import com.sun.opengl.util.*;
/** This demo illustrates the use of the GLDrawable and GLContext APIs
to create two OpenGL contexts for the same Canvas. The red and
@@ -58,7 +69,7 @@ public class DualContext extends Canvas {
private GLContext context1;
private GLContext context2;
private GLU glu;
- private GLUT glut;
+ private GLUTgl2 glut;
private int repaintNum;
public DualContext(GLCapabilities capabilities) {
diff --git a/src/demos/cubefbo/Main.java b/src/demos/cubefbo/Main.java
index bb2d479..b1db392 100755
--- a/src/demos/cubefbo/Main.java
+++ b/src/demos/cubefbo/Main.java
@@ -33,12 +33,14 @@
package demos.cubefbo;
-import javax.media.opengl.*;
-import com.sun.opengl.util.*;
-import java.nio.*;
-import java.awt.*;
-import java.awt.event.*;
-import java.applet.*;
+import java.awt.Frame;
+import java.awt.event.WindowAdapter;
+import java.awt.event.WindowEvent;
+import javax.media.opengl.GLCapabilities;
+import javax.media.opengl.awt.GLCanvas;
+import javax.media.opengl.util.Animator;
+import javax.media.opengl.util.FPSAnimator;
+
public class Main
{
@@ -87,7 +89,7 @@ public class Main
}
});
- frame.show();
+ frame.setVisible(true);
animator.start();
}
}
diff --git a/src/demos/fullscreen/GearsFullscreen.java b/src/demos/fullscreen/GearsFullscreen.java
index f71dd77..5e574be 100755
--- a/src/demos/fullscreen/GearsFullscreen.java
+++ b/src/demos/fullscreen/GearsFullscreen.java
@@ -3,10 +3,10 @@ package demos.fullscreen;
import java.awt.*;
import java.awt.event.*;
-import javax.media.opengl.*;
-import com.sun.opengl.util.*;
import demos.gears.Gears;
import demos.util.*;
+import javax.media.opengl.awt.GLCanvas;
+import javax.media.opengl.util.Animator;
/**
* GearsFullscreen.java <BR>
diff --git a/src/demos/fullscreen/GearsFullscreen2.java b/src/demos/fullscreen/GearsFullscreen2.java
index eea7869..9b08cba 100755
--- a/src/demos/fullscreen/GearsFullscreen2.java
+++ b/src/demos/fullscreen/GearsFullscreen2.java
@@ -1,13 +1,21 @@
package demos.fullscreen;
-import java.awt.*;
-import java.awt.event.*;
-import javax.swing.*;
-
-import javax.media.opengl.*;
-import com.sun.opengl.util.*;
import demos.gears.Gears;
-import demos.util.*;
+import demos.util.ScreenResSelector;
+import java.awt.BorderLayout;
+import java.awt.DisplayMode;
+import java.awt.EventQueue;
+import java.awt.Frame;
+import java.awt.GraphicsDevice;
+import java.awt.GraphicsEnvironment;
+import java.awt.event.WindowAdapter;
+import java.awt.event.WindowEvent;
+import javax.media.opengl.awt.GLCanvas;
+import javax.media.opengl.util.Animator;
+import javax.swing.JButton;
+import javax.swing.JFrame;
+import javax.swing.ToolTipManager;
+
/**
* GearsFullscreen2.java <BR>
diff --git a/src/demos/fullscreen/JGearsFullscreen.java b/src/demos/fullscreen/JGearsFullscreen.java
index 465c566..d9d1134 100755
--- a/src/demos/fullscreen/JGearsFullscreen.java
+++ b/src/demos/fullscreen/JGearsFullscreen.java
@@ -1,13 +1,21 @@
package demos.fullscreen;
-import java.awt.*;
-import java.awt.event.*;
-import javax.swing.*;
-
-import javax.media.opengl.*;
-import com.sun.opengl.util.*;
import demos.jgears.JGears;
-import demos.util.*;
+import demos.util.ScreenResSelector;
+import java.awt.BorderLayout;
+import java.awt.DisplayMode;
+import java.awt.EventQueue;
+import java.awt.Frame;
+import java.awt.GraphicsDevice;
+import java.awt.GraphicsEnvironment;
+import java.awt.event.WindowAdapter;
+import java.awt.event.WindowEvent;
+import javax.media.opengl.awt.gl2.GL2JPanel;
+import javax.media.opengl.util.Animator;
+import javax.swing.JButton;
+import javax.swing.JFrame;
+
+
/**
* JGearsFullscreen.java <BR>
@@ -53,7 +61,7 @@ public class JGearsFullscreen {
if (newMode != null) {
frame.setUndecorated(true);
}
- GLJPanel drawable = new JGears();
+ JGears drawable = new JGears();
drawable.addGLEventListener(new FullscreenWorkaround(initWidth, initHeight));
frame.getContentPane().setLayout(new BorderLayout());
diff --git a/src/demos/gamma/TestGamma.java b/src/demos/gamma/TestGamma.java
index 17fb365..74a63a1 100755
--- a/src/demos/gamma/TestGamma.java
+++ b/src/demos/gamma/TestGamma.java
@@ -39,13 +39,15 @@
package demos.gamma;
-import java.awt.*;
-import java.awt.event.*;
+import demos.gears.Gears;
+import java.awt.Frame;
+import java.awt.event.WindowAdapter;
+import java.awt.event.WindowEvent;
+import javax.media.opengl.awt.GLCanvas;
+import javax.media.opengl.util.Animator;
+import javax.media.opengl.util.Gamma;
-import javax.media.opengl.*;
-import com.sun.opengl.util.*;
-import demos.gears.*;
public class TestGamma {
private static void usage() {
@@ -89,7 +91,7 @@ public class TestGamma {
}).start();
}
});
- frame.show();
+ frame.setVisible(true);
animator.start();
if (!Gamma.setDisplayGamma(gamma, brightness, contrast)) {
diff --git a/src/demos/gears/Gears.java b/src/demos/gears/Gears.java
index 4ae780e..c20d183 100644
--- a/src/demos/gears/Gears.java
+++ b/src/demos/gears/Gears.java
@@ -1,10 +1,19 @@
package demos.gears;
-import java.awt.*;
-import java.awt.event.*;
-
-import javax.media.opengl.*;
-import com.sun.opengl.util.*;
+import java.awt.Dimension;
+import java.awt.Frame;
+import java.awt.event.MouseEvent;
+import java.awt.event.MouseListener;
+import java.awt.event.MouseMotionListener;
+import java.awt.event.WindowAdapter;
+import java.awt.event.WindowEvent;
+import javax.media.opengl.GL;
+import javax.media.opengl.GL2;
+import javax.media.opengl.GLAutoDrawable;
+import javax.media.opengl.GLEventListener;
+import javax.media.opengl.awt.GLCanvas;
+import javax.media.opengl.awt.gl2.GL2JPanel;
+import javax.media.opengl.util.Animator;
/**
* Gears.java <BR>
@@ -18,7 +27,11 @@ public class Gears implements GLEventListener, MouseListener, MouseMotionListene
Frame frame = new Frame("Gear Demo");
GLCanvas canvas = new GLCanvas();
- canvas.addGLEventListener(new Gears());
+ final Gears gears = new Gears();
+ canvas.addMouseListener(gears);
+ canvas.addMouseMotionListener(gears);
+ canvas.addGLEventListener(gears);
+
frame.add(canvas);
frame.setSize(300, 300);
final Animator animator = new Animator(canvas);
@@ -35,7 +48,7 @@ public class Gears implements GLEventListener, MouseListener, MouseMotionListene
}).start();
}
});
- frame.show();
+ frame.setVisible(true);
animator.start();
}
@@ -50,7 +63,7 @@ public class Gears implements GLEventListener, MouseListener, MouseMotionListene
// Use debug pipeline
// drawable.setGL(new DebugGL(drawable.getGL()));
- GL gl = drawable.getGL();
+ GL2 gl = drawable.getGL().getGL2();
System.err.println("INIT GL IS: " + gl.getClass().getName());
@@ -63,50 +76,48 @@ public class Gears implements GLEventListener, MouseListener, MouseMotionListene
float green[] = { 0.0f, 0.8f, 0.2f, 1.0f };
float blue[] = { 0.2f, 0.2f, 1.0f, 1.0f };
- gl.glLightfv(GL.GL_LIGHT0, GL.GL_POSITION, pos, 0);
- gl.glEnable(GL.GL_CULL_FACE);
- gl.glEnable(GL.GL_LIGHTING);
- gl.glEnable(GL.GL_LIGHT0);
- gl.glEnable(GL.GL_DEPTH_TEST);
+ gl.glLightfv(GL2.GL_LIGHT0, GL2.GL_POSITION, pos, 0);
+ gl.glEnable(GL2.GL_CULL_FACE);
+ gl.glEnable(GL2.GL_LIGHTING);
+ gl.glEnable(GL2.GL_LIGHT0);
+ gl.glEnable(GL2.GL_DEPTH_TEST);
/* make the gears */
gear1 = gl.glGenLists(1);
- gl.glNewList(gear1, GL.GL_COMPILE);
- gl.glMaterialfv(GL.GL_FRONT, GL.GL_AMBIENT_AND_DIFFUSE, red, 0);
+ gl.glNewList(gear1, GL2.GL_COMPILE);
+ gl.glMaterialfv(GL2.GL_FRONT, GL2.GL_AMBIENT_AND_DIFFUSE, red, 0);
gear(gl, 1.0f, 4.0f, 1.0f, 20, 0.7f);
gl.glEndList();
gear2 = gl.glGenLists(1);
- gl.glNewList(gear2, GL.GL_COMPILE);
- gl.glMaterialfv(GL.GL_FRONT, GL.GL_AMBIENT_AND_DIFFUSE, green, 0);
+ gl.glNewList(gear2, GL2.GL_COMPILE);
+ gl.glMaterialfv(GL2.GL_FRONT, GL2.GL_AMBIENT_AND_DIFFUSE, green, 0);
gear(gl, 0.5f, 2.0f, 2.0f, 10, 0.7f);
gl.glEndList();
gear3 = gl.glGenLists(1);
- gl.glNewList(gear3, GL.GL_COMPILE);
- gl.glMaterialfv(GL.GL_FRONT, GL.GL_AMBIENT_AND_DIFFUSE, blue, 0);
+ gl.glNewList(gear3, GL2.GL_COMPILE);
+ gl.glMaterialfv(GL2.GL_FRONT, GL2.GL_AMBIENT_AND_DIFFUSE, blue, 0);
gear(gl, 1.3f, 2.0f, 0.5f, 10, 0.7f);
gl.glEndList();
- gl.glEnable(GL.GL_NORMALIZE);
+ gl.glEnable(GL2.GL_NORMALIZE);
- drawable.addMouseListener(this);
- drawable.addMouseMotionListener(this);
}
public void reshape(GLAutoDrawable drawable, int x, int y, int width, int height) {
- GL gl = drawable.getGL();
+ GL2 gl = drawable.getGL().getGL2();
float h = (float)height / (float)width;
- gl.glMatrixMode(GL.GL_PROJECTION);
+ gl.glMatrixMode(GL2.GL_PROJECTION);
- System.err.println("GL_VENDOR: " + gl.glGetString(GL.GL_VENDOR));
- System.err.println("GL_RENDERER: " + gl.glGetString(GL.GL_RENDERER));
- System.err.println("GL_VERSION: " + gl.glGetString(GL.GL_VERSION));
+ System.err.println("GL_VENDOR: " + gl.glGetString(GL2.GL_VENDOR));
+ System.err.println("GL_RENDERER: " + gl.glGetString(GL2.GL_RENDERER));
+ System.err.println("GL_VERSION: " + gl.glGetString(GL2.GL_VERSION));
gl.glLoadIdentity();
gl.glFrustum(-1.0f, 1.0f, -h, h, 5.0f, 60.0f);
- gl.glMatrixMode(GL.GL_MODELVIEW);
+ gl.glMatrixMode(GL2.GL_MODELVIEW);
gl.glLoadIdentity();
gl.glTranslatef(0.0f, 0.0f, -40.0f);
}
@@ -116,16 +127,16 @@ public class Gears implements GLEventListener, MouseListener, MouseMotionListene
angle += 2.0f;
// Get the GL corresponding to the drawable we are animating
- GL gl = drawable.getGL();
+ GL2 gl = drawable.getGL().getGL2();
// Special handling for the case where the GLJPanel is translucent
// and wants to be composited with other Java 2D content
- if ((drawable instanceof GLJPanel) &&
- !((GLJPanel) drawable).isOpaque() &&
- ((GLJPanel) drawable).shouldPreserveColorBufferIfTranslucent()) {
- gl.glClear(GL.GL_DEPTH_BUFFER_BIT);
+ if ((drawable instanceof GL2JPanel) &&
+ !((GL2JPanel) drawable).isOpaque() &&
+ ((GL2JPanel) drawable).shouldPreserveColorBufferIfTranslucent()) {
+ gl.glClear(GL2.GL_DEPTH_BUFFER_BIT);
} else {
- gl.glClear(GL.GL_COLOR_BUFFER_BIT | GL.GL_DEPTH_BUFFER_BIT);
+ gl.glClear(GL2.GL_COLOR_BUFFER_BIT | GL2.GL_DEPTH_BUFFER_BIT);
}
// Rotate the entire assembly of gears based on how the user
@@ -163,7 +174,7 @@ public class Gears implements GLEventListener, MouseListener, MouseMotionListene
public void displayChanged(GLAutoDrawable drawable, boolean modeChanged, boolean deviceChanged) {}
- public static void gear(GL gl,
+ public static void gear(GL2 gl,
float inner_radius,
float outer_radius,
float width,
@@ -181,12 +192,12 @@ public class Gears implements GLEventListener, MouseListener, MouseMotionListene
da = 2.0f * (float) Math.PI / teeth / 4.0f;
- gl.glShadeModel(GL.GL_FLAT);
+ gl.glShadeModel(GL2.GL_FLAT);
gl.glNormal3f(0.0f, 0.0f, 1.0f);
/* draw front face */
- gl.glBegin(GL.GL_QUAD_STRIP);
+ gl.glBegin(GL2.GL_QUAD_STRIP);
for (i = 0; i <= teeth; i++)
{
angle = i * 2.0f * (float) Math.PI / teeth;
@@ -201,7 +212,7 @@ public class Gears implements GLEventListener, MouseListener, MouseMotionListene
gl.glEnd();
/* draw front sides of teeth */
- gl.glBegin(GL.GL_QUADS);
+ gl.glBegin(GL2.GL_QUADS);
for (i = 0; i < teeth; i++)
{
angle = i * 2.0f * (float) Math.PI / teeth;
@@ -213,7 +224,7 @@ public class Gears implements GLEventListener, MouseListener, MouseMotionListene
gl.glEnd();
/* draw back face */
- gl.glBegin(GL.GL_QUAD_STRIP);
+ gl.glBegin(GL2.GL_QUAD_STRIP);
for (i = 0; i <= teeth; i++)
{
angle = i * 2.0f * (float) Math.PI / teeth;
@@ -225,7 +236,7 @@ public class Gears implements GLEventListener, MouseListener, MouseMotionListene
gl.glEnd();
/* draw back sides of teeth */
- gl.glBegin(GL.GL_QUADS);
+ gl.glBegin(GL2.GL_QUADS);
for (i = 0; i < teeth; i++)
{
angle = i * 2.0f * (float) Math.PI / teeth;
@@ -237,7 +248,7 @@ public class Gears implements GLEventListener, MouseListener, MouseMotionListene
gl.glEnd();
/* draw outward faces of teeth */
- gl.glBegin(GL.GL_QUAD_STRIP);
+ gl.glBegin(GL2.GL_QUAD_STRIP);
for (i = 0; i < teeth; i++)
{
angle = i * 2.0f * (float) Math.PI / teeth;
@@ -265,10 +276,10 @@ public class Gears implements GLEventListener, MouseListener, MouseMotionListene
gl.glVertex3f(r1 * (float)Math.cos(0), r1 * (float)Math.sin(0), -width * 0.5f);
gl.glEnd();
- gl.glShadeModel(GL.GL_SMOOTH);
+ gl.glShadeModel(GL2.GL_SMOOTH);
/* draw inside radius cylinder */
- gl.glBegin(GL.GL_QUAD_STRIP);
+ gl.glBegin(GL2.GL_QUAD_STRIP);
for (i = 0; i <= teeth; i++)
{
angle = i * 2.0f * (float) Math.PI / teeth;
diff --git a/src/demos/hdr/HDR.java b/src/demos/hdr/HDR.java
index 5bf64dd..4c6efc6 100755
--- a/src/demos/hdr/HDR.java
+++ b/src/demos/hdr/HDR.java
@@ -1,19 +1,45 @@
package demos.hdr;
-import java.awt.*;
-import java.awt.event.*;
-import java.io.*;
-import java.nio.*;
-import java.util.*;
-import javax.swing.*;
-
-import javax.media.opengl.*;
-import javax.media.opengl.glu.*;
-import com.sun.opengl.util.*;
-import demos.common.*;
-import demos.util.*;
-import gleem.*;
-import gleem.linalg.*;
+import com.sun.opengl.util.glut.gl2.GLUTgl2;
+import demos.common.Demo;
+import demos.common.DemoListener;
+import demos.util.DurationTimer;
+import demos.util.ObjReader;
+import demos.util.SystemTime;
+import demos.util.Time;
+import gleem.BSphere;
+import gleem.BSphereProvider;
+import gleem.CameraParameters;
+import gleem.ExaminerViewer;
+import gleem.ManipManager;
+import gleem.MouseButtonHelper;
+import gleem.linalg.Mat4f;
+import gleem.linalg.Rotf;
+import gleem.linalg.Vec3f;
+import java.awt.BorderLayout;
+import java.awt.Frame;
+import java.awt.event.KeyAdapter;
+import java.awt.event.KeyEvent;
+import java.awt.event.WindowAdapter;
+import java.awt.event.WindowEvent;
+import java.io.IOException;
+import java.io.InputStream;
+import java.nio.FloatBuffer;
+import java.nio.IntBuffer;
+import javax.media.opengl.GL;
+import javax.media.opengl.GL2;
+import javax.media.opengl.GLAutoDrawable;
+import javax.media.opengl.GLCapabilities;
+import javax.media.opengl.GLContext;
+import javax.media.opengl.GLDrawableFactory;
+import javax.media.opengl.GLEventListener;
+import javax.media.opengl.GLException;
+import javax.media.opengl.GLPbuffer;
+import javax.media.opengl.awt.GLCanvas;
+import javax.media.opengl.glu.GLU;
+import javax.media.opengl.util.Animator;
+import javax.swing.JOptionPane;
+
/** HDR demo by NVidia Corporation - Simon Green, [email protected] <P>
@@ -38,7 +64,7 @@ public class HDR extends Demo {
private ObjReader model;
private Pipeline pipeline;
- private GLUT glut = new GLUT();
+ private GLUTgl2 glut = new GLUTgl2();
private boolean[] b = new boolean[256];
@@ -124,7 +150,7 @@ public class HDR extends Demo {
frame.add(canvas, BorderLayout.CENTER);
frame.pack();
- frame.show();
+ frame.setVisible(true);
canvas.requestFocus();
frame.addWindowListener(new WindowAdapter() {
@@ -405,16 +431,16 @@ public class HDR extends Demo {
tonemap_pbuffer.display();
// display in window
- gl.glEnable(GL.GL_TEXTURE_RECTANGLE_NV);
- gl.glActiveTexture(GL.GL_TEXTURE0);
- gl.glBindTexture(GL.GL_TEXTURE_RECTANGLE_NV, tonemap_pbuffer_tex);
+ gl.glEnable(GL2.GL_TEXTURE_RECTANGLE);
+ gl.glActiveTexture(GL2.GL_TEXTURE0);
+ gl.glBindTexture(GL2.GL_TEXTURE_RECTANGLE, tonemap_pbuffer_tex);
if (b['n']) {
- gl.glTexParameteri( GL.GL_TEXTURE_RECTANGLE_NV, GL.GL_TEXTURE_MAG_FILTER, GL.GL_LINEAR);
+ gl.glTexParameteri( GL2.GL_TEXTURE_RECTANGLE, GL2.GL_TEXTURE_MAG_FILTER, GL2.GL_LINEAR);
} else {
- gl.glTexParameteri( GL.GL_TEXTURE_RECTANGLE_NV, GL.GL_TEXTURE_MAG_FILTER, GL.GL_NEAREST);
+ gl.glTexParameteri( GL2.GL_TEXTURE_RECTANGLE, GL2.GL_TEXTURE_MAG_FILTER, GL2.GL_NEAREST);
}
drawQuadRect4(gl, win_w, win_h, pbuffer_w, pbuffer_h);
- gl.glDisable(GL.GL_TEXTURE_RECTANGLE_NV);
+ gl.glDisable(GL2.GL_TEXTURE_RECTANGLE);
// Try to avoid swamping the CPU on Linux
Thread.yield();
@@ -498,13 +524,13 @@ public class HDR extends Demo {
gl.glGenTextures(1, tmp, 0);
int texid = tmp[0];
- int target = GL.GL_TEXTURE_1D;
+ int target = GL2.GL_TEXTURE_1D;
gl.glBindTexture(target, texid);
- gl.glTexParameteri(target, GL.GL_TEXTURE_MAG_FILTER, GL.GL_NEAREST);
- gl.glTexParameteri(target, GL.GL_TEXTURE_MIN_FILTER, GL.GL_NEAREST);
- gl.glTexParameteri(target, GL.GL_TEXTURE_WRAP_S, GL.GL_CLAMP_TO_EDGE);
+ gl.glTexParameteri(target, GL2.GL_TEXTURE_MAG_FILTER, GL2.GL_NEAREST);
+ gl.glTexParameteri(target, GL2.GL_TEXTURE_MIN_FILTER, GL2.GL_NEAREST);
+ gl.glTexParameteri(target, GL2.GL_TEXTURE_WRAP_S, GL2.GL_CLAMP_TO_EDGE);
- gl.glPixelStorei(GL.GL_UNPACK_ALIGNMENT, 1);
+ gl.glPixelStorei(GL2.GL_UNPACK_ALIGNMENT, 1);
float[] img = new float [size];
@@ -513,7 +539,7 @@ public class HDR extends Demo {
img[i] = (float) Math.pow(x, gamma);
}
- gl.glTexImage1D(target, 0, GL.GL_LUMINANCE, size, 0, GL.GL_LUMINANCE, GL.GL_FLOAT, FloatBuffer.wrap(img));
+ gl.glTexImage1D(target, 0, GL2.GL_LUMINANCE, size, 0, GL2.GL_LUMINANCE, GL2.GL_FLOAT, FloatBuffer.wrap(img));
return texid;
}
@@ -525,13 +551,13 @@ public class HDR extends Demo {
gl.glGenTextures(1, tmp, 0);
int texid = tmp[0];
- gl.glBindTexture(GL.GL_TEXTURE_RECTANGLE_NV, texid);
- gl.glTexParameteri(GL.GL_TEXTURE_RECTANGLE_NV, GL.GL_TEXTURE_MAG_FILTER, GL.GL_NEAREST);
- gl.glTexParameteri(GL.GL_TEXTURE_RECTANGLE_NV, GL.GL_TEXTURE_MIN_FILTER, GL.GL_NEAREST);
- gl.glTexParameteri(GL.GL_TEXTURE_RECTANGLE_NV, GL.GL_TEXTURE_WRAP_S, GL.GL_CLAMP_TO_EDGE);
- gl.glTexParameteri(GL.GL_TEXTURE_RECTANGLE_NV, GL.GL_TEXTURE_WRAP_T, GL.GL_CLAMP_TO_EDGE);
+ gl.glBindTexture(GL2.GL_TEXTURE_RECTANGLE_NV, texid);
+ gl.glTexParameteri(GL2.GL_TEXTURE_RECTANGLE_NV, GL2.GL_TEXTURE_MAG_FILTER, GL2.GL_NEAREST);
+ gl.glTexParameteri(GL2.GL_TEXTURE_RECTANGLE_NV, GL2.GL_TEXTURE_MIN_FILTER, GL2.GL_NEAREST);
+ gl.glTexParameteri(GL2.GL_TEXTURE_RECTANGLE_NV, GL2.GL_TEXTURE_WRAP_S, GL2.GL_CLAMP_TO_EDGE);
+ gl.glTexParameteri(GL2.GL_TEXTURE_RECTANGLE_NV, GL2.GL_TEXTURE_WRAP_T, GL2.GL_CLAMP_TO_EDGE);
- gl.glPixelStorei(GL.GL_UNPACK_ALIGNMENT, 1);
+ gl.glPixelStorei(GL2.GL_UNPACK_ALIGNMENT, 1);
float[] img = new float [xsiz*ysiz];
@@ -553,7 +579,7 @@ public class HDR extends Demo {
}
}
- gl.glTexImage2D(GL.GL_TEXTURE_RECTANGLE_NV, 0, GL.GL_LUMINANCE, xsiz, ysiz, 0, GL.GL_LUMINANCE, GL.GL_FLOAT, FloatBuffer.wrap(img));
+ gl.glTexImage2D(GL2.GL_TEXTURE_RECTANGLE_NV, 0, GL2.GL_LUMINANCE, xsiz, ysiz, 0, GL2.GL_LUMINANCE, GL2.GL_FLOAT, FloatBuffer.wrap(img));
return texid;
}
@@ -569,7 +595,7 @@ public class HDR extends Demo {
// drawable.setGL(new DebugGL(drawable.getGL()));
GL gl = drawable.getGL();
- gl.glEnable(GL.GL_DEPTH_TEST);
+ gl.glEnable(GL2.GL_DEPTH_TEST);
// FIXME: what about the ExaminerViewer?
setPerspectiveProjection(gl, pbuffer_w, pbuffer_h);
@@ -582,18 +608,18 @@ public class HDR extends Demo {
System.err.println("Creating HILO cubemap");
hdr_tex = hdr.createCubemapHILO(gl, true);
hdr_tex2 = hdr.createCubemapHILO(gl, false);
- texmode = GL.GL_FLOAT_RGBA16_NV;
+ texmode = GL2.GL_FLOAT_RGBA16_NV;
hilo = true;
break;
case GLPbuffer.APPLE_FLOAT:
System.err.println("Creating FLOAT16_APPLE cubemap");
- hdr_tex = hdr.createCubemap(gl, GL.GL_RGB_FLOAT16_APPLE);
- texmode = GL.GL_RGBA_FLOAT16_APPLE;
+ hdr_tex = hdr.createCubemap(gl, GL2.GL_RGB_FLOAT16_APPLE);
+ texmode = GL2.GL_RGBA_FLOAT16_APPLE;
break;
case GLPbuffer.ATI_FLOAT:
System.err.println("Creating FLOAT16_ATI cubemap");
- hdr_tex = hdr.createCubemap(gl, GL.GL_RGB_FLOAT16_ATI);
- texmode = GL.GL_RGBA_FLOAT16_ATI;
+ hdr_tex = hdr.createCubemap(gl, GL2.GL_RGB_FLOAT16_ATI);
+ texmode = GL2.GL_RGBA_FLOAT16_ATI;
break;
default:
throw new RuntimeException("Unexpected floating-point mode " + fpmode);
@@ -630,42 +656,42 @@ public class HDR extends Demo {
// render scene to float pbuffer
private void renderScene(GL gl) {
- gl.glClear(GL.GL_COLOR_BUFFER_BIT | GL.GL_DEPTH_BUFFER_BIT);
+ gl.glClear(GL2.GL_COLOR_BUFFER_BIT | GL2.GL_DEPTH_BUFFER_BIT);
if (doViewAll) {
viewer.viewAll(gl);
}
if (b['w'])
- gl.glPolygonMode(GL.GL_FRONT_AND_BACK, GL.GL_LINE);
+ gl.glPolygonMode(GL2.GL_FRONT_AND_BACK, GL2.GL_LINE);
else
- gl.glPolygonMode(GL.GL_FRONT_AND_BACK, GL.GL_FILL);
+ gl.glPolygonMode(GL2.GL_FRONT_AND_BACK, GL2.GL_FILL);
if (b['m']) {
- gl.glEnable(GL.GL_MULTISAMPLE);
- gl.glHint(GL.GL_MULTISAMPLE_FILTER_HINT_NV, GL.GL_NICEST);
+ gl.glEnable(GL2.GL_MULTISAMPLE);
+ gl.glHint(GL2.GL_MULTISAMPLE_FILTER_HINT_NV, GL2.GL_NICEST);
} else {
- gl.glDisable(GL.GL_MULTISAMPLE);
+ gl.glDisable(GL2.GL_MULTISAMPLE);
}
if (!b['e']) {
// draw background
pipeline.enableFragmentProgram(gl, skybox_fprog);
- gl.glDisable(GL.GL_DEPTH_TEST);
+ gl.glDisable(GL2.GL_DEPTH_TEST);
drawSkyBox(gl);
- gl.glEnable(GL.GL_DEPTH_TEST);
+ gl.glEnable(GL2.GL_DEPTH_TEST);
}
// draw object
pipeline.enableVertexProgram(gl, object_vprog);
pipeline.enableFragmentProgram(gl, object_fprog);
- gl.glMatrixMode(GL.GL_TEXTURE);
+ gl.glMatrixMode(GL2.GL_TEXTURE);
gl.glLoadIdentity();
viewer.update();
viewer.updateInverseRotation(gl);
- gl.glMatrixMode( GL.GL_MODELVIEW );
+ gl.glMatrixMode( GL2.GL_MODELVIEW );
gl.glLoadIdentity();
CameraParameters params = viewer.getCameraParameters();
Mat4f view = params.getModelviewMatrix();
@@ -684,36 +710,36 @@ public class HDR extends Demo {
view.xformPt(eyePos_eye, eyePos_model);
pipeline.setVertexProgramParameter3f(gl, eyePos_param, eyePos_model.x(), eyePos_model.y(), eyePos_model.z());
- gl.glActiveTexture(GL.GL_TEXTURE0);
- gl.glBindTexture(GL.GL_TEXTURE_CUBE_MAP, hdr_tex);
- gl.glEnable(GL.GL_TEXTURE_CUBE_MAP);
+ gl.glActiveTexture(GL2.GL_TEXTURE0);
+ gl.glBindTexture(GL2.GL_TEXTURE_CUBE_MAP, hdr_tex);
+ gl.glEnable(GL2.GL_TEXTURE_CUBE_MAP);
boolean linear = b['l'];
if (linear) {
- gl.glTexParameteri(GL.GL_TEXTURE_CUBE_MAP, GL.GL_TEXTURE_MIN_FILTER, GL.GL_LINEAR_MIPMAP_LINEAR);
- gl.glTexParameteri( GL.GL_TEXTURE_CUBE_MAP, GL.GL_TEXTURE_MAG_FILTER, GL.GL_LINEAR);
+ gl.glTexParameteri(GL2.GL_TEXTURE_CUBE_MAP, GL2.GL_TEXTURE_MIN_FILTER, GL2.GL_LINEAR_MIPMAP_LINEAR);
+ gl.glTexParameteri( GL2.GL_TEXTURE_CUBE_MAP, GL2.GL_TEXTURE_MAG_FILTER, GL2.GL_LINEAR);
} else {
- // glTexParameteri( GL.GL_TEXTURE_CUBE_MAP, GL.GL_TEXTURE_MIN_FILTER, GL.GL_NEAREST_MIPMAP_NEAREST);
- gl.glTexParameteri( GL.GL_TEXTURE_CUBE_MAP, GL.GL_TEXTURE_MIN_FILTER, GL.GL_NEAREST);
- gl.glTexParameteri( GL.GL_TEXTURE_CUBE_MAP, GL.GL_TEXTURE_MAG_FILTER, GL.GL_NEAREST);
+ // glTexParameteri( GL2.GL_TEXTURE_CUBE_MAP, GL2.GL_TEXTURE_MIN_FILTER, GL2.GL_NEAREST_MIPMAP_NEAREST);
+ gl.glTexParameteri( GL2.GL_TEXTURE_CUBE_MAP, GL2.GL_TEXTURE_MIN_FILTER, GL2.GL_NEAREST);
+ gl.glTexParameteri( GL2.GL_TEXTURE_CUBE_MAP, GL2.GL_TEXTURE_MAG_FILTER, GL2.GL_NEAREST);
}
if (hilo) {
- gl.glActiveTexture(GL.GL_TEXTURE1);
- gl.glBindTexture(GL.GL_TEXTURE_CUBE_MAP, hdr_tex2);
- gl.glEnable(GL.GL_TEXTURE_CUBE_MAP);
+ gl.glActiveTexture(GL2.GL_TEXTURE1);
+ gl.glBindTexture(GL2.GL_TEXTURE_CUBE_MAP, hdr_tex2);
+ gl.glEnable(GL2.GL_TEXTURE_CUBE_MAP);
if (linear) {
- gl.glTexParameteri( GL.GL_TEXTURE_CUBE_MAP, GL.GL_TEXTURE_MIN_FILTER, GL.GL_LINEAR_MIPMAP_LINEAR);
- gl.glTexParameteri( GL.GL_TEXTURE_CUBE_MAP, GL.GL_TEXTURE_MAG_FILTER, GL.GL_LINEAR);
+ gl.glTexParameteri( GL2.GL_TEXTURE_CUBE_MAP, GL2.GL_TEXTURE_MIN_FILTER, GL2.GL_LINEAR_MIPMAP_LINEAR);
+ gl.glTexParameteri( GL2.GL_TEXTURE_CUBE_MAP, GL2.GL_TEXTURE_MAG_FILTER, GL2.GL_LINEAR);
} else {
- // glTexParameteri( GL.GL_TEXTURE_CUBE_MAP, GL.GL_TEXTURE_MIN_FILTER, GL.GL_NEAREST_MIPMAP_NEAREST);
- gl.glTexParameteri( GL.GL_TEXTURE_CUBE_MAP, GL.GL_TEXTURE_MIN_FILTER, GL.GL_NEAREST);
- gl.glTexParameteri( GL.GL_TEXTURE_CUBE_MAP, GL.GL_TEXTURE_MAG_FILTER, GL.GL_NEAREST);
+ // glTexParameteri( GL2.GL_TEXTURE_CUBE_MAP, GL2.GL_TEXTURE_MIN_FILTER, GL2.GL_NEAREST_MIPMAP_NEAREST);
+ gl.glTexParameteri( GL2.GL_TEXTURE_CUBE_MAP, GL2.GL_TEXTURE_MIN_FILTER, GL2.GL_NEAREST);
+ gl.glTexParameteri( GL2.GL_TEXTURE_CUBE_MAP, GL2.GL_TEXTURE_MAG_FILTER, GL2.GL_NEAREST);
}
}
- gl.glEnable(GL.GL_CULL_FACE);
+ gl.glEnable(GL2.GL_CULL_FACE);
switch(modelno) {
case 0:
@@ -733,21 +759,21 @@ public class HDR extends Demo {
// glut.glutSolidTeapot(gl, 1.0f);
break;
case 5:
- gl.glEnableClientState(GL.GL_VERTEX_ARRAY);
- gl.glEnableClientState(GL.GL_NORMAL_ARRAY);
- gl.glVertexPointer(3, GL.GL_FLOAT, 0, model.getVertices());
- gl.glNormalPointer(GL.GL_FLOAT, 0, model.getVertexNormals());
+ gl.glEnableClientState(GL2.GL_VERTEX_ARRAY);
+ gl.glEnableClientState(GL2.GL_NORMAL_ARRAY);
+ gl.glVertexPointer(3, GL2.GL_FLOAT, 0, model.getVertices());
+ gl.glNormalPointer(GL2.GL_FLOAT, 0, model.getVertexNormals());
int[] indices = model.getFaceIndices();
- gl.glDrawElements(GL.GL_TRIANGLES, indices.length, GL.GL_UNSIGNED_INT, IntBuffer.wrap(indices));
- gl.glDisableClientState(GL.GL_VERTEX_ARRAY);
- gl.glDisableClientState(GL.GL_NORMAL_ARRAY);
+ gl.glDrawElements(GL2.GL_TRIANGLES, indices.length, GL2.GL_UNSIGNED_INT, IntBuffer.wrap(indices));
+ gl.glDisableClientState(GL2.GL_VERTEX_ARRAY);
+ gl.glDisableClientState(GL2.GL_NORMAL_ARRAY);
break;
}
- gl.glDisable(GL.GL_CULL_FACE);
+ gl.glDisable(GL2.GL_CULL_FACE);
pipeline.disableVertexProgram(gl);
pipeline.disableFragmentProgram(gl);
- gl.glPolygonMode(GL.GL_FRONT_AND_BACK, GL.GL_FILL);
+ gl.glPolygonMode(GL2.GL_FRONT_AND_BACK, GL2.GL_FILL);
}
}
@@ -771,8 +797,8 @@ public class HDR extends Demo {
GL gl = drawable.getGL();
// horizontal blur
- gl.glBindProgramARB(GL.GL_FRAGMENT_PROGRAM_ARB, blurh_fprog);
- gl.glActiveTexture(GL.GL_TEXTURE0);
+ gl.glBindProgramARB(GL2.GL_FRAGMENT_PROGRAM_ARB, blurh_fprog);
+ gl.glActiveTexture(GL2.GL_TEXTURE0);
pipeline.bindTexture(gl, blur2_pbuffer_tex);
glowPass(gl);
@@ -803,20 +829,20 @@ public class HDR extends Demo {
GL gl = drawable.getGL();
if (blur2Pass == BLUR2_SHRINK_PASS) {
- gl.glClear(GL.GL_COLOR_BUFFER_BIT);
+ gl.glClear(GL2.GL_COLOR_BUFFER_BIT);
pipeline.enableFragmentProgram(gl, shrink_fprog);
setOrthoProjection(gl, 0, 0, blur_w, blur_h);
- gl.glActiveTexture(GL.GL_TEXTURE0);
- gl.glBindTexture(GL.GL_TEXTURE_RECTANGLE_NV, pbuffer_tex);
+ gl.glActiveTexture(GL2.GL_TEXTURE0);
+ gl.glBindTexture(GL2.GL_TEXTURE_RECTANGLE_NV, pbuffer_tex);
drawQuadRect2(gl, blur_w, blur_h, pbuffer_w, pbuffer_h);
pipeline.disableFragmentProgram(gl);
} else if (blur2Pass == BLUR2_VERT_BLUR_PASS) {
// vertical blur
- gl.glBindProgramARB(GL.GL_FRAGMENT_PROGRAM_ARB, blurv_fprog);
- gl.glActiveTexture(GL.GL_TEXTURE0);
+ gl.glBindProgramARB(GL2.GL_FRAGMENT_PROGRAM_ARB, blurv_fprog);
+ gl.glActiveTexture(GL2.GL_TEXTURE0);
pipeline.bindTexture(gl, blur_pbuffer_tex);
glowPass(gl);
@@ -859,48 +885,48 @@ public class HDR extends Demo {
//
private void setOrthoProjection(GL gl, int x, int y, int w, int h) {
- gl.glMatrixMode(GL.GL_PROJECTION);
+ gl.glMatrixMode(GL2.GL_PROJECTION);
gl.glLoadIdentity();
gl.glOrtho(0, w, 0, h, -1.0, 1.0);
- gl.glMatrixMode(GL.GL_TEXTURE);
+ gl.glMatrixMode(GL2.GL_TEXTURE);
gl.glLoadIdentity();
- gl.glMatrixMode(GL.GL_MODELVIEW);
+ gl.glMatrixMode(GL2.GL_MODELVIEW);
gl.glLoadIdentity();
gl.glViewport(x, y, w, h);
}
private void setPerspectiveProjection(GL gl, int w, int h) {
// FIXME: what about ExaminerViewer?
- gl.glMatrixMode(GL.GL_PROJECTION);
+ gl.glMatrixMode(GL2.GL_PROJECTION);
gl.glLoadIdentity();
glu.gluPerspective(60.0, (float) w / (float) h, 0.1, 10.0);
- gl.glMatrixMode(GL.GL_MODELVIEW);
+ gl.glMatrixMode(GL2.GL_MODELVIEW);
gl.glLoadIdentity();
gl.glViewport(0, 0, w, h);
}
// blur floating point image
private void glowPass(GL gl) {
- gl.glDisable(GL.GL_DEPTH_TEST);
- gl.glEnable(GL.GL_FRAGMENT_PROGRAM_ARB);
+ gl.glDisable(GL2.GL_DEPTH_TEST);
+ gl.glEnable(GL2.GL_FRAGMENT_PROGRAM_ARB);
setOrthoProjection(gl, 0, 0, blur_w, blur_h);
drawQuadRect(gl, blur_w, blur_h);
- gl.glDisable(GL.GL_FRAGMENT_PROGRAM_ARB);
+ gl.glDisable(GL2.GL_FRAGMENT_PROGRAM_ARB);
}
private void drawQuadRect(GL gl, int w, int h) {
- gl.glBegin(GL.GL_QUADS);
- gl.glTexCoord2f(0, h); gl.glMultiTexCoord2f(GL.GL_TEXTURE1, 0, h / blur_scale); gl.glVertex3f(0, h, 0);
- gl.glTexCoord2f(w, h); gl.glMultiTexCoord2f(GL.GL_TEXTURE1, w / blur_scale, h / blur_scale); gl.glVertex3f(w, h, 0);
- gl.glTexCoord2f(w, 0); gl.glMultiTexCoord2f(GL.GL_TEXTURE1, w / blur_scale, 0); gl.glVertex3f(w, 0, 0);
- gl.glTexCoord2f(0, 0); gl.glMultiTexCoord2f(GL.GL_TEXTURE1, 0, 0); gl.glVertex3f(0, 0, 0);
+ gl.glBegin(GL2.GL_QUADS);
+ gl.glTexCoord2f(0, h); gl.glMultiTexCoord2f(GL2.GL_TEXTURE1, 0, h / blur_scale); gl.glVertex3f(0, h, 0);
+ gl.glTexCoord2f(w, h); gl.glMultiTexCoord2f(GL2.GL_TEXTURE1, w / blur_scale, h / blur_scale); gl.glVertex3f(w, h, 0);
+ gl.glTexCoord2f(w, 0); gl.glMultiTexCoord2f(GL2.GL_TEXTURE1, w / blur_scale, 0); gl.glVertex3f(w, 0, 0);
+ gl.glTexCoord2f(0, 0); gl.glMultiTexCoord2f(GL2.GL_TEXTURE1, 0, 0); gl.glVertex3f(0, 0, 0);
gl.glEnd();
}
private void drawQuadRect2(GL gl, int w, int h, int tw, int th) {
- gl.glBegin(GL.GL_QUADS);
+ gl.glBegin(GL2.GL_QUADS);
gl.glTexCoord2f(0, th); gl.glVertex3f(0, h, 0);
gl.glTexCoord2f(tw, th); gl.glVertex3f(w, h, 0);
gl.glTexCoord2f(tw, 0); gl.glVertex3f(w, 0, 0);
@@ -910,7 +936,7 @@ public class HDR extends Demo {
private void drawQuadRect4(GL gl, int w, int h, int tw, int th) {
float offset = 0.5f;
- gl.glBegin(GL.GL_QUADS);
+ gl.glBegin(GL2.GL_QUADS);
gl.glTexCoord2f(offset, th - offset); gl.glVertex3f(0, h, 0);
gl.glTexCoord2f(tw - offset, th - offset); gl.glVertex3f(w, h, 0);
gl.glTexCoord2f(tw - offset, offset); gl.glVertex3f(w, 0, 0);
@@ -919,65 +945,65 @@ public class HDR extends Demo {
}
private void disableTexGen(GL gl) {
- gl.glDisable(GL.GL_TEXTURE_GEN_S);
- gl.glDisable(GL.GL_TEXTURE_GEN_T);
- gl.glDisable(GL.GL_TEXTURE_GEN_R);
+ gl.glDisable(GL2.GL_TEXTURE_GEN_S);
+ gl.glDisable(GL2.GL_TEXTURE_GEN_T);
+ gl.glDisable(GL2.GL_TEXTURE_GEN_R);
}
private void enableTexGen(GL gl) {
- gl.glEnable(GL.GL_TEXTURE_GEN_S);
- gl.glEnable(GL.GL_TEXTURE_GEN_T);
- gl.glEnable(GL.GL_TEXTURE_GEN_R);
+ gl.glEnable(GL2.GL_TEXTURE_GEN_S);
+ gl.glEnable(GL2.GL_TEXTURE_GEN_T);
+ gl.glEnable(GL2.GL_TEXTURE_GEN_R);
}
// draw cubemap background
private void drawSkyBox(GL gl) {
- gl.glActiveTexture(GL.GL_TEXTURE0);
- gl.glBindTexture(GL.GL_TEXTURE_CUBE_MAP, hdr_tex);
- gl.glEnable(GL.GL_TEXTURE_CUBE_MAP);
+ gl.glActiveTexture(GL2.GL_TEXTURE0);
+ gl.glBindTexture(GL2.GL_TEXTURE_CUBE_MAP, hdr_tex);
+ gl.glEnable(GL2.GL_TEXTURE_CUBE_MAP);
if (hilo) {
- gl.glActiveTexture(GL.GL_TEXTURE1);
- gl.glBindTexture(GL.GL_TEXTURE_CUBE_MAP, hdr_tex2);
- gl.glEnable(GL.GL_TEXTURE_CUBE_MAP);
+ gl.glActiveTexture(GL2.GL_TEXTURE1);
+ gl.glBindTexture(GL2.GL_TEXTURE_CUBE_MAP, hdr_tex2);
+ gl.glEnable(GL2.GL_TEXTURE_CUBE_MAP);
}
// initialize object linear texgen
- gl.glActiveTexture(GL.GL_TEXTURE0);
- gl.glMatrixMode(GL.GL_MODELVIEW);
+ gl.glActiveTexture(GL2.GL_TEXTURE0);
+ gl.glMatrixMode(GL2.GL_MODELVIEW);
gl.glPushMatrix();
gl.glLoadIdentity();
float[] s_plane = { 1.0f, 0.0f, 0.0f, 0.0f };
float[] t_plane = { 0.0f, 1.0f, 0.0f, 0.0f };
float[] r_plane = { 0.0f, 0.0f, 1.0f, 0.0f };
- gl.glTexGenfv(GL.GL_S, GL.GL_OBJECT_PLANE, s_plane, 0);
- gl.glTexGenfv(GL.GL_T, GL.GL_OBJECT_PLANE, t_plane, 0);
- gl.glTexGenfv(GL.GL_R, GL.GL_OBJECT_PLANE, r_plane, 0);
+ gl.glTexGenfv(GL2.GL_S, GL2.GL_OBJECT_PLANE, s_plane, 0);
+ gl.glTexGenfv(GL2.GL_T, GL2.GL_OBJECT_PLANE, t_plane, 0);
+ gl.glTexGenfv(GL2.GL_R, GL2.GL_OBJECT_PLANE, r_plane, 0);
gl.glPopMatrix();
- gl.glTexGeni(GL.GL_S, GL.GL_TEXTURE_GEN_MODE, GL.GL_OBJECT_LINEAR);
- gl.glTexGeni(GL.GL_T, GL.GL_TEXTURE_GEN_MODE, GL.GL_OBJECT_LINEAR);
- gl.glTexGeni(GL.GL_R, GL.GL_TEXTURE_GEN_MODE, GL.GL_OBJECT_LINEAR);
+ gl.glTexGeni(GL2.GL_S, GL2.GL_TEXTURE_GEN_MODE, GL2.GL_OBJECT_LINEAR);
+ gl.glTexGeni(GL2.GL_T, GL2.GL_TEXTURE_GEN_MODE, GL2.GL_OBJECT_LINEAR);
+ gl.glTexGeni(GL2.GL_R, GL2.GL_TEXTURE_GEN_MODE, GL2.GL_OBJECT_LINEAR);
enableTexGen(gl);
- gl.glTexEnvi(GL.GL_TEXTURE_ENV, GL.GL_TEXTURE_ENV_MODE, GL.GL_REPLACE);
+ gl.glTexEnvi(GL2.GL_TEXTURE_ENV, GL2.GL_TEXTURE_ENV_MODE, GL2.GL_REPLACE);
- gl.glMatrixMode(GL.GL_TEXTURE);
+ gl.glMatrixMode(GL2.GL_TEXTURE);
gl.glPushMatrix();
gl.glLoadIdentity();
viewer.updateInverseRotation(gl);
- gl.glMatrixMode(GL.GL_MODELVIEW);
+ gl.glMatrixMode(GL2.GL_MODELVIEW);
gl.glPushMatrix();
gl.glLoadIdentity();
gl.glScalef(10.0f, 10.0f, 10.0f);
glut.glutSolidCube(1.0f);
gl.glPopMatrix();
- gl.glDisable(GL.GL_TEXTURE_CUBE_MAP);
+ gl.glDisable(GL2.GL_TEXTURE_CUBE_MAP);
- gl.glMatrixMode(GL.GL_TEXTURE);
+ gl.glMatrixMode(GL2.GL_TEXTURE);
gl.glPopMatrix();
- gl.glMatrixMode(GL.GL_MODELVIEW);
+ gl.glMatrixMode(GL2.GL_MODELVIEW);
disableTexGen(gl);
}
@@ -986,18 +1012,18 @@ public class HDR extends Demo {
private void toneMappingPass(GL gl) {
gl.glFinish();
- gl.glActiveTexture(GL.GL_TEXTURE0);
- gl.glBindTexture(GL.GL_TEXTURE_RECTANGLE_NV, pbuffer_tex);
+ gl.glActiveTexture(GL2.GL_TEXTURE0);
+ gl.glBindTexture(GL2.GL_TEXTURE_RECTANGLE_NV, pbuffer_tex);
- gl.glActiveTexture(GL.GL_TEXTURE1);
+ gl.glActiveTexture(GL2.GL_TEXTURE1);
if (blur2_pbuffer != null) {
- gl.glBindTexture(GL.GL_TEXTURE_RECTANGLE_NV, blur2_pbuffer_tex);
+ gl.glBindTexture(GL2.GL_TEXTURE_RECTANGLE_NV, blur2_pbuffer_tex);
}
- gl.glActiveTexture(GL.GL_TEXTURE2);
- gl.glBindTexture(GL.GL_TEXTURE_1D, gamma_tex);
+ gl.glActiveTexture(GL2.GL_TEXTURE2);
+ gl.glBindTexture(GL2.GL_TEXTURE_1D, gamma_tex);
- gl.glActiveTexture(GL.GL_TEXTURE3);
+ gl.glActiveTexture(GL2.GL_TEXTURE3);
pipeline.bindTexture(gl, vignette_tex);
pipeline.enableFragmentProgram(gl, tonemap_fprog);
@@ -1087,11 +1113,11 @@ public class HDR extends Demo {
private void initBlurCode(GL gl, int blurWidth) {
// generate blur code
String blurCode = generateBlurCodeFP2(blurWidth, false);
- blurh_fprog = loadProgram(gl, GL.GL_FRAGMENT_PROGRAM_ARB, blurCode);
+ blurh_fprog = loadProgram(gl, GL2.GL_FRAGMENT_PROGRAM_ARB, blurCode);
// printf("%s\n", blurCode);
blurCode = generateBlurCodeFP2(blurWidth, true);
- blurv_fprog = loadProgram(gl, GL.GL_FRAGMENT_PROGRAM_ARB, blurCode);
+ blurv_fprog = loadProgram(gl, GL2.GL_FRAGMENT_PROGRAM_ARB, blurCode);
// printf("%s\n", blurCode);
}
@@ -1102,18 +1128,18 @@ public class HDR extends Demo {
prog_id = tmp[0];
gl.glBindProgramARB(target, prog_id);
int size = code.length();
- gl.glProgramStringARB(target, GL.GL_PROGRAM_FORMAT_ASCII_ARB, code.length(), code);
+ gl.glProgramStringARB(target, GL2.GL_PROGRAM_FORMAT_ASCII_ARB, code.length(), code);
int[] errPos = new int[1];
- gl.glGetIntegerv(GL.GL_PROGRAM_ERROR_POSITION_ARB, errPos, 0);
+ gl.glGetIntegerv(GL2.GL_PROGRAM_ERROR_POSITION_ARB, errPos, 0);
if (errPos[0] >= 0) {
String kind = "Program";
- if (target == GL.GL_VERTEX_PROGRAM_ARB) {
+ if (target == GL2.GL_VERTEX_PROGRAM_ARB) {
kind = "Vertex program";
- } else if (target == GL.GL_FRAGMENT_PROGRAM_ARB) {
+ } else if (target == GL2.GL_FRAGMENT_PROGRAM_ARB) {
kind = "Fragment program";
}
System.out.println(kind + " failed to load:");
- String errMsg = gl.glGetString(GL.GL_PROGRAM_ERROR_STRING_ARB);
+ String errMsg = gl.glGetString(GL2.GL_PROGRAM_ERROR_STRING_ARB);
if (errMsg == null) {
System.out.println("[No error message available]");
} else {
@@ -1127,10 +1153,10 @@ public class HDR extends Demo {
System.out.println(code.substring(errPos[0], endPos));
throw new GLException("Error loading " + kind);
} else {
- if (target == GL.GL_FRAGMENT_PROGRAM_ARB) {
+ if (target == GL2.GL_FRAGMENT_PROGRAM_ARB) {
int[] isNative = new int[1];
- gl.glGetProgramivARB(GL.GL_FRAGMENT_PROGRAM_ARB,
- GL.GL_PROGRAM_UNDER_NATIVE_LIMITS_ARB,
+ gl.glGetProgramivARB(GL2.GL_FRAGMENT_PROGRAM_ARB,
+ GL2.GL_PROGRAM_UNDER_NATIVE_LIMITS_ARB,
isNative, 0);
if (isNative[0] != 1) {
System.out.println("WARNING: fragment program is over native resource limits");
diff --git a/src/demos/hwShadowmapsSimple/HWShadowmapsSimple.java b/src/demos/hwShadowmapsSimple/HWShadowmapsSimple.java
index 50ff3e4..fddef16 100644
--- a/src/demos/hwShadowmapsSimple/HWShadowmapsSimple.java
+++ b/src/demos/hwShadowmapsSimple/HWShadowmapsSimple.java
@@ -33,23 +33,41 @@
package demos.hwShadowmapsSimple;
-import java.awt.*;
-import java.awt.event.*;
-import java.awt.image.*;
-import java.io.*;
-import java.nio.*;
-import java.util.*;
-import javax.imageio.*;
-import javax.swing.*;
-
-import javax.media.opengl.*;
-import javax.media.opengl.glu.*;
-import com.sun.opengl.util.*;
-import com.sun.opengl.util.texture.*;
-import demos.common.*;
-import demos.util.*;
-import gleem.*;
-import gleem.linalg.*;
+import com.sun.opengl.util.glut.gl2.GLUTgl2;
+import com.sun.opengl.util.texture.Texture;
+import com.sun.opengl.util.texture.TextureIO;
+import demos.common.Demo;
+import demos.common.DemoListener;
+import gleem.BSphere;
+import gleem.BSphereProvider;
+import gleem.CameraParameters;
+import gleem.ExaminerViewer;
+import gleem.HandleBoxManip;
+import gleem.ManipManager;
+import gleem.MouseButtonHelper;
+import gleem.linalg.Mat4f;
+import gleem.linalg.Rotf;
+import gleem.linalg.Vec3f;
+import java.awt.BorderLayout;
+import java.awt.Frame;
+import java.awt.event.KeyAdapter;
+import java.awt.event.KeyEvent;
+import java.awt.event.WindowAdapter;
+import java.awt.event.WindowEvent;
+import java.io.IOException;
+import java.util.ArrayList;
+import javax.media.opengl.GL;
+import javax.media.opengl.GL2;
+import javax.media.opengl.GLAutoDrawable;
+import javax.media.opengl.GLCapabilities;
+import javax.media.opengl.GLDrawableFactory;
+import javax.media.opengl.GLEventListener;
+import javax.media.opengl.GLException;
+import javax.media.opengl.GLPbuffer;
+import javax.media.opengl.awt.GLCanvas;
+import javax.media.opengl.glu.GLU;
+import javax.swing.JOptionPane;
+
/** This demo is a simple illustration of ARB_shadow and ARB_depth_texture. <P>
Cass Everitt <BR>
@@ -63,9 +81,16 @@ import gleem.linalg.*;
public class HWShadowmapsSimple extends Demo {
public static void main(String[] args) {
final GLCanvas canvas = new GLCanvas();
- HWShadowmapsSimple demo = new HWShadowmapsSimple();
+ final HWShadowmapsSimple demo = new HWShadowmapsSimple();
canvas.addGLEventListener(demo);
+ canvas.addKeyListener(new KeyAdapter() {
+ public void keyPressed(KeyEvent e) {
+ demo.dispatchKey(e.getKeyChar());
+ demo.demoListener.repaint();
+ }
+ });
+
demo.setDemoListener(new DemoListener() {
public void shutdownDemo() {
runExit();
@@ -80,7 +105,7 @@ public class HWShadowmapsSimple extends Demo {
canvas.setSize(512, 512);
frame.add(canvas, BorderLayout.CENTER);
frame.pack();
- frame.show();
+ frame.setVisible(true);
canvas.requestFocus();
frame.addWindowListener(new WindowAdapter() {
@@ -103,7 +128,7 @@ public class HWShadowmapsSimple extends Demo {
private GLPbuffer pbuffer;
private GLU glu;
- private GLUT glut;
+ private GLUTgl2 glut;
private float[] light_ambient = { 0, 0, 0, 0 };
private float[] light_intensity = { 1, 1, 1, 1 };
@@ -178,9 +203,9 @@ public class HWShadowmapsSimple extends Demo {
// Use debug pipeline
// drawable.setGL(new DebugGL(drawable.getGL()));
- GL gl = drawable.getGL();
+ GL2 gl = drawable.getGL().getGL2();
glu = new GLU();
- glut = new GLUT();
+ glut = new GLUTgl2();
try {
checkExtension(gl, "GL_VERSION_1_3"); // For multitexture
@@ -199,8 +224,8 @@ public class HWShadowmapsSimple extends Demo {
decal = TextureIO.newTexture(getClass().getClassLoader().getResourceAsStream("demos/data/images/decal_image.png"),
true,
TextureIO.PNG);
- decal.setTexParameteri(GL.GL_TEXTURE_WRAP_S, GL.GL_REPEAT);
- decal.setTexParameteri(GL.GL_TEXTURE_WRAP_T, GL.GL_REPEAT);
+ decal.setTexParameteri(GL2.GL_TEXTURE_WRAP_S, GL2.GL_REPEAT);
+ decal.setTexParameteri(GL2.GL_TEXTURE_WRAP_T, GL2.GL_REPEAT);
light_image = TextureIO.newTexture(getClass().getClassLoader().getResourceAsStream("demos/data/images/nvlogo_spot.png"),
true,
TextureIO.PNG);
@@ -209,11 +234,11 @@ public class HWShadowmapsSimple extends Demo {
}
quad = gl.glGenLists(1);
- gl.glNewList(quad, GL.GL_COMPILE);
+ gl.glNewList(quad, GL2.GL_COMPILE);
gl.glPushMatrix();
gl.glRotatef(-90, 1, 0, 0);
gl.glScalef(4,4,4);
- gl.glBegin(GL.GL_QUADS);
+ gl.glBegin(GL2.GL_QUADS);
gl.glNormal3f(0, 0, 1);
gl.glVertex2f(-1, -1);
gl.glVertex2f(-1, 1);
@@ -224,23 +249,23 @@ public class HWShadowmapsSimple extends Demo {
gl.glEndList();
wirecube = gl.glGenLists(1);
- gl.glNewList(wirecube, GL.GL_COMPILE);
+ gl.glNewList(wirecube, GL2.GL_COMPILE);
glut.glutWireCube(2);
gl.glEndList();
geometry = gl.glGenLists(1);
- gl.glNewList(geometry, GL.GL_COMPILE);
+ gl.glNewList(geometry, GL2.GL_COMPILE);
gl.glPushMatrix();
glut.glutSolidTeapot(0.8f);
gl.glPopMatrix();
gl.glEndList();
- gl.glEnable(GL.GL_LIGHT0);
- gl.glLightfv(GL.GL_LIGHT0, GL.GL_AMBIENT, light_ambient, 0);
- gl.glLightfv(GL.GL_LIGHT0, GL.GL_DIFFUSE, light_intensity, 0);
- gl.glLightfv(GL.GL_LIGHT0, GL.GL_SPECULAR, light_intensity, 0);
+ gl.glEnable(GL2.GL_LIGHT0);
+ gl.glLightfv(GL2.GL_LIGHT0, GL2.GL_AMBIENT, light_ambient, 0);
+ gl.glLightfv(GL2.GL_LIGHT0, GL2.GL_DIFFUSE, light_intensity, 0);
+ gl.glLightfv(GL2.GL_LIGHT0, GL2.GL_SPECULAR, light_intensity, 0);
- gl.glEnable(GL.GL_DEPTH_TEST);
+ gl.glEnable(GL2.GL_DEPTH_TEST);
// init pbuffer
GLCapabilities caps = new GLCapabilities();
@@ -293,12 +318,6 @@ public class HWShadowmapsSimple extends Demo {
tweaks.add(new Tweak("polygon offset scale", 2.5f, 0.5f));
tweaks.add(new Tweak("polygon offset bias", 10.0f, 1.0f));
- drawable.addKeyListener(new KeyAdapter() {
- public void keyPressed(KeyEvent e) {
- dispatchKey(e.getKeyChar());
- demoListener.repaint();
- }
- });
}
public void display(GLAutoDrawable drawable) {
@@ -330,17 +349,17 @@ public class HWShadowmapsSimple extends Demo {
return;
}
- GL gl = drawable.getGL();
+ GL2 gl = drawable.getGL().getGL2();
- gl.glClear(GL.GL_COLOR_BUFFER_BIT | GL.GL_DEPTH_BUFFER_BIT);
+ gl.glClear(GL2.GL_COLOR_BUFFER_BIT | GL2.GL_DEPTH_BUFFER_BIT);
if (doViewAll) {
viewer.viewAll(gl);
doViewAll = false;
// Immediately zap effects
- gl.glMatrixMode(GL.GL_PROJECTION);
+ gl.glMatrixMode(GL2.GL_PROJECTION);
gl.glLoadIdentity();
- gl.glMatrixMode(GL.GL_MODELVIEW);
+ gl.glMatrixMode(GL2.GL_MODELVIEW);
gl.glLoadIdentity();
// Schedule repaint to clean up first bogus frame
demoListener.repaint();
@@ -402,42 +421,42 @@ public class HWShadowmapsSimple extends Demo {
// Use debug pipeline
// drawable.setGL(new DebugGL(drawable.getGL()));
- GL gl = drawable.getGL();
+ GL2 gl = drawable.getGL().getGL2();
- gl.glEnable(GL.GL_DEPTH_TEST);
+ gl.glEnable(GL2.GL_DEPTH_TEST);
int[] depth_bits = new int[1];
- gl.glGetIntegerv(GL.GL_DEPTH_BITS, depth_bits, 0);
+ gl.glGetIntegerv(GL2.GL_DEPTH_BITS, depth_bits, 0);
- if (depth_bits[0] == 16) depth_format = GL.GL_DEPTH_COMPONENT16_ARB;
- else depth_format = GL.GL_DEPTH_COMPONENT24_ARB;
+ if (depth_bits[0] == 16) depth_format = GL2.GL_DEPTH_COMPONENT16_ARB;
+ else depth_format = GL2.GL_DEPTH_COMPONENT24_ARB;
light_view_depth = genTexture(gl);
- gl.glBindTexture(GL.GL_TEXTURE_2D, light_view_depth);
- gl.glTexImage2D(GL.GL_TEXTURE_2D, 0, depth_format, TEX_SIZE, TEX_SIZE, 0,
- GL.GL_DEPTH_COMPONENT, GL.GL_UNSIGNED_INT, null);
+ gl.glBindTexture(GL2.GL_TEXTURE_2D, light_view_depth);
+ gl.glTexImage2D(GL2.GL_TEXTURE_2D, 0, depth_format, TEX_SIZE, TEX_SIZE, 0,
+ GL2.GL_DEPTH_COMPONENT, GL2.GL_UNSIGNED_INT, null);
set_light_view_texture_parameters(gl);
fullyInitialized = true;
}
public void display(GLAutoDrawable drawable) {
- GL gl = drawable.getGL();
+ GL2 gl = drawable.getGL().getGL2();
- gl.glClear(GL.GL_COLOR_BUFFER_BIT | GL.GL_DEPTH_BUFFER_BIT);
+ gl.glClear(GL2.GL_COLOR_BUFFER_BIT | GL2.GL_DEPTH_BUFFER_BIT);
gl.glPolygonOffset(((Tweak) tweaks.get(POLYGON_OFFSET_SCALE)).val,
((Tweak) tweaks.get(POLYGON_OFFSET_BIAS)).val);
- gl.glEnable(GL.GL_POLYGON_OFFSET_FILL);
+ gl.glEnable(GL2.GL_POLYGON_OFFSET_FILL);
render_scene_from_light_view(gl, drawable, 0, 0);
- gl.glDisable(GL.GL_POLYGON_OFFSET_FILL);
+ gl.glDisable(GL2.GL_POLYGON_OFFSET_FILL);
- gl.glBindTexture(GL.GL_TEXTURE_2D, light_view_depth);
+ gl.glBindTexture(GL2.GL_TEXTURE_2D, light_view_depth);
// trying different ways of getting the depth info over
- gl.glCopyTexSubImage2D(GL.GL_TEXTURE_2D, 0, 0, 0, 0, 0, TEX_SIZE, TEX_SIZE);
+ gl.glCopyTexSubImage2D(GL2.GL_TEXTURE_2D, 0, 0, 0, 0, 0, TEX_SIZE, TEX_SIZE);
}
// Unused routines
@@ -446,13 +465,13 @@ public class HWShadowmapsSimple extends Demo {
}
private void set_light_view_texture_parameters(GL gl) {
- gl.glBindTexture(GL.GL_TEXTURE_2D, light_view_depth);
- gl.glTexParameteri(GL.GL_TEXTURE_2D, GL.GL_TEXTURE_MIN_FILTER, GL.GL_LINEAR);
- gl.glTexParameteri(GL.GL_TEXTURE_2D, GL.GL_TEXTURE_MAG_FILTER, GL.GL_LINEAR);
- gl.glTexParameteri(GL.GL_TEXTURE_2D, GL.GL_TEXTURE_WRAP_S, GL.GL_CLAMP_TO_EDGE);
- gl.glTexParameteri(GL.GL_TEXTURE_2D, GL.GL_TEXTURE_WRAP_T, GL.GL_CLAMP_TO_EDGE);
- gl.glTexParameteri(GL.GL_TEXTURE_2D, GL.GL_TEXTURE_COMPARE_MODE_ARB, GL.GL_COMPARE_R_TO_TEXTURE_ARB);
- gl.glTexParameteri(GL.GL_TEXTURE_2D, GL.GL_TEXTURE_COMPARE_FUNC_ARB, GL.GL_LEQUAL);
+ gl.glBindTexture(GL2.GL_TEXTURE_2D, light_view_depth);
+ gl.glTexParameteri(GL2.GL_TEXTURE_2D, GL2.GL_TEXTURE_MIN_FILTER, GL2.GL_LINEAR);
+ gl.glTexParameteri(GL2.GL_TEXTURE_2D, GL2.GL_TEXTURE_MAG_FILTER, GL2.GL_LINEAR);
+ gl.glTexParameteri(GL2.GL_TEXTURE_2D, GL2.GL_TEXTURE_WRAP_S, GL2.GL_CLAMP_TO_EDGE);
+ gl.glTexParameteri(GL2.GL_TEXTURE_2D, GL2.GL_TEXTURE_WRAP_T, GL2.GL_CLAMP_TO_EDGE);
+ gl.glTexParameteri(GL2.GL_TEXTURE_2D, GL2.GL_TEXTURE_COMPARE_MODE, GL2.GL_COMPARE_R_TO_TEXTURE);
+ gl.glTexParameteri(GL2.GL_TEXTURE_2D, GL2.GL_TEXTURE_COMPARE_FUNC, GL2.GL_LEQUAL);
}
private int genTexture(GL gl) {
@@ -461,30 +480,30 @@ public class HWShadowmapsSimple extends Demo {
return tmp[0];
}
- private void eye_linear_texgen(GL gl) {
+ private void eye_linear_texgen(GL2 gl) {
Mat4f m = new Mat4f();
m.makeIdent();
- set_texgen_planes(gl, GL.GL_EYE_PLANE, m);
- gl.glTexGeni(GL.GL_S, GL.GL_TEXTURE_GEN_MODE, GL.GL_EYE_LINEAR);
- gl.glTexGeni(GL.GL_T, GL.GL_TEXTURE_GEN_MODE, GL.GL_EYE_LINEAR);
- gl.glTexGeni(GL.GL_R, GL.GL_TEXTURE_GEN_MODE, GL.GL_EYE_LINEAR);
- gl.glTexGeni(GL.GL_Q, GL.GL_TEXTURE_GEN_MODE, GL.GL_EYE_LINEAR);
+ set_texgen_planes(gl, GL2.GL_EYE_PLANE, m);
+ gl.glTexGeni(GL2.GL_S, GL2.GL_TEXTURE_GEN_MODE, GL2.GL_EYE_LINEAR);
+ gl.glTexGeni(GL2.GL_T, GL2.GL_TEXTURE_GEN_MODE, GL2.GL_EYE_LINEAR);
+ gl.glTexGeni(GL2.GL_R, GL2.GL_TEXTURE_GEN_MODE, GL2.GL_EYE_LINEAR);
+ gl.glTexGeni(GL2.GL_Q, GL2.GL_TEXTURE_GEN_MODE, GL2.GL_EYE_LINEAR);
}
- private void obj_linear_texgen(GL gl) {
+ private void obj_linear_texgen(GL2 gl) {
Mat4f m = new Mat4f();
m.makeIdent();
- set_texgen_planes(gl, GL.GL_OBJECT_PLANE, m);
- gl.glTexGeni(GL.GL_S, GL.GL_TEXTURE_GEN_MODE, GL.GL_OBJECT_LINEAR);
- gl.glTexGeni(GL.GL_T, GL.GL_TEXTURE_GEN_MODE, GL.GL_OBJECT_LINEAR);
- gl.glTexGeni(GL.GL_R, GL.GL_TEXTURE_GEN_MODE, GL.GL_OBJECT_LINEAR);
- gl.glTexGeni(GL.GL_Q, GL.GL_TEXTURE_GEN_MODE, GL.GL_OBJECT_LINEAR);
+ set_texgen_planes(gl, GL2.GL_OBJECT_PLANE, m);
+ gl.glTexGeni(GL2.GL_S, GL2.GL_TEXTURE_GEN_MODE, GL2.GL_OBJECT_LINEAR);
+ gl.glTexGeni(GL2.GL_T, GL2.GL_TEXTURE_GEN_MODE, GL2.GL_OBJECT_LINEAR);
+ gl.glTexGeni(GL2.GL_R, GL2.GL_TEXTURE_GEN_MODE, GL2.GL_OBJECT_LINEAR);
+ gl.glTexGeni(GL2.GL_Q, GL2.GL_TEXTURE_GEN_MODE, GL2.GL_OBJECT_LINEAR);
}
- private void set_texgen_planes(GL gl, int plane_type, Mat4f m) {
- int[] coord = {GL.GL_S, GL.GL_T, GL.GL_R, GL.GL_Q};
+ private void set_texgen_planes(GL2 gl, int plane_type, Mat4f m) {
+ int[] coord = {GL2.GL_S, GL2.GL_T, GL2.GL_R, GL2.GL_Q};
float[] row = new float[4];
for(int i = 0; i < 4; i++) {
getRow(m, i, row);
@@ -494,54 +513,54 @@ public class HWShadowmapsSimple extends Demo {
private void texgen(GL gl, boolean enable) {
if(enable) {
- gl.glEnable(GL.GL_TEXTURE_GEN_S);
- gl.glEnable(GL.GL_TEXTURE_GEN_T);
- gl.glEnable(GL.GL_TEXTURE_GEN_R);
- gl.glEnable(GL.GL_TEXTURE_GEN_Q);
+ gl.glEnable(GL2.GL_TEXTURE_GEN_S);
+ gl.glEnable(GL2.GL_TEXTURE_GEN_T);
+ gl.glEnable(GL2.GL_TEXTURE_GEN_R);
+ gl.glEnable(GL2.GL_TEXTURE_GEN_Q);
} else {
- gl.glDisable(GL.GL_TEXTURE_GEN_S);
- gl.glDisable(GL.GL_TEXTURE_GEN_T);
- gl.glDisable(GL.GL_TEXTURE_GEN_R);
- gl.glDisable(GL.GL_TEXTURE_GEN_Q);
+ gl.glDisable(GL2.GL_TEXTURE_GEN_S);
+ gl.glDisable(GL2.GL_TEXTURE_GEN_T);
+ gl.glDisable(GL2.GL_TEXTURE_GEN_R);
+ gl.glDisable(GL2.GL_TEXTURE_GEN_Q);
}
}
- private void render_light_frustum(GL gl) {
+ private void render_light_frustum(GL2 gl) {
gl.glPushMatrix();
applyTransform(gl, cameraInverseTransform);
applyTransform(gl, spotlightTransform);
applyTransform(gl, perspectiveInverse(lightshaper_fovy, 1, lightshaper_zNear, lightshaper_zFar));
- gl.glDisable(GL.GL_LIGHTING);
+ gl.glDisable(GL2.GL_LIGHTING);
gl.glColor3f(1,1,0);
gl.glCallList(wirecube);
gl.glColor3f(1,1,1);
- gl.glEnable(GL.GL_LIGHTING);
+ gl.glEnable(GL2.GL_LIGHTING);
gl.glPopMatrix();
}
- private void render_quad(GL gl) {
- gl.glActiveTexture(GL.GL_TEXTURE0);
+ private void render_quad(GL2 gl) {
+ gl.glActiveTexture(GL2.GL_TEXTURE0);
obj_linear_texgen(gl);
texgen(gl, true);
- gl.glMatrixMode(GL.GL_TEXTURE);
+ gl.glMatrixMode(GL2.GL_TEXTURE);
gl.glLoadIdentity();
gl.glScalef(4,4,1);
- gl.glMatrixMode(GL.GL_MODELVIEW);
+ gl.glMatrixMode(GL2.GL_MODELVIEW);
- gl.glDisable(GL.GL_LIGHTING);
+ gl.glDisable(GL2.GL_LIGHTING);
decal.bind();
decal.enable();
gl.glCallList(quad);
decal.disable();
- gl.glEnable(GL.GL_LIGHTING);
+ gl.glEnable(GL2.GL_LIGHTING);
texgen(gl, false);
- gl.glMatrixMode(GL.GL_TEXTURE);
+ gl.glMatrixMode(GL2.GL_TEXTURE);
gl.glLoadIdentity();
- gl.glMatrixMode(GL.GL_MODELVIEW);
+ gl.glMatrixMode(GL2.GL_MODELVIEW);
}
- private void render_scene(GL gl, Mat4f view, GLAutoDrawable drawable, CameraParameters params) {
+ private void render_scene(GL2 gl, Mat4f view, GLAutoDrawable drawable, CameraParameters params) {
gl.glColor3f(1,1,1);
gl.glPushMatrix();
Mat4f inverseView = new Mat4f(view);
@@ -553,16 +572,16 @@ public class HWShadowmapsSimple extends Demo {
applyTransform(gl, objectTransform);
- gl.glEnable(GL.GL_LIGHTING);
+ gl.glEnable(GL2.GL_LIGHTING);
gl.glCallList(geometry);
- gl.glDisable(GL.GL_LIGHTING);
+ gl.glDisable(GL2.GL_LIGHTING);
gl.glPopMatrix();
gl.glPopMatrix();
}
- private void render_manipulators(GL gl, Mat4f view, GLAutoDrawable drawable, CameraParameters params) {
+ private void render_manipulators(GL2 gl, Mat4f view, GLAutoDrawable drawable, CameraParameters params) {
gl.glColor3f(1,1,1);
gl.glPushMatrix();
Mat4f inverseView = new Mat4f(view);
@@ -577,17 +596,17 @@ public class HWShadowmapsSimple extends Demo {
gl.glPopMatrix();
}
- private void render_scene_from_camera_view(GL gl, GLAutoDrawable drawable, CameraParameters params) {
+ private void render_scene_from_camera_view(GL2 gl, GLAutoDrawable drawable, CameraParameters params) {
// place light
gl.glPushMatrix();
gl.glLoadIdentity();
applyTransform(gl, cameraInverseTransform);
applyTransform(gl, spotlightTransform);
- gl.glLightfv(GL.GL_LIGHT0, GL.GL_POSITION, light_pos, 0);
+ gl.glLightfv(GL2.GL_LIGHT0, GL2.GL_POSITION, light_pos, 0);
gl.glPopMatrix();
// spot image
- gl.glActiveTexture(GL.GL_TEXTURE1);
+ gl.glActiveTexture(GL2.GL_TEXTURE1);
gl.glPushMatrix();
applyTransform(gl, cameraInverseTransform);
@@ -595,46 +614,46 @@ public class HWShadowmapsSimple extends Demo {
texgen(gl, true);
gl.glPopMatrix();
- gl.glMatrixMode(GL.GL_TEXTURE);
+ gl.glMatrixMode(GL2.GL_TEXTURE);
gl.glLoadIdentity();
gl.glTranslatef(.5f, .5f, .5f);
gl.glScalef(.5f, -.5f, .5f);
glu.gluPerspective(lightshaper_fovy, 1, lightshaper_zNear, lightshaper_zFar);
applyTransform(gl, spotlightInverseTransform);
- gl.glMatrixMode(GL.GL_MODELVIEW);
+ gl.glMatrixMode(GL2.GL_MODELVIEW);
light_image.bind();
light_image.enable();
- gl.glTexEnvi(GL.GL_TEXTURE_ENV, GL.GL_TEXTURE_ENV_MODE, GL.GL_MODULATE);
+ gl.glTexEnvi(GL2.GL_TEXTURE_ENV, GL2.GL_TEXTURE_ENV_MODE, GL2.GL_MODULATE);
- gl.glActiveTexture(GL.GL_TEXTURE0);
- gl.glMatrixMode(GL.GL_PROJECTION);
+ gl.glActiveTexture(GL2.GL_TEXTURE0);
+ gl.glMatrixMode(GL2.GL_PROJECTION);
gl.glLoadIdentity();
gl.glViewport(viewportX, viewportY, drawable.getWidth(), drawable.getHeight());
applyTransform(gl, cameraPerspective);
- gl.glMatrixMode(GL.GL_MODELVIEW);
+ gl.glMatrixMode(GL2.GL_MODELVIEW);
render_scene(gl, cameraTransform, drawable, params);
- gl.glActiveTexture(GL.GL_TEXTURE1);
+ gl.glActiveTexture(GL2.GL_TEXTURE1);
light_image.disable();
- gl.glActiveTexture(GL.GL_TEXTURE0);
+ gl.glActiveTexture(GL2.GL_TEXTURE0);
render_manipulators(gl, cameraTransform, drawable, params);
render_light_frustum(gl);
}
- private void render_scene_from_camera_view_shadowed(GL gl, GLAutoDrawable drawable, CameraParameters params) {
+ private void render_scene_from_camera_view_shadowed(GL2 gl, GLAutoDrawable drawable, CameraParameters params) {
// place light
gl.glPushMatrix();
gl.glLoadIdentity();
applyTransform(gl, cameraInverseTransform);
applyTransform(gl, spotlightTransform);
- gl.glLightfv(GL.GL_LIGHT0, GL.GL_POSITION, light_pos, 0);
+ gl.glLightfv(GL2.GL_LIGHT0, GL2.GL_POSITION, light_pos, 0);
gl.glPopMatrix();
// spot image
- gl.glActiveTexture(GL.GL_TEXTURE1);
+ gl.glActiveTexture(GL2.GL_TEXTURE1);
gl.glPushMatrix();
applyTransform(gl, cameraInverseTransform);
@@ -642,20 +661,20 @@ public class HWShadowmapsSimple extends Demo {
texgen(gl, true);
gl.glPopMatrix();
- gl.glMatrixMode(GL.GL_TEXTURE);
+ gl.glMatrixMode(GL2.GL_TEXTURE);
gl.glLoadIdentity();
gl.glTranslatef(.5f, .5f, .5f);
gl.glScalef(.5f, -.5f, .5f);
glu.gluPerspective(lightshaper_fovy, 1, lightshaper_zNear, lightshaper_zFar);
applyTransform(gl, spotlightInverseTransform);
- gl.glMatrixMode(GL.GL_MODELVIEW);
+ gl.glMatrixMode(GL2.GL_MODELVIEW);
light_image.bind();
light_image.enable();
- gl.glTexEnvi(GL.GL_TEXTURE_ENV, GL.GL_TEXTURE_ENV_MODE, GL.GL_MODULATE);
+ gl.glTexEnvi(GL2.GL_TEXTURE_ENV, GL2.GL_TEXTURE_ENV_MODE, GL2.GL_MODULATE);
// depth compare
- gl.glActiveTexture(GL.GL_TEXTURE2);
+ gl.glActiveTexture(GL2.GL_TEXTURE2);
gl.glPushMatrix();
applyTransform(gl, cameraInverseTransform);
@@ -663,32 +682,32 @@ public class HWShadowmapsSimple extends Demo {
texgen(gl, true);
gl.glPopMatrix();
- gl.glMatrixMode(GL.GL_TEXTURE);
+ gl.glMatrixMode(GL2.GL_TEXTURE);
gl.glLoadIdentity();
gl.glTranslatef(.5f, .5f, ((Tweak) tweaks.get(R_COORDINATE_SCALE)).val);
gl.glScalef(.5f, .5f, ((Tweak) tweaks.get(R_COORDINATE_BIAS)).val);
glu.gluPerspective(lightshaper_fovy, 1, lightshaper_zNear, lightshaper_zFar);
applyTransform(gl, spotlightInverseTransform);
- gl.glMatrixMode(GL.GL_MODELVIEW);
+ gl.glMatrixMode(GL2.GL_MODELVIEW);
- gl.glBindTexture(GL.GL_TEXTURE_2D, light_view_depth);
- gl.glEnable(GL.GL_TEXTURE_2D);
- gl.glTexEnvi(GL.GL_TEXTURE_ENV, GL.GL_TEXTURE_ENV_MODE, GL.GL_MODULATE);
+ gl.glBindTexture(GL2.GL_TEXTURE_2D, light_view_depth);
+ gl.glEnable(GL2.GL_TEXTURE_2D);
+ gl.glTexEnvi(GL2.GL_TEXTURE_ENV, GL2.GL_TEXTURE_ENV_MODE, GL2.GL_MODULATE);
- gl.glActiveTexture(GL.GL_TEXTURE0);
+ gl.glActiveTexture(GL2.GL_TEXTURE0);
- gl.glMatrixMode(GL.GL_PROJECTION);
+ gl.glMatrixMode(GL2.GL_PROJECTION);
gl.glLoadIdentity();
gl.glViewport(viewportX, viewportY, drawable.getWidth(), drawable.getHeight());
applyTransform(gl, cameraPerspective);
- gl.glMatrixMode(GL.GL_MODELVIEW);
+ gl.glMatrixMode(GL2.GL_MODELVIEW);
render_scene(gl, cameraTransform, drawable, params);
- gl.glActiveTexture(GL.GL_TEXTURE1);
+ gl.glActiveTexture(GL2.GL_TEXTURE1);
light_image.disable();
- gl.glActiveTexture(GL.GL_TEXTURE2);
- gl.glDisable(GL.GL_TEXTURE_2D);
- gl.glActiveTexture(GL.GL_TEXTURE0);
+ gl.glActiveTexture(GL2.GL_TEXTURE2);
+ gl.glDisable(GL2.GL_TEXTURE_2D);
+ gl.glActiveTexture(GL2.GL_TEXTURE0);
render_manipulators(gl, cameraTransform, drawable, params);
@@ -703,46 +722,46 @@ public class HWShadowmapsSimple extends Demo {
gl.glViewport(viewportX, viewportY, size, size);
}
- private void render_scene_from_light_view(GL gl, GLAutoDrawable drawable, int viewportX, int viewportY) {
+ private void render_scene_from_light_view(GL2 gl, GLAutoDrawable drawable, int viewportX, int viewportY) {
// place light
gl.glPushMatrix();
gl.glLoadIdentity();
- gl.glLightfv(GL.GL_LIGHT0, GL.GL_POSITION, light_pos, 0);
+ gl.glLightfv(GL2.GL_LIGHT0, GL2.GL_POSITION, light_pos, 0);
gl.glPopMatrix();
// spot image
- gl.glActiveTexture(GL.GL_TEXTURE1);
+ gl.glActiveTexture(GL2.GL_TEXTURE1);
gl.glPushMatrix();
eye_linear_texgen(gl);
texgen(gl, true);
gl.glPopMatrix();
- gl.glMatrixMode(GL.GL_TEXTURE);
+ gl.glMatrixMode(GL2.GL_TEXTURE);
gl.glLoadIdentity();
gl.glTranslatef(.5f, .5f, .5f);
gl.glScalef(.5f, .5f, .5f);
glu.gluPerspective(lightshaper_fovy, 1, lightshaper_zNear, lightshaper_zFar);
- gl.glMatrixMode(GL.GL_MODELVIEW);
+ gl.glMatrixMode(GL2.GL_MODELVIEW);
light_image.bind();
light_image.enable();
- gl.glTexEnvi(GL.GL_TEXTURE_ENV, GL.GL_TEXTURE_ENV_MODE, GL.GL_MODULATE);
+ gl.glTexEnvi(GL2.GL_TEXTURE_ENV, GL2.GL_TEXTURE_ENV_MODE, GL2.GL_MODULATE);
- gl.glActiveTexture(GL.GL_TEXTURE0);
+ gl.glActiveTexture(GL2.GL_TEXTURE0);
gl.glViewport(0, 0, TEX_SIZE, TEX_SIZE);
- gl.glMatrixMode(GL.GL_PROJECTION);
+ gl.glMatrixMode(GL2.GL_PROJECTION);
gl.glLoadIdentity();
glu.gluPerspective(lightshaper_fovy, 1, lightshaper_zNear, lightshaper_zFar);
- gl.glMatrixMode(GL.GL_MODELVIEW);
+ gl.glMatrixMode(GL2.GL_MODELVIEW);
if (displayMode == RENDER_SCENE_FROM_LIGHT_VIEW)
largest_square_power_of_two_viewport(gl, drawable, viewportX, viewportY);
render_scene(gl, spotlightTransform, null, null);
- gl.glActiveTexture(GL.GL_TEXTURE1);
+ gl.glActiveTexture(GL2.GL_TEXTURE1);
light_image.disable();
- gl.glActiveTexture(GL.GL_TEXTURE0);
+ gl.glActiveTexture(GL2.GL_TEXTURE0);
}
private static void getRow(Mat4f m, int row, float[] out) {
diff --git a/src/demos/infiniteShadowVolumes/InfiniteShadowVolumes.java b/src/demos/infiniteShadowVolumes/InfiniteShadowVolumes.java
index 364fc0e..4bcef94 100644
--- a/src/demos/infiniteShadowVolumes/InfiniteShadowVolumes.java
+++ b/src/demos/infiniteShadowVolumes/InfiniteShadowVolumes.java
@@ -33,22 +33,37 @@
package demos.infiniteShadowVolumes;
-import java.awt.*;
-import java.awt.event.*;
-import java.awt.image.*;
-import java.io.*;
-import java.nio.*;
-import java.util.*;
-import javax.imageio.*;
-import javax.imageio.stream.*;
-
-import javax.media.opengl.*;
-import javax.media.opengl.glu.*;
-import com.sun.opengl.util.*;
-import demos.common.*;
-import demos.util.*;
-import gleem.*;
-import gleem.linalg.*;
+import com.sun.opengl.util.glut.gl2.GLUTgl2;
+import demos.common.Demo;
+import demos.common.DemoListener;
+import demos.util.MD2;
+import gleem.BSphere;
+import gleem.BSphereProvider;
+import gleem.CameraParameters;
+import gleem.ExaminerViewer;
+import gleem.HandleBoxManip;
+import gleem.ManipManager;
+import gleem.MouseButtonHelper;
+import gleem.linalg.Mat4f;
+import gleem.linalg.Rotf;
+import gleem.linalg.Vec3f;
+import gleem.linalg.Vec4f;
+import java.awt.BorderLayout;
+import java.awt.Frame;
+import java.awt.event.KeyAdapter;
+import java.awt.event.KeyEvent;
+import java.awt.event.WindowAdapter;
+import java.awt.event.WindowEvent;
+import java.io.IOException;
+import java.nio.FloatBuffer;
+import javax.media.opengl.GL;
+import javax.media.opengl.GL2;
+import javax.media.opengl.GLAutoDrawable;
+import javax.media.opengl.GLCapabilities;
+import javax.media.opengl.awt.GLCanvas;
+import javax.media.opengl.glu.GLU;
+
+
/**
Infinite shadow volumes are described in the paper
@@ -89,7 +104,7 @@ public class InfiniteShadowVolumes extends Demo {
canvas.setSize(512, 512);
frame.add(canvas, BorderLayout.CENTER);
frame.pack();
- frame.show();
+ frame.setVisible(true);
canvas.requestFocus();
frame.addWindowListener(new WindowAdapter() {
@@ -148,7 +163,7 @@ public class InfiniteShadowVolumes extends Demo {
private int curr_view = CAMERA_VIEW;
private GLU glu = new GLU();
- private GLUT glut = new GLUT();
+ private GLUTgl2 glut = new GLUTgl2();
private GLAutoDrawable drawable;
private ExaminerViewer viewer;
@@ -177,28 +192,28 @@ public class InfiniteShadowVolumes extends Demo {
private boolean toggleWireframe;
public void init(GLAutoDrawable drawable) {
- GL gl = drawable.getGL();
+ GL2 gl = drawable.getGL().getGL2();
gl.glClearStencil(128);
- //glEnable(GL.GL_DEPTH_CLAMP_NV);
- gl.glEnable(GL.GL_DEPTH_TEST);
- gl.glDepthFunc(GL.GL_LESS);
- gl.glEnable(GL.GL_NORMALIZE);
- gl.glLightModeli(GL.GL_LIGHT_MODEL_TWO_SIDE, GL.GL_FALSE);
+ //glEnable(GL2.GL_DEPTH_CLAMP_NV);
+ gl.glEnable(GL2.GL_DEPTH_TEST);
+ gl.glDepthFunc(GL2.GL_LESS);
+ gl.glEnable(GL2.GL_NORMALIZE);
+ gl.glLightModeli(GL2.GL_LIGHT_MODEL_TWO_SIDE, GL2.GL_FALSE);
float[] ambient = new float[] {0.3f, 0.3f, 0.3f, 1};
- gl.glLightfv(GL.GL_LIGHT0, GL.GL_AMBIENT, ambient, 0);
+ gl.glLightfv(GL2.GL_LIGHT0, GL2.GL_AMBIENT, ambient, 0);
faceDisplayList = gl.glGenLists(1);
- gl.glNewList(faceDisplayList, GL.GL_COMPILE);
+ gl.glNewList(faceDisplayList, GL2.GL_COMPILE);
drawMesh(gl, 20, 40);
gl.glEndList();
int[] tmp = new int[1];
gl.glGenTextures(1, tmp, 0);
wallTexObject = tmp[0];
- gl.glBindTexture(GL.GL_TEXTURE_2D, wallTexObject);
- gl.glTexParameteri(GL.GL_TEXTURE_2D, GL.GL_GENERATE_MIPMAP_SGIS, GL.GL_TRUE);
- gl.glTexParameteri(GL.GL_TEXTURE_2D, GL.GL_TEXTURE_MIN_FILTER, GL.GL_LINEAR_MIPMAP_LINEAR);
- gl.glTexParameteri(GL.GL_TEXTURE_2D, GL.GL_TEXTURE_MAG_FILTER, GL.GL_LINEAR);
+ gl.glBindTexture(GL2.GL_TEXTURE_2D, wallTexObject);
+ gl.glTexParameteri(GL2.GL_TEXTURE_2D, GL2.GL_GENERATE_MIPMAP, GL2.GL_TRUE);
+ gl.glTexParameteri(GL2.GL_TEXTURE_2D, GL2.GL_TEXTURE_MIN_FILTER, GL2.GL_LINEAR_MIPMAP_LINEAR);
+ gl.glTexParameteri(GL2.GL_TEXTURE_2D, GL2.GL_TEXTURE_MAG_FILTER, GL2.GL_LINEAR);
float[] tex = new float[32*32];
for(int i=0; i < 32; i++) {
@@ -209,7 +224,7 @@ public class InfiniteShadowVolumes extends Demo {
tex[i+j*32] = .9f;
}
}
- gl.glTexImage2D(GL.GL_TEXTURE_2D, 0, GL.GL_RGBA, 32, 32, 0, GL.GL_LUMINANCE, GL.GL_FLOAT, FloatBuffer.wrap(tex));
+ gl.glTexImage2D(GL2.GL_TEXTURE_2D, 0, GL2.GL_RGBA, 32, 32, 0, GL2.GL_LUMINANCE, GL2.GL_FLOAT, FloatBuffer.wrap(tex));
initModel();
@@ -220,12 +235,13 @@ public class InfiniteShadowVolumes extends Demo {
doViewAll = true;
- drawable.addKeyListener(new KeyAdapter() {
- public void keyTyped(KeyEvent e) {
- dispatchKey(e.getKeyChar());
- demoListener.repaint();
- }
- });
+ //TODO drawable has no addKeyListener
+// drawable.addKeyListener(new KeyAdapter() {
+// public void keyTyped(KeyEvent e) {
+// dispatchKey(e.getKeyChar());
+// demoListener.repaint();
+// }
+// });
// Register the window with the ManipManager
ManipManager manager = ManipManager.getManipManager();
@@ -300,9 +316,9 @@ public class InfiniteShadowVolumes extends Demo {
}
public void display(GLAutoDrawable drawable) {
- GL gl = drawable.getGL();
+ GL2 gl = drawable.getGL().getGL2();
- gl.glMatrixMode(GL.GL_PROJECTION);
+ gl.glMatrixMode(GL2.GL_PROJECTION);
gl.glLoadIdentity();
if (doViewAll) {
@@ -313,14 +329,15 @@ public class InfiniteShadowVolumes extends Demo {
objectManipXform = objectManip.getTransform();
lightManipXform = lightManip.getTransform();
- if (toggleDepthClampNV) {
- if (enableDepthClampNV) {
- gl.glEnable(GL.GL_DEPTH_CLAMP_NV);
- } else {
- gl.glDisable(GL.GL_DEPTH_CLAMP_NV);
- }
- toggleDepthClampNV = false;
- }
+ // TODO GL_DEPTH_CLAMP_NV not available
+// if (toggleDepthClampNV) {
+// if (enableDepthClampNV) {
+// gl.glEnable(GL2.GL_DEPTH_CLAMP_NV);
+// } else {
+// gl.glDisable(GL2.GL_DEPTH_CLAMP_NV);
+// }
+// toggleDepthClampNV = false;
+// }
if (b[' ']) {
animateForward = true;
@@ -345,7 +362,7 @@ public class InfiniteShadowVolumes extends Demo {
}
if (hideCurrentModel) {
- gl.glNewList(faceDisplayList, GL.GL_COMPILE);
+ gl.glNewList(faceDisplayList, GL2.GL_COMPILE);
drawMesh(gl, 20, 40);
gl.glEndList();
hideCurrentModel = false;
@@ -353,9 +370,9 @@ public class InfiniteShadowVolumes extends Demo {
if (toggleWireframe) {
if(b['w'])
- gl.glPolygonMode(GL.GL_FRONT_AND_BACK, GL.GL_LINE);
+ gl.glPolygonMode(GL2.GL_FRONT_AND_BACK, GL2.GL_LINE);
else
- gl.glPolygonMode(GL.GL_FRONT_AND_BACK, GL.GL_FILL);
+ gl.glPolygonMode(GL2.GL_FRONT_AND_BACK, GL2.GL_FILL);
}
if(b['I']) {
@@ -364,7 +381,7 @@ public class InfiniteShadowVolumes extends Demo {
case CAMERA_VIEW:
viewer.update(gl);
// Undo perspective effects of ExaminerViewer
- gl.glMatrixMode(GL.GL_PROJECTION);
+ gl.glMatrixMode(GL2.GL_PROJECTION);
gl.glLoadIdentity();
applyInfinitePerspective(gl, viewer);
break;
@@ -412,7 +429,7 @@ public class InfiniteShadowVolumes extends Demo {
}
}
- gl.glMatrixMode(GL.GL_MODELVIEW);
+ gl.glMatrixMode(GL2.GL_MODELVIEW);
// FIXME
if (b['X']) {
@@ -430,18 +447,18 @@ public class InfiniteShadowVolumes extends Demo {
double[] neg_y = new double[] { 0, 1, 0, 1};
double[] pos_z = new double[] { 0, 0,-1, 1};
double[] neg_z = new double[] { 0, 0, 1, 1};
- gl.glClipPlane(GL.GL_CLIP_PLANE0, pos_x, 0);
- gl.glClipPlane(GL.GL_CLIP_PLANE1, neg_x, 0);
- gl.glClipPlane(GL.GL_CLIP_PLANE2, pos_y, 0);
- gl.glClipPlane(GL.GL_CLIP_PLANE3, neg_y, 0);
- gl.glClipPlane(GL.GL_CLIP_PLANE4, pos_z, 0);
- gl.glClipPlane(GL.GL_CLIP_PLANE5, neg_z, 0);
- gl.glEnable(GL.GL_CLIP_PLANE0);
- gl.glEnable(GL.GL_CLIP_PLANE1);
- gl.glEnable(GL.GL_CLIP_PLANE2);
- gl.glEnable(GL.GL_CLIP_PLANE3);
- gl.glEnable(GL.GL_CLIP_PLANE4);
- gl.glEnable(GL.GL_CLIP_PLANE5);
+ gl.glClipPlane(GL2.GL_CLIP_PLANE0, pos_x, 0);
+ gl.glClipPlane(GL2.GL_CLIP_PLANE1, neg_x, 0);
+ gl.glClipPlane(GL2.GL_CLIP_PLANE2, pos_y, 0);
+ gl.glClipPlane(GL2.GL_CLIP_PLANE3, neg_y, 0);
+ gl.glClipPlane(GL2.GL_CLIP_PLANE4, pos_z, 0);
+ gl.glClipPlane(GL2.GL_CLIP_PLANE5, neg_z, 0);
+ gl.glEnable(GL2.GL_CLIP_PLANE0);
+ gl.glEnable(GL2.GL_CLIP_PLANE1);
+ gl.glEnable(GL2.GL_CLIP_PLANE2);
+ gl.glEnable(GL2.GL_CLIP_PLANE3);
+ gl.glEnable(GL2.GL_CLIP_PLANE4);
+ gl.glEnable(GL2.GL_CLIP_PLANE5);
gl.glLoadIdentity();
}
@@ -450,16 +467,16 @@ public class InfiniteShadowVolumes extends Demo {
// camera.apply_inverse_transform();
// light.apply_transform();
gl.glMultMatrixf(getData(lightManipXform), 0);
- gl.glLightfv(GL.GL_LIGHT0, GL.GL_POSITION, getData(light_position), 0);
+ gl.glLightfv(GL2.GL_LIGHT0, GL2.GL_POSITION, getData(light_position), 0);
gl.glPopMatrix();
- gl.glEnable(GL.GL_LIGHT0);
+ gl.glEnable(GL2.GL_LIGHT0);
// FIXME
gl.glPushMatrix();
// gl.glLoadIdentity();
// camera.apply_inverse_transform();
- gl.glClear(GL.GL_COLOR_BUFFER_BIT | GL.GL_DEPTH_BUFFER_BIT | GL.GL_STENCIL_BUFFER_BIT);
+ gl.glClear(GL2.GL_COLOR_BUFFER_BIT | GL2.GL_DEPTH_BUFFER_BIT | GL2.GL_STENCIL_BUFFER_BIT);
ManipManager.getManipManager().updateCameraParameters(drawable, viewer.getCameraParameters());
ManipManager.getManipManager().render(drawable, gl);
@@ -475,12 +492,12 @@ public class InfiniteShadowVolumes extends Demo {
}
if (b['X']) {
- gl.glDisable(GL.GL_CLIP_PLANE0);
- gl.glDisable(GL.GL_CLIP_PLANE1);
- gl.glDisable(GL.GL_CLIP_PLANE2);
- gl.glDisable(GL.GL_CLIP_PLANE3);
- gl.glDisable(GL.GL_CLIP_PLANE4);
- gl.glDisable(GL.GL_CLIP_PLANE5);
+ gl.glDisable(GL2.GL_CLIP_PLANE0);
+ gl.glDisable(GL2.GL_CLIP_PLANE1);
+ gl.glDisable(GL2.GL_CLIP_PLANE2);
+ gl.glDisable(GL2.GL_CLIP_PLANE3);
+ gl.glDisable(GL2.GL_CLIP_PLANE4);
+ gl.glDisable(GL2.GL_CLIP_PLANE5);
}
if (!b['s']) {
@@ -492,12 +509,12 @@ public class InfiniteShadowVolumes extends Demo {
// Be aware that this can cause some multipass artifacts
// due to invariance issues.
if (b['X']) {
- gl.glEnable(GL.GL_CLIP_PLANE0);
- gl.glEnable(GL.GL_CLIP_PLANE1);
- gl.glEnable(GL.GL_CLIP_PLANE2);
- gl.glEnable(GL.GL_CLIP_PLANE3);
- gl.glEnable(GL.GL_CLIP_PLANE4);
- gl.glEnable(GL.GL_CLIP_PLANE5);
+ gl.glEnable(GL2.GL_CLIP_PLANE0);
+ gl.glEnable(GL2.GL_CLIP_PLANE1);
+ gl.glEnable(GL2.GL_CLIP_PLANE2);
+ gl.glEnable(GL2.GL_CLIP_PLANE3);
+ gl.glEnable(GL2.GL_CLIP_PLANE4);
+ gl.glEnable(GL2.GL_CLIP_PLANE5);
}
if (!b['d']) {
if (!b['R'])
@@ -523,12 +540,12 @@ public class InfiniteShadowVolumes extends Demo {
// Be aware that this can cause some multipass artifacts
// due to invariance issues.
if (b['X']) {
- gl.glDisable(GL.GL_CLIP_PLANE0);
- gl.glDisable(GL.GL_CLIP_PLANE1);
- gl.glDisable(GL.GL_CLIP_PLANE2);
- gl.glDisable(GL.GL_CLIP_PLANE3);
- gl.glDisable(GL.GL_CLIP_PLANE4);
- gl.glDisable(GL.GL_CLIP_PLANE5);
+ gl.glDisable(GL2.GL_CLIP_PLANE0);
+ gl.glDisable(GL2.GL_CLIP_PLANE1);
+ gl.glDisable(GL2.GL_CLIP_PLANE2);
+ gl.glDisable(GL2.GL_CLIP_PLANE3);
+ gl.glDisable(GL2.GL_CLIP_PLANE4);
+ gl.glDisable(GL2.GL_CLIP_PLANE5);
}
drawLight(gl);
@@ -795,7 +812,7 @@ public class InfiniteShadowVolumes extends Demo {
// This routine draws the end caps (both local and infinite) for an
// occluder. These caps are required for the zfail approach to work.
- private void drawShadowVolumeEndCaps(GL gl, int mindex) {
+ private void drawShadowVolumeEndCaps(GL2 gl, int mindex) {
Vec4f olight = new Vec4f();
Mat4f ml = new Mat4f(objectManipXform);
@@ -807,7 +824,7 @@ public class InfiniteShadowVolumes extends Demo {
gl.glPushMatrix();
gl.glMultMatrixf(getData(objectManipXform), 0);
- gl.glBegin(GL.GL_TRIANGLES);
+ gl.glBegin(GL2.GL_TRIANGLES);
for (int i = 0; i < m[mindex].mod.tri.length; i++) {
if (m[mindex].mod.tri[i].kill)
continue;
@@ -833,38 +850,38 @@ public class InfiniteShadowVolumes extends Demo {
gl.glPopMatrix();
}
- private void drawModel(GL gl, int mindex, boolean do_diffuse) {
+ private void drawModel(GL2 gl, int mindex, boolean do_diffuse) {
MD2.PositionNormal[] vpn = m[mindex].interp_frame.pn;
float[] zero = new float[] { 0, 0, 0, 0};
float[] dim = new float[] {.2f,.2f,.2f,.2f};
float[] diffuse = new float[4];
float[] specular = new float[4];
- gl.glMaterialfv(GL.GL_FRONT_AND_BACK, GL.GL_AMBIENT, getData(m[mindex].ambient), 0);
- gl.glMaterialfv(GL.GL_FRONT_AND_BACK, GL.GL_DIFFUSE, getData(m[mindex].diffuse), 0);
- gl.glMaterialfv(GL.GL_FRONT_AND_BACK, GL.GL_SPECULAR, getData(m[mindex].specular), 0);
- gl.glMaterialf(GL.GL_FRONT_AND_BACK, GL.GL_SHININESS, m[mindex].shininess);
+ gl.glMaterialfv(GL2.GL_FRONT_AND_BACK, GL2.GL_AMBIENT, getData(m[mindex].ambient), 0);
+ gl.glMaterialfv(GL2.GL_FRONT_AND_BACK, GL2.GL_DIFFUSE, getData(m[mindex].diffuse), 0);
+ gl.glMaterialfv(GL2.GL_FRONT_AND_BACK, GL2.GL_SPECULAR, getData(m[mindex].specular), 0);
+ gl.glMaterialf(GL2.GL_FRONT_AND_BACK, GL2.GL_SHININESS, m[mindex].shininess);
if (!do_diffuse) {
- gl.glGetLightfv(GL.GL_LIGHT0, GL.GL_DIFFUSE, diffuse, 0);
- gl.glLightfv(GL.GL_LIGHT0, GL.GL_DIFFUSE, dim, 0);
- gl.glGetLightfv(GL.GL_LIGHT0, GL.GL_SPECULAR, specular, 0);
- gl.glLightfv(GL.GL_LIGHT0, GL.GL_SPECULAR, zero, 0);
+ gl.glGetLightfv(GL2.GL_LIGHT0, GL2.GL_DIFFUSE, diffuse, 0);
+ gl.glLightfv(GL2.GL_LIGHT0, GL2.GL_DIFFUSE, dim, 0);
+ gl.glGetLightfv(GL2.GL_LIGHT0, GL2.GL_SPECULAR, specular, 0);
+ gl.glLightfv(GL2.GL_LIGHT0, GL2.GL_SPECULAR, zero, 0);
} else {
- gl.glBlendFunc(GL.GL_ONE, GL.GL_ONE);
- gl.glEnable(GL.GL_BLEND);
- gl.glStencilFunc(GL.GL_EQUAL, 128, ~0);
- gl.glStencilOp(GL.GL_KEEP, GL.GL_KEEP, GL.GL_KEEP);
- gl.glEnable(GL.GL_STENCIL_TEST);
- gl.glDepthFunc(GL.GL_EQUAL);
+ gl.glBlendFunc(GL2.GL_ONE, GL2.GL_ONE);
+ gl.glEnable(GL2.GL_BLEND);
+ gl.glStencilFunc(GL2.GL_EQUAL, 128, ~0);
+ gl.glStencilOp(GL2.GL_KEEP, GL2.GL_KEEP, GL2.GL_KEEP);
+ gl.glEnable(GL2.GL_STENCIL_TEST);
+ gl.glDepthFunc(GL2.GL_EQUAL);
}
gl.glPushMatrix();
gl.glMultMatrixf(getData(objectManipXform), 0);
- gl.glEnable(GL.GL_LIGHTING);
+ gl.glEnable(GL2.GL_LIGHTING);
gl.glPolygonOffset(0,-2);
- gl.glEnable(GL.GL_POLYGON_OFFSET_FILL);
+ gl.glEnable(GL2.GL_POLYGON_OFFSET_FILL);
- gl.glBegin(GL.GL_TRIANGLES);
+ gl.glBegin(GL2.GL_TRIANGLES);
{
for (int i = 0; i < m[mindex].mod.tri.length; i++) {
for(int j=0; j < 3; j++) {
@@ -876,28 +893,28 @@ public class InfiniteShadowVolumes extends Demo {
}
gl.glEnd();
- gl.glDisable(GL.GL_POLYGON_OFFSET_FILL);
+ gl.glDisable(GL2.GL_POLYGON_OFFSET_FILL);
- gl.glDisable(GL.GL_LIGHTING);
+ gl.glDisable(GL2.GL_LIGHTING);
gl.glPopMatrix();
- gl.glMaterialfv(GL.GL_FRONT_AND_BACK, GL.GL_DIFFUSE, new float[] { 0.8f, 0.8f, 0.8f, 1}, 0);
- gl.glMaterialfv(GL.GL_FRONT_AND_BACK, GL.GL_SPECULAR, new float[] { 0.3f, 0.3f, 0.3f, 1}, 0);
+ gl.glMaterialfv(GL2.GL_FRONT_AND_BACK, GL2.GL_DIFFUSE, new float[] { 0.8f, 0.8f, 0.8f, 1}, 0);
+ gl.glMaterialfv(GL2.GL_FRONT_AND_BACK, GL2.GL_SPECULAR, new float[] { 0.3f, 0.3f, 0.3f, 1}, 0);
if (!do_diffuse) {
- gl.glLightfv(GL.GL_LIGHT0, GL.GL_DIFFUSE, diffuse, 0);
- gl.glLightfv(GL.GL_LIGHT0, GL.GL_SPECULAR, specular, 0);
+ gl.glLightfv(GL2.GL_LIGHT0, GL2.GL_DIFFUSE, diffuse, 0);
+ gl.glLightfv(GL2.GL_LIGHT0, GL2.GL_SPECULAR, specular, 0);
} else {
- gl.glDisable(GL.GL_BLEND);
- //glDisable(GL.GL_STENCIL_TEST);
- gl.glStencilFunc(GL.GL_ALWAYS, 128, ~0);
- gl.glStencilOp(GL.GL_KEEP, GL.GL_KEEP, GL.GL_KEEP);
+ gl.glDisable(GL2.GL_BLEND);
+ //glDisable(GL2.GL_STENCIL_TEST);
+ gl.glStencilFunc(GL2.GL_ALWAYS, 128, ~0);
+ gl.glStencilOp(GL2.GL_KEEP, GL2.GL_KEEP, GL2.GL_KEEP);
- gl.glDepthFunc(GL.GL_LESS);
+ gl.glDepthFunc(GL2.GL_LESS);
}
}
// This is for drawing the walls of the room.
- private void drawMesh(GL gl, float size, int tess) {
+ private void drawMesh(GL2 gl, float size, int tess) {
float hsize = size/2;
float delta = size/(tess-1);
@@ -909,7 +926,7 @@ public class InfiniteShadowVolumes extends Demo {
float x = 0;
for(int i=0; i < tess-1; i++) {
float y = 0;
- gl.glBegin(GL.GL_QUAD_STRIP);
+ gl.glBegin(GL2.GL_QUAD_STRIP);
for(int j=0; j < tess; j++) {
gl.glTexCoord2f( x, y);
gl.glVertex2f ( x, y);
@@ -923,9 +940,9 @@ public class InfiniteShadowVolumes extends Demo {
gl.glPopMatrix();
}
- private void drawCube(GL gl) {
- gl.glBindTexture(GL.GL_TEXTURE_2D, wallTexObject);
- gl.glEnable(GL.GL_TEXTURE_2D);
+ private void drawCube(GL2 gl) {
+ gl.glBindTexture(GL2.GL_TEXTURE_2D, wallTexObject);
+ gl.glEnable(GL2.GL_TEXTURE_2D);
gl.glPushMatrix();
// FIXME
// room.apply_transform();
@@ -942,10 +959,10 @@ public class InfiniteShadowVolumes extends Demo {
gl.glRotatef(180, 0, 1, 0);
gl.glCallList(faceDisplayList);
gl.glPopMatrix();
- gl.glDisable(GL.GL_TEXTURE_2D);
+ gl.glDisable(GL2.GL_TEXTURE_2D);
}
- private void drawRoom(GL gl, boolean do_diffuse) {
+ private void drawRoom(GL2 gl, boolean do_diffuse) {
float[] zero = new float[] {0,0,0,0};
float[] a = new float[4];
a[0] = room_ambient;
@@ -961,53 +978,53 @@ public class InfiniteShadowVolumes extends Demo {
float[] diffuse = new float[4];
float[] specular = new float[4];
- gl.glMaterialfv(GL.GL_FRONT_AND_BACK, GL.GL_AMBIENT, a, 0);
- gl.glMaterialfv(GL.GL_FRONT_AND_BACK, GL.GL_DIFFUSE, new float[] {0.8f, 0.8f, 0.8f, 1}, 0);
- gl.glMaterialfv(GL.GL_FRONT_AND_BACK, GL.GL_SPECULAR, new float[] {0.4f, 0.4f, 0.4f, 1}, 0);
- gl.glMaterialf(GL.GL_FRONT_AND_BACK, GL.GL_SHININESS, 64.0f);
+ gl.glMaterialfv(GL2.GL_FRONT_AND_BACK, GL2.GL_AMBIENT, a, 0);
+ gl.glMaterialfv(GL2.GL_FRONT_AND_BACK, GL2.GL_DIFFUSE, new float[] {0.8f, 0.8f, 0.8f, 1}, 0);
+ gl.glMaterialfv(GL2.GL_FRONT_AND_BACK, GL2.GL_SPECULAR, new float[] {0.4f, 0.4f, 0.4f, 1}, 0);
+ gl.glMaterialf(GL2.GL_FRONT_AND_BACK, GL2.GL_SHININESS, 64.0f);
if (!do_diffuse) {
- gl.glGetLightfv(GL.GL_LIGHT0, GL.GL_DIFFUSE, diffuse, 0);
- gl.glLightfv(GL.GL_LIGHT0, GL.GL_DIFFUSE, d1, 0);
- gl.glGetLightfv(GL.GL_LIGHT0, GL.GL_SPECULAR, specular, 0);
- gl.glLightfv(GL.GL_LIGHT0, GL.GL_SPECULAR, zero, 0);
- gl.glStencilFunc(GL.GL_ALWAYS, 128, ~0);
+ gl.glGetLightfv(GL2.GL_LIGHT0, GL2.GL_DIFFUSE, diffuse, 0);
+ gl.glLightfv(GL2.GL_LIGHT0, GL2.GL_DIFFUSE, d1, 0);
+ gl.glGetLightfv(GL2.GL_LIGHT0, GL2.GL_SPECULAR, specular, 0);
+ gl.glLightfv(GL2.GL_LIGHT0, GL2.GL_SPECULAR, zero, 0);
+ gl.glStencilFunc(GL2.GL_ALWAYS, 128, ~0);
} else {
- gl.glGetLightfv(GL.GL_LIGHT0, GL.GL_EMISSION, emission, 0);
- gl.glLightfv(GL.GL_LIGHT0, GL.GL_EMISSION, zero, 0);
- gl.glGetLightfv(GL.GL_LIGHT0, GL.GL_AMBIENT, ambient, 0);
- gl.glLightfv(GL.GL_LIGHT0, GL.GL_AMBIENT, zero, 0);
- gl.glLightfv(GL.GL_LIGHT0, GL.GL_DIFFUSE, d2, 0);
- gl.glLightfv(GL.GL_LIGHT0, GL.GL_SPECULAR, s, 0);
-
- gl.glBlendFunc(GL.GL_ONE, GL.GL_ONE);
- gl.glEnable(GL.GL_BLEND);
- gl.glStencilFunc(GL.GL_EQUAL, 128, ~0);
- gl.glDepthFunc(GL.GL_EQUAL);
+ gl.glGetLightfv(GL2.GL_LIGHT0, GL2.GL_EMISSION, emission, 0);
+ gl.glLightfv(GL2.GL_LIGHT0, GL2.GL_EMISSION, zero, 0);
+ gl.glGetLightfv(GL2.GL_LIGHT0, GL2.GL_AMBIENT, ambient, 0);
+ gl.glLightfv(GL2.GL_LIGHT0, GL2.GL_AMBIENT, zero, 0);
+ gl.glLightfv(GL2.GL_LIGHT0, GL2.GL_DIFFUSE, d2, 0);
+ gl.glLightfv(GL2.GL_LIGHT0, GL2.GL_SPECULAR, s, 0);
+
+ gl.glBlendFunc(GL2.GL_ONE, GL2.GL_ONE);
+ gl.glEnable(GL2.GL_BLEND);
+ gl.glStencilFunc(GL2.GL_EQUAL, 128, ~0);
+ gl.glDepthFunc(GL2.GL_EQUAL);
}
gl.glPushMatrix();
gl.glTranslatef(0,9,0);
- gl.glEnable(GL.GL_LIGHTING);
- gl.glStencilOp(GL.GL_KEEP, GL.GL_KEEP, GL.GL_KEEP);
- gl.glEnable(GL.GL_STENCIL_TEST);
+ gl.glEnable(GL2.GL_LIGHTING);
+ gl.glStencilOp(GL2.GL_KEEP, GL2.GL_KEEP, GL2.GL_KEEP);
+ gl.glEnable(GL2.GL_STENCIL_TEST);
drawCube(gl);
- gl.glStencilFunc(GL.GL_ALWAYS, 128, ~0);
- gl.glStencilOp(GL.GL_KEEP, GL.GL_KEEP, GL.GL_KEEP);
+ gl.glStencilFunc(GL2.GL_ALWAYS, 128, ~0);
+ gl.glStencilOp(GL2.GL_KEEP, GL2.GL_KEEP, GL2.GL_KEEP);
- gl.glDisable(GL.GL_LIGHTING);
+ gl.glDisable(GL2.GL_LIGHTING);
gl.glPopMatrix();
if (!do_diffuse) {
- gl.glLightfv(GL.GL_LIGHT0, GL.GL_DIFFUSE, diffuse, 0);
- gl.glLightfv(GL.GL_LIGHT0, GL.GL_SPECULAR, specular, 0);
+ gl.glLightfv(GL2.GL_LIGHT0, GL2.GL_DIFFUSE, diffuse, 0);
+ gl.glLightfv(GL2.GL_LIGHT0, GL2.GL_SPECULAR, specular, 0);
} else {
- gl.glLightfv(GL.GL_LIGHT0, GL.GL_EMISSION, emission, 0);
- gl.glLightfv(GL.GL_LIGHT0, GL.GL_AMBIENT, ambient, 0);
+ gl.glLightfv(GL2.GL_LIGHT0, GL2.GL_EMISSION, emission, 0);
+ gl.glLightfv(GL2.GL_LIGHT0, GL2.GL_AMBIENT, ambient, 0);
- gl.glDisable(GL.GL_BLEND);
- gl.glDepthFunc(GL.GL_LESS);
+ gl.glDisable(GL2.GL_BLEND);
+ gl.glDepthFunc(GL2.GL_LESS);
}
}
@@ -1021,7 +1038,7 @@ public class InfiniteShadowVolumes extends Demo {
// This routine also doubles as the routine for drawing the local and ininite
// silhouette edges (when prim == GL_LINES).
- private void drawShadowVolumeEdges(GL gl,
+ private void drawShadowVolumeEdges(GL2 gl,
int mindex,
int prim,
boolean local,
@@ -1076,12 +1093,12 @@ public class InfiniteShadowVolumes extends Demo {
MD2.PositionNormal pn0 = f.pn[edge[0]];
MD2.PositionNormal pn1 = f.pn[edge[1]];
- if(prim == GL.GL_QUADS || local) {
+ if(prim == GL2.GL_QUADS || local) {
// local segment
gl.glVertex4f(pn0.x, pn0.y, pn0.z, 1);
gl.glVertex4f(pn1.x, pn1.y, pn1.z, 1);
}
- if(prim == GL.GL_QUADS || infinity) {
+ if(prim == GL2.GL_QUADS || infinity) {
// segment projected to infinity
gl.glVertex4f(pn1.x*olight.get(3) - olight.get(0),
pn1.y*olight.get(3) - olight.get(1),
@@ -1097,56 +1114,56 @@ public class InfiniteShadowVolumes extends Demo {
gl.glPopMatrix();
}
- private void drawShadowVolumeExtrudedEdges(GL gl, int mindex) {
- drawShadowVolumeEdges(gl, mindex, GL.GL_QUADS, true, true);
+ private void drawShadowVolumeExtrudedEdges(GL2 gl, int mindex) {
+ drawShadowVolumeEdges(gl, mindex, GL2.GL_QUADS, true, true);
}
- private void drawPossibleSilhouette(GL gl, int mindex) {
+ private void drawPossibleSilhouette(GL2 gl, int mindex) {
gl.glLineWidth(3);
gl.glColor3f(1,1,1);
- drawShadowVolumeEdges(gl, mindex, GL.GL_LINES, true, !b['-']);
+ drawShadowVolumeEdges(gl, mindex, GL2.GL_LINES, true, !b['-']);
gl.glLineWidth(1);
}
// Draw the shadow volume into the stencil buffer.
- private void drawShadowVolumeToStencil(GL gl, int mindex) {
- gl.glDepthFunc(GL.GL_LESS);
+ private void drawShadowVolumeToStencil(GL2 gl, int mindex) {
+ gl.glDepthFunc(GL2.GL_LESS);
gl.glDepthMask(false);
- gl.glStencilFunc(GL.GL_ALWAYS, 128, ~0);
- gl.glEnable(GL.GL_STENCIL_TEST);
+ gl.glStencilFunc(GL2.GL_ALWAYS, 128, ~0);
+ gl.glEnable(GL2.GL_STENCIL_TEST);
- gl.glEnable(GL.GL_CULL_FACE);
- gl.glCullFace(GL.GL_FRONT);
- gl.glStencilOp(GL.GL_KEEP, GL.GL_INCR, GL.GL_KEEP);
+ gl.glEnable(GL2.GL_CULL_FACE);
+ gl.glCullFace(GL2.GL_FRONT);
+ gl.glStencilOp(GL2.GL_KEEP, GL2.GL_INCR, GL2.GL_KEEP);
gl.glColorMask(false, false, false, false);
drawShadowVolumeExtrudedEdges(gl, mindex);
drawShadowVolumeEndCaps(gl, mindex);
- gl.glCullFace(GL.GL_BACK);
- gl.glStencilOp(GL.GL_KEEP, GL.GL_DECR, GL.GL_KEEP);
+ gl.glCullFace(GL2.GL_BACK);
+ gl.glStencilOp(GL2.GL_KEEP, GL2.GL_DECR, GL2.GL_KEEP);
drawShadowVolumeExtrudedEdges(gl, mindex);
drawShadowVolumeEndCaps(gl, mindex);
gl.glColorMask(true, true, true, true);
- gl.glDisable(GL.GL_CULL_FACE);
+ gl.glDisable(GL2.GL_CULL_FACE);
- gl.glStencilFunc(GL.GL_ALWAYS, 128, ~0);
- gl.glStencilOp(GL.GL_KEEP, GL.GL_KEEP, GL.GL_KEEP);
+ gl.glStencilFunc(GL2.GL_ALWAYS, 128, ~0);
+ gl.glStencilOp(GL2.GL_KEEP, GL2.GL_KEEP, GL2.GL_KEEP);
gl.glDepthMask(true);
- gl.glDepthFunc(GL.GL_LESS);
+ gl.glDepthFunc(GL2.GL_LESS);
}
// Draw the shadow volume into the color buffer.
- private void drawShadowVolumeToColor(GL gl, int mindex) {
- gl.glDepthFunc(GL.GL_LESS);
+ private void drawShadowVolumeToColor(GL2 gl, int mindex) {
+ gl.glDepthFunc(GL2.GL_LESS);
gl.glDepthMask(false);
- gl.glEnable(GL.GL_BLEND);
- gl.glBlendFunc(GL.GL_SRC_ALPHA, GL.GL_ONE_MINUS_SRC_ALPHA);
+ gl.glEnable(GL2.GL_BLEND);
+ gl.glBlendFunc(GL2.GL_SRC_ALPHA, GL2.GL_ONE_MINUS_SRC_ALPHA);
gl.glColor4f(1,1,1,.7f * volume_alpha);
drawShadowVolumeEndCaps(gl, mindex);
@@ -1154,13 +1171,13 @@ public class InfiniteShadowVolumes extends Demo {
drawShadowVolumeExtrudedEdges(gl, mindex);
gl.glDepthMask(true);
- gl.glDepthFunc(GL.GL_LESS);
- gl.glDisable(GL.GL_BLEND);
+ gl.glDepthFunc(GL2.GL_LESS);
+ gl.glDisable(GL2.GL_BLEND);
}
// Draw an icon to show where the local light is
// or in what direction the infinite light is pointing.
- private void drawLight(GL gl) {
+ private void drawLight(GL2 gl) {
gl.glColor3f(1,1,0);
gl.glPushMatrix();
gl.glMultMatrixf(getData(lightManipXform), 0);
diff --git a/src/demos/j2d/CustomText.java b/src/demos/j2d/CustomText.java
index aba7b97..031dfa3 100755
--- a/src/demos/j2d/CustomText.java
+++ b/src/demos/j2d/CustomText.java
@@ -39,6 +39,14 @@
package demos.j2d;
+import com.sun.opengl.util.texture.Texture;
+import com.sun.opengl.util.texture.TextureCoords;
+import com.sun.opengl.util.texture.TextureIO;
+import demos.common.Demo;
+import demos.util.FPSCounter;
+import demos.util.SystemTime;
+import demos.util.Time;
+import gleem.linalg.Vec2f;
import java.awt.BorderLayout;
import java.awt.Color;
import java.awt.Container;
@@ -47,24 +55,29 @@ import java.awt.Font;
import java.awt.GradientPaint;
import java.awt.Graphics2D;
import java.awt.GraphicsEnvironment;
-import java.awt.event.*;
-import java.awt.geom.*;
-import java.awt.font.*;
-import java.awt.image.*;
-import java.text.*;
-import java.util.*;
-import javax.swing.*;
-import javax.swing.event.*;
-
-import javax.media.opengl.*;
-import javax.media.opengl.glu.*;
-import com.sun.opengl.util.*;
-import com.sun.opengl.util.j2d.*;
-import com.sun.opengl.util.texture.*;
-
-import demos.common.*;
-import demos.util.*;
-import gleem.linalg.*;
+import java.awt.event.ActionEvent;
+import java.awt.event.ActionListener;
+import java.awt.event.WindowAdapter;
+import java.awt.event.WindowEvent;
+import java.awt.font.FontRenderContext;
+import java.awt.font.GlyphVector;
+import java.awt.geom.Rectangle2D;
+import java.awt.image.BufferedImage;
+import java.util.ArrayList;
+import java.util.Iterator;
+import java.util.List;
+import java.util.Random;
+import javax.media.opengl.GL;
+import javax.media.opengl.GL2;
+import javax.media.opengl.GLAutoDrawable;
+import javax.media.opengl.awt.GLCanvas;
+import javax.media.opengl.glu.GLU;
+import javax.media.opengl.util.Animator;
+import javax.swing.JButton;
+import javax.swing.JFrame;
+import javax.swing.JPanel;
+import sun.java2d.pipe.TextRenderer;
+
/** Illustrates more advanced use of the TextRenderer class; shows how
to do text filled with a linear Java 2D gradient. */
@@ -101,7 +114,7 @@ public class CustomText extends Demo {
}).start();
}
});
- frame.show();
+ frame.setVisible(true);
animator.start();
}
@@ -263,7 +276,7 @@ public class CustomText extends Demo {
}
}
- GL gl = drawable.getGL();
+ GL2 gl = drawable.getGL().getGL2();
gl.glClear(GL.GL_COLOR_BUFFER_BIT);
gl.glMatrixMode(GL.GL_PROJECTION);
gl.glLoadIdentity();
@@ -279,8 +292,8 @@ public class CustomText extends Demo {
int h = drawable.getHeight();
float fw = w / 100.0f;
float fh = h / 100.0f;
- gl.glTexEnvi(GL.GL_TEXTURE_ENV, GL.GL_TEXTURE_ENV_MODE, GL.GL_REPLACE);
- gl.glBegin(GL.GL_QUADS);
+ gl.glTexEnvi(GL2.GL_TEXTURE_ENV, GL2.GL_TEXTURE_ENV_MODE, GL2.GL_REPLACE);
+ gl.glBegin(GL2.GL_QUADS);
gl.glTexCoord2f(fw * coords.left(), fh * coords.bottom());
gl.glVertex3f(0, 0, 0);
gl.glTexCoord2f(fw * coords.right(), fh * coords.bottom());
diff --git a/src/demos/j2d/FlyingText.java b/src/demos/j2d/FlyingText.java
index 81deeec..b42d5ce 100755
--- a/src/demos/j2d/FlyingText.java
+++ b/src/demos/j2d/FlyingText.java
@@ -39,6 +39,14 @@
package demos.j2d;
+import com.sun.opengl.util.texture.Texture;
+import com.sun.opengl.util.texture.TextureCoords;
+import com.sun.opengl.util.texture.TextureIO;
+import demos.common.Demo;
+import demos.util.FPSCounter;
+import demos.util.SystemTime;
+import demos.util.Time;
+import gleem.linalg.Vec2f;
import java.awt.BorderLayout;
import java.awt.Color;
import java.awt.Container;
@@ -46,22 +54,30 @@ import java.awt.DisplayMode;
import java.awt.Font;
import java.awt.Graphics2D;
import java.awt.GraphicsEnvironment;
-import java.awt.event.*;
-import java.awt.image.*;
-import java.text.*;
-import java.util.*;
-import javax.swing.*;
-import javax.swing.event.*;
-
-import javax.media.opengl.*;
-import javax.media.opengl.glu.*;
-import com.sun.opengl.util.*;
-import com.sun.opengl.util.j2d.*;
-import com.sun.opengl.util.texture.*;
-
-import demos.common.*;
-import demos.util.*;
-import gleem.linalg.*;
+import java.awt.event.ActionEvent;
+import java.awt.event.ActionListener;
+import java.awt.event.WindowAdapter;
+import java.awt.event.WindowEvent;
+import java.awt.image.BufferedImage;
+import java.util.ArrayList;
+import java.util.Iterator;
+import java.util.List;
+import java.util.Random;
+import javax.media.opengl.GL;
+import javax.media.opengl.GL2;
+import javax.media.opengl.GLAutoDrawable;
+import javax.media.opengl.awt.GLCanvas;
+import javax.media.opengl.glu.GLU;
+import javax.media.opengl.util.Animator;
+import javax.swing.JButton;
+import javax.swing.JFrame;
+import javax.swing.JPanel;
+import javax.swing.JSlider;
+import javax.swing.event.ChangeEvent;
+import javax.swing.event.ChangeListener;
+import sun.java2d.pipe.TextRenderer;
+
+
/** Illustrates more advanced use of the TextRenderer class; shows how
to do animated translated and rotated text as well as a drop
@@ -99,7 +115,7 @@ public class FlyingText extends Demo {
}).start();
}
});
- frame.show();
+ frame.setVisible(true);
animator.start();
}
@@ -223,10 +239,10 @@ public class FlyingText extends Demo {
g.dispose();
backgroundTexture = TextureIO.newTexture(bgImage, false);
backgroundTexture.bind();
- backgroundTexture.setTexParameteri(GL.GL_TEXTURE_MIN_FILTER, GL.GL_NEAREST);
- backgroundTexture.setTexParameteri(GL.GL_TEXTURE_MAG_FILTER, GL.GL_NEAREST);
- backgroundTexture.setTexParameteri(GL.GL_TEXTURE_WRAP_S, GL.GL_REPEAT);
- backgroundTexture.setTexParameteri(GL.GL_TEXTURE_WRAP_T, GL.GL_REPEAT);
+ backgroundTexture.setTexParameteri(GL2.GL_TEXTURE_MIN_FILTER, GL2.GL_NEAREST);
+ backgroundTexture.setTexParameteri(GL2.GL_TEXTURE_MAG_FILTER, GL2.GL_NEAREST);
+ backgroundTexture.setTexParameteri(GL2.GL_TEXTURE_WRAP_S, GL2.GL_REPEAT);
+ backgroundTexture.setTexParameteri(GL2.GL_TEXTURE_WRAP_T, GL2.GL_REPEAT);
// Create the text renderer
renderer = new TextRenderer(new Font("Serif", Font.PLAIN, 72), true, true);
@@ -253,7 +269,7 @@ public class FlyingText extends Demo {
// Set up properties; note we don't need the depth buffer in this demo
GL gl = drawable.getGL();
- gl.glDisable(GL.GL_DEPTH_TEST);
+ gl.glDisable(GL2.GL_DEPTH_TEST);
// Turn off vsync if we can
gl.setSwapInterval(0);
}
@@ -311,12 +327,12 @@ public class FlyingText extends Demo {
}
}
- GL gl = drawable.getGL();
- gl.glClear(GL.GL_COLOR_BUFFER_BIT);
- gl.glMatrixMode(GL.GL_PROJECTION);
+ GL2 gl = drawable.getGL().getGL2();
+ gl.glClear(GL2.GL_COLOR_BUFFER_BIT);
+ gl.glMatrixMode(GL2.GL_PROJECTION);
gl.glLoadIdentity();
glu.gluOrtho2D(0, drawable.getWidth(), 0, drawable.getHeight());
- gl.glMatrixMode(GL.GL_MODELVIEW);
+ gl.glMatrixMode(GL2.GL_MODELVIEW);
gl.glLoadIdentity();
// Draw the background texture
@@ -327,8 +343,8 @@ public class FlyingText extends Demo {
int h = drawable.getHeight();
float fw = w / 100.0f;
float fh = h / 100.0f;
- gl.glTexEnvi(GL.GL_TEXTURE_ENV, GL.GL_TEXTURE_ENV_MODE, GL.GL_REPLACE);
- gl.glBegin(GL.GL_QUADS);
+ gl.glTexEnvi(GL2.GL_TEXTURE_ENV, GL2.GL_TEXTURE_ENV_MODE, GL2.GL_REPLACE);
+ gl.glBegin(GL2.GL_QUADS);
gl.glTexCoord2f(fw * coords.left(), fh * coords.bottom());
gl.glVertex3f(0, 0, 0);
gl.glTexCoord2f(fw * coords.right(), fh * coords.bottom());
@@ -347,7 +363,7 @@ public class FlyingText extends Demo {
// We tell the text renderer to render the text at the origin, and
// manipulate the modelview matrix to put the text where we want.
- gl.glMatrixMode(GL.GL_MODELVIEW);
+ gl.glMatrixMode(GL2.GL_MODELVIEW);
// First render drop shadows
renderer.setColor(0, 0, 0, 0.5f);
diff --git a/src/demos/j2d/TestOverlay.java b/src/demos/j2d/TestOverlay.java
index b0bcae2..9d6212d 100755
--- a/src/demos/j2d/TestOverlay.java
+++ b/src/demos/j2d/TestOverlay.java
@@ -39,23 +39,28 @@
package demos.j2d;
+
+
+import demos.gears.Gears;
+import demos.util.*;
+import gleem.linalg.*;
import java.awt.AlphaComposite;
import java.awt.Color;
import java.awt.Font;
import java.awt.Frame;
import java.awt.Graphics2D;
import java.awt.Rectangle;
-import java.awt.event.*;
-import java.awt.font.*;
-import java.text.*;
-
-import javax.media.opengl.*;
-import com.sun.opengl.util.*;
-import com.sun.opengl.util.j2d.*;
-
-import demos.gears.Gears;
-import demos.util.*;
-import gleem.linalg.*;
+import java.awt.event.WindowAdapter;
+import java.awt.event.WindowEvent;
+import java.awt.font.FontRenderContext;
+import java.awt.font.GlyphVector;
+import java.text.DecimalFormat;
+import javax.media.opengl.GL;
+import javax.media.opengl.GLAutoDrawable;
+import javax.media.opengl.GLCapabilities;
+import javax.media.opengl.GLEventListener;
+import javax.media.opengl.awt.GLCanvas;
+import javax.media.opengl.util.Animator;
/** A simple test of the Overlay utility class. Draws gears underneath
with moving Java 2D-rendered text on top. */
@@ -84,7 +89,7 @@ public class TestOverlay implements GLEventListener {
}).start();
}
});
- frame.show();
+ frame.setVisible(true);
animator.start();
}
diff --git a/src/demos/j2d/TestTextRenderer.java b/src/demos/j2d/TestTextRenderer.java
index 281476f..8b5284a 100755
--- a/src/demos/j2d/TestTextRenderer.java
+++ b/src/demos/j2d/TestTextRenderer.java
@@ -39,20 +39,25 @@
package demos.j2d;
+import demos.gears.Gears;
+import demos.util.FPSCounter;
+import demos.util.SystemTime;
+import demos.util.Time;
+import gleem.linalg.Vec2f;
import java.awt.Font;
import java.awt.Frame;
-import java.awt.event.*;
-import java.awt.geom.*;
-import java.text.*;
+import java.awt.event.WindowAdapter;
+import java.awt.event.WindowEvent;
+import java.awt.geom.Rectangle2D;
+import javax.media.opengl.GL;
+import javax.media.opengl.GLAutoDrawable;
+import javax.media.opengl.GLCapabilities;
+import javax.media.opengl.GLEventListener;
+import javax.media.opengl.awt.GLCanvas;
+import javax.media.opengl.util.Animator;
+import sun.java2d.pipe.TextRenderer;
-import javax.media.opengl.*;
-import javax.media.opengl.glu.*;
-import com.sun.opengl.util.*;
-import com.sun.opengl.util.j2d.*;
-import demos.gears.Gears;
-import demos.util.*;
-import gleem.linalg.*;
/** A simple test of the TextRenderer class. Draws gears underneath
with moving Java 2D-rendered text on top. */
@@ -82,7 +87,7 @@ public class TestTextRenderer implements GLEventListener {
}
});
- frame.show();
+ frame.setVisible(true);
animator.start();
}
diff --git a/src/demos/j2d/TestTextureRenderer.java b/src/demos/j2d/TestTextureRenderer.java
index 5702743..bcb7b96 100755
--- a/src/demos/j2d/TestTextureRenderer.java
+++ b/src/demos/j2d/TestTextureRenderer.java
@@ -39,24 +39,30 @@
package demos.j2d;
+import demos.gears.Gears;
+import demos.util.SystemTime;
+import demos.util.Time;
+import gleem.linalg.Vec2f;
import java.awt.AlphaComposite;
import java.awt.Color;
import java.awt.Font;
import java.awt.Frame;
import java.awt.Graphics2D;
import java.awt.Rectangle;
-import java.awt.event.*;
-import java.awt.font.*;
-import java.text.*;
+import java.awt.event.WindowAdapter;
+import java.awt.event.WindowEvent;
+import java.awt.font.FontRenderContext;
+import java.awt.font.GlyphVector;
+import java.text.DecimalFormat;
+import javax.media.opengl.GL;
+import javax.media.opengl.GLAutoDrawable;
+import javax.media.opengl.GLCapabilities;
+import javax.media.opengl.GLEventListener;
+import javax.media.opengl.awt.GLCanvas;
+import javax.media.opengl.glu.GLU;
+import javax.media.opengl.util.Animator;
-import javax.media.opengl.*;
-import javax.media.opengl.glu.*;
-import com.sun.opengl.util.*;
-import com.sun.opengl.util.j2d.*;
-import demos.gears.Gears;
-import demos.util.*;
-import gleem.linalg.*;
/** A simple test of the TextureRenderer utility class. Draws gears
underneath with moving Java 2D-rendered text on top. */
@@ -85,7 +91,7 @@ public class TestTextureRenderer implements GLEventListener {
}).start();
}
});
- frame.show();
+ frame.setVisible(true);
animator.start();
}
diff --git a/src/demos/j2d/TextCube.java b/src/demos/j2d/TextCube.java
index 10d97b7..0480358 100755
--- a/src/demos/j2d/TextCube.java
+++ b/src/demos/j2d/TextCube.java
@@ -39,20 +39,25 @@
package demos.j2d;
+import demos.common.Demo;
+import demos.util.FPSCounter;
+import demos.util.SystemTime;
+import demos.util.Time;
import java.awt.BorderLayout;
-import java.awt.Color;
import java.awt.Font;
import java.awt.Frame;
-import java.awt.event.*;
-import java.awt.geom.*;
+import java.awt.event.WindowAdapter;
+import java.awt.event.WindowEvent;
+import java.awt.geom.Rectangle2D;
+import javax.media.opengl.GL;
+import javax.media.opengl.GL2;
+import javax.media.opengl.GLAutoDrawable;
+import javax.media.opengl.awt.GLCanvas;
+import javax.media.opengl.glu.GLU;
+import javax.media.opengl.util.Animator;
+import sun.java2d.pipe.TextRenderer;
-import javax.media.opengl.*;
-import javax.media.opengl.glu.*;
-import com.sun.opengl.util.*;
-import com.sun.opengl.util.j2d.*;
-import demos.common.*;
-import demos.util.*;
/** Shows how to place 2D text in 3D using the TextRenderer. */
@@ -90,14 +95,14 @@ public class TextCube extends Demo {
}).start();
}
});
- frame.show();
+ frame.setVisible(true);
animator.start();
}
public void init(GLAutoDrawable drawable) {
renderer = new TextRenderer(new Font("SansSerif", Font.PLAIN, 72));
GL gl = drawable.getGL();
- gl.glEnable(GL.GL_DEPTH_TEST);
+ gl.glEnable(GL2.GL_DEPTH_TEST);
// Compute the scale factor of the largest string which will make
// them all fit on the faces of the cube
@@ -113,10 +118,10 @@ public class TextCube extends Demo {
}
public void display(GLAutoDrawable drawable) {
- GL gl = drawable.getGL();
- gl.glClear(GL.GL_COLOR_BUFFER_BIT | GL.GL_DEPTH_BUFFER_BIT);
+ GL2 gl = drawable.getGL().getGL2();
+ gl.glClear(GL2.GL_COLOR_BUFFER_BIT | GL2.GL_DEPTH_BUFFER_BIT);
- gl.glMatrixMode(GL.GL_MODELVIEW);
+ gl.glMatrixMode(GL2.GL_MODELVIEW);
gl.glLoadIdentity();
glu.gluLookAt(0, 0, 10,
0, 0, 0,
@@ -160,14 +165,14 @@ public class TextCube extends Demo {
public void reshape(GLAutoDrawable drawable, int x, int y, int width, int height) {
GL gl = drawable.getGL();
- gl.glMatrixMode(GL.GL_PROJECTION);
+ gl.glMatrixMode(GL2.GL_PROJECTION);
gl.glLoadIdentity();
glu.gluPerspective(15, (float) width / (float) height, 5, 15);
}
public void displayChanged(GLAutoDrawable drawable, boolean modeChanged, boolean deviceChanged) {}
- private void drawFace(GL gl,
+ private void drawFace(GL2 gl,
float faceSize,
float r, float g, float b,
String text) {
@@ -175,7 +180,7 @@ public class TextCube extends Demo {
// Face is centered around the local coordinate system's z axis,
// at a z depth of faceSize / 2
gl.glColor3f(r, g, b);
- gl.glBegin(GL.GL_QUADS);
+ gl.glBegin(GL2.GL_QUADS);
gl.glVertex3f(-halfFaceSize, -halfFaceSize, halfFaceSize);
gl.glVertex3f( halfFaceSize, -halfFaceSize, halfFaceSize);
gl.glVertex3f( halfFaceSize, halfFaceSize, halfFaceSize);
@@ -191,8 +196,8 @@ public class TextCube extends Demo {
// internally we don't have to reset the depth test or cull face
// bits after we're done.
renderer.begin3DRendering();
- gl.glDisable(GL.GL_DEPTH_TEST);
- gl.glEnable(GL.GL_CULL_FACE);
+ gl.glDisable(GL2.GL_DEPTH_TEST);
+ gl.glEnable(GL2.GL_CULL_FACE);
// Note that the defaults for glCullFace and glFrontFace are
// GL_BACK and GL_CCW, which match the TextRenderer's definition
// of front-facing text.
diff --git a/src/demos/j2d/TextFlow.java b/src/demos/j2d/TextFlow.java
index 3dfcf14..11e8ea5 100755
--- a/src/demos/j2d/TextFlow.java
+++ b/src/demos/j2d/TextFlow.java
@@ -39,21 +39,29 @@
package demos.j2d;
+import demos.common.Demo;
+import demos.util.SystemTime;
+import demos.util.Time;
import java.awt.BorderLayout;
import java.awt.Font;
import java.awt.Frame;
-import java.awt.event.*;
-import java.awt.font.*;
-import java.awt.geom.*;
-import java.text.*;
-import java.util.*;
+import java.awt.event.WindowAdapter;
+import java.awt.event.WindowEvent;
+import java.awt.font.FontRenderContext;
+import java.awt.font.LineBreakMeasurer;
+import java.awt.font.TextAttribute;
+import java.awt.geom.Rectangle2D;
+import java.text.AttributedString;
+import java.util.ArrayList;
+import java.util.HashMap;
+import java.util.List;
+import java.util.Map;
+import javax.media.opengl.GL;
+import javax.media.opengl.GLAutoDrawable;
+import javax.media.opengl.awt.GLCanvas;
+import javax.media.opengl.util.Animator;
+import sun.java2d.pipe.TextRenderer;
-import javax.media.opengl.*;
-import com.sun.opengl.util.*;
-import com.sun.opengl.util.j2d.*;
-
-import demos.common.*;
-import demos.util.*;
/** Illustrates both the TextRenderer's capability for handling
relatively large amounts of text (more than drawn on the screen --
@@ -88,7 +96,7 @@ public class TextFlow extends Demo {
}).start();
}
});
- frame.show();
+ frame.setVisible(true);
animator.start();
}
diff --git a/src/demos/jgears/JGears.java b/src/demos/jgears/JGears.java
index 9da0f46..0c10bab 100644
--- a/src/demos/jgears/JGears.java
+++ b/src/demos/jgears/JGears.java
@@ -1,17 +1,29 @@
package demos.jgears;
-import java.awt.*;
-import java.awt.event.*;
-import java.awt.geom.*;
-import java.awt.image.*;
-import java.io.*;
-import java.text.*;
-import javax.imageio.*;
-import javax.swing.*;
-
-import javax.media.opengl.*;
-import com.sun.opengl.util.*;
+
import demos.gears.Gears;
+import java.awt.BorderLayout;
+import java.awt.Color;
+import java.awt.Font;
+import java.awt.GradientPaint;
+import java.awt.Graphics;
+import java.awt.Graphics2D;
+import java.awt.RenderingHints;
+import java.awt.event.ActionEvent;
+import java.awt.event.ActionListener;
+import java.awt.event.WindowAdapter;
+import java.awt.event.WindowEvent;
+import java.awt.geom.AffineTransform;
+import java.awt.image.BufferedImage;
+import java.io.InputStream;
+import java.text.DecimalFormat;
+import javax.imageio.ImageIO;
+import javax.media.opengl.GLCapabilities;
+import javax.media.opengl.awt.gl2.GL2JPanel;
+import javax.media.opengl.util.Animator;
+import javax.swing.JCheckBox;
+import javax.swing.JFrame;
+import javax.swing.JPanel;
/**
* JGears.java <BR>
@@ -20,7 +32,7 @@ import demos.gears.Gears;
* This version is equal to Brian Paul's version 1.2 1999/10/21
*/
-public class JGears extends GLJPanel {
+public class JGears extends GL2JPanel {
private static GLCapabilities caps;
private long startTime;
private int frameCount;
@@ -107,7 +119,7 @@ public class JGears extends GLJPanel {
public static void main(String[] args) {
JFrame frame = new JFrame("Gear Demo");
frame.getContentPane().setLayout(new BorderLayout());
- final GLJPanel drawable = new JGears();
+ final GL2JPanel drawable = new JGears();
drawable.setOpaque(false);
JPanel gradientPanel = createGradientPanel();
@@ -137,7 +149,7 @@ public class JGears extends GLJPanel {
}).start();
}
});
- frame.show();
+ frame.setVisible(true);
animator.start();
}
}
diff --git a/src/demos/jrefract/JRefract.java b/src/demos/jrefract/JRefract.java
index ee659da..6a46230 100755
--- a/src/demos/jrefract/JRefract.java
+++ b/src/demos/jrefract/JRefract.java
@@ -33,28 +33,46 @@
package demos.jrefract;
-import java.awt.*;
-import java.awt.event.*;
-import java.util.*;
-import javax.swing.*;
-import javax.swing.event.*;
-
-import javax.media.opengl.*;
-import com.sun.opengl.util.*;
-import com.sun.opengl.util.*;
-import demos.common.*;
+import demos.common.Demo;
+import demos.common.DemoListener;
import demos.hdr.HDR;
import demos.hwShadowmapsSimple.HWShadowmapsSimple;
import demos.infiniteShadowVolumes.InfiniteShadowVolumes;
import demos.j2d.FlyingText;
import demos.jgears.JGears;
import demos.proceduralTexturePhysics.ProceduralTexturePhysics;
-import demos.util.*;
import demos.vertexBufferObject.VertexBufferObject;
import demos.vertexProgRefract.VertexProgRefract;
import demos.vertexProgWarp.VertexProgWarp;
+import demos.xtrans.XTDesktopPane;
+import java.awt.BorderLayout;
+import java.awt.Font;
+import java.awt.event.ActionEvent;
+import java.awt.event.ActionListener;
+import java.awt.event.InputEvent;
+import java.awt.event.KeyEvent;
+import java.awt.event.MouseAdapter;
+import java.awt.event.MouseEvent;
+import java.awt.event.WindowAdapter;
+import java.awt.event.WindowEvent;
+import javax.media.opengl.GLCapabilities;
+import javax.media.opengl.awt.gl2.GL2JPanel;
+import javax.media.opengl.util.Animator;
+import javax.media.opengl.util.FPSAnimator;
+import javax.swing.JCheckBox;
+import javax.swing.JDesktopPane;
+import javax.swing.JFrame;
+import javax.swing.JInternalFrame;
+import javax.swing.JLabel;
+import javax.swing.JMenu;
+import javax.swing.JMenuBar;
+import javax.swing.JMenuItem;
+import javax.swing.JPanel;
+import javax.swing.KeyStroke;
+import javax.swing.SwingUtilities;
+import javax.swing.event.InternalFrameAdapter;
+import javax.swing.event.InternalFrameEvent;
-import demos.xtrans.*;
/**
Wavelength-dependent refraction demo<br>
@@ -120,10 +138,10 @@ public class JRefract {
if (which == INFINITE) {
caps.setStencilBits(16);
}
- final GLJPanel canvas =
+ final GL2JPanel canvas =
(which == GEARS) ?
new JGears() :
- new GLJPanel(caps);
+ new GL2JPanel(caps);
final DemoListener demoListener = new DemoListener() {
public void shutdownDemo() {
removeJPanel(canvas);
@@ -402,11 +420,11 @@ public class JRefract {
}).start();
}
- private synchronized void addJPanel(GLJPanel panel) {
+ private synchronized void addJPanel(GL2JPanel panel) {
animator.add(panel);
}
- private synchronized void removeJPanel(GLJPanel panel) {
+ private synchronized void removeJPanel(GL2JPanel panel) {
animator.remove(panel);
}
diff --git a/src/demos/misc/GLCapsTableDemo.java b/src/demos/misc/GLCapsTableDemo.java
index 767c4d5..940079c 100755
--- a/src/demos/misc/GLCapsTableDemo.java
+++ b/src/demos/misc/GLCapsTableDemo.java
@@ -1,16 +1,30 @@
package demos.misc;
-import java.awt.*;
-import java.awt.event.*;
-import java.util.*;
-import javax.media.opengl.*;
-import javax.media.opengl.glu.*;
-import javax.swing.*;
-import com.sun.opengl.util.FPSAnimator;
+
import javax.swing.border.TitledBorder;
import javax.swing.table.TableColumn;
import demos.gears.Gears;
+import java.awt.BorderLayout;
+import java.awt.Dimension;
+import java.awt.GraphicsDevice;
+import java.awt.GraphicsEnvironment;
+import java.awt.Toolkit;
+import java.awt.event.ActionEvent;
+import java.awt.event.ActionListener;
+import java.util.ArrayList;
+import javax.media.opengl.DefaultGLCapabilitiesChooser;
+import javax.media.opengl.GLCapabilities;
+import javax.media.opengl.GLCapabilitiesChooser;
+import javax.media.opengl.awt.GLCanvas;
+import javax.media.opengl.util.FPSAnimator;
+import javax.swing.BorderFactory;
+import javax.swing.JButton;
+import javax.swing.JFrame;
+import javax.swing.JPanel;
+import javax.swing.JScrollPane;
+import javax.swing.JSplitPane;
+import javax.swing.JTable;
/*******************************************************************************
* @file GLCapsTableDemo.java
diff --git a/src/demos/misc/Picking.java b/src/demos/misc/Picking.java
index 2fe8b2d..c985894 100755
--- a/src/demos/misc/Picking.java
+++ b/src/demos/misc/Picking.java
@@ -14,10 +14,11 @@ import java.awt.*;
import java.awt.event.*;
import java.awt.Canvas.*;
import java.nio.*;
-import java.util.*;
import javax.media.opengl.*;
+import javax.media.opengl.awt.GLCanvas;
import javax.media.opengl.glu.*;
-import com.sun.opengl.util.*;
+import javax.media.opengl.util.Animator;
+import javax.media.opengl.util.BufferUtil;
public class Picking
{
@@ -32,7 +33,10 @@ public class Picking
GLDrawableFactory factory = GLDrawableFactory.getFactory();
GLCapabilities capabilities = new GLCapabilities();
GLCanvas drawable = new GLCanvas(capabilities);
- drawable.addGLEventListener(new Renderer());
+ final Renderer renderer = new Renderer();
+ drawable.addGLEventListener(renderer);
+ drawable.addMouseListener(renderer);
+ drawable.addMouseMotionListener(renderer);
frame.add(drawable);
frame.setSize(400, 400);
final Animator animator = new Animator(drawable);
@@ -44,7 +48,7 @@ public class Picking
System.exit(0);
}
});
- frame.show();
+ frame.setVisible(true);
animator.start();
}
@@ -61,12 +65,10 @@ public class Picking
{
GL gl = drawable.getGL();
this.gldrawable = drawable;
- gl.glEnable(GL.GL_CULL_FACE);
- gl.glEnable(GL.GL_DEPTH_TEST);
- gl.glEnable(GL.GL_NORMALIZE);
+ gl.glEnable(GL2.GL_CULL_FACE);
+ gl.glEnable(GL2.GL_DEPTH_TEST);
+ gl.glEnable(GL2.GL_NORMALIZE);
gl.glClearColor(0.0f, 0.0f, 0.0f, 0.0f);
- drawable.addMouseListener(this);
- drawable.addMouseMotionListener(this);
}
public void reshape(GLAutoDrawable drawable, int x, int y, int width, int height)
@@ -74,14 +76,14 @@ public class Picking
GL gl = drawable.getGL();
float h = (float) height / (float) width;
gl.glViewport(0, 0, width, height);
- gl.glMatrixMode(GL.GL_PROJECTION);
+ gl.glMatrixMode(GL2.GL_PROJECTION);
gl.glLoadIdentity();
glu.gluOrtho2D(0.0f,1.0f,0.0f,1.0f);
}
public void display(GLAutoDrawable drawable)
{
- GL gl = drawable.getGL();
+ GL2 gl = drawable.getGL().getGL2();
switch(cmd)
{
case UPDATE:
@@ -93,20 +95,20 @@ public class Picking
int[] viewPort = new int[4];
IntBuffer selectBuffer = BufferUtil.newIntBuffer(buffsize);
int hits = 0;
- gl.glGetIntegerv(GL.GL_VIEWPORT, viewPort, 0);
+ gl.glGetIntegerv(GL2.GL_VIEWPORT, viewPort, 0);
gl.glSelectBuffer(buffsize, selectBuffer);
- gl.glRenderMode(GL.GL_SELECT);
+ gl.glRenderMode(GL2.GL_SELECT);
gl.glInitNames();
- gl.glMatrixMode(GL.GL_PROJECTION);
+ gl.glMatrixMode(GL2.GL_PROJECTION);
gl.glPushMatrix();
gl.glLoadIdentity();
glu.gluPickMatrix(x, (double) viewPort[3] - y, 5.0d, 5.0d, viewPort, 0);
glu.gluOrtho2D(0.0d, 1.0d, 0.0d, 1.0d);
drawScene(gl);
- gl.glMatrixMode(GL.GL_PROJECTION);
+ gl.glMatrixMode(GL2.GL_PROJECTION);
gl.glPopMatrix();
gl.glFlush();
- hits = gl.glRenderMode(GL.GL_RENDER);
+ hits = gl.glRenderMode(GL2.GL_RENDER);
processHits(hits, selectBuffer);
cmd = UPDATE;
break;
@@ -149,20 +151,20 @@ public class Picking
public int viewPortWidth(GL gl)
{
int[] viewPort = new int[4];
- gl.glGetIntegerv(GL.GL_VIEWPORT, viewPort, 0);
+ gl.glGetIntegerv(GL2.GL_VIEWPORT, viewPort, 0);
return viewPort[2];
}
public int viewPortHeight(GL gl)
{
int[] viewPort = new int[4];
- gl.glGetIntegerv(GL.GL_VIEWPORT, viewPort, 0);
+ gl.glGetIntegerv(GL2.GL_VIEWPORT, viewPort, 0);
return viewPort[3];
}
- public void drawScene(GL gl)
+ public void drawScene(GL2 gl)
{
- gl.glClear(GL.GL_COLOR_BUFFER_BIT | GL.GL_DEPTH_BUFFER_BIT);
+ gl.glClear(GL2.GL_COLOR_BUFFER_BIT | GL2.GL_DEPTH_BUFFER_BIT);
// Colors
float red[] = {1.0f,0.0f,0.0f,1.0f};
@@ -227,9 +229,9 @@ public class Picking
float[] c;
int id = 0;
boolean outline = false;
- GL gl;
+ GL2 gl;
GLU glu;
- public GLEntity(GL gl, GLU glu)
+ public GLEntity(GL2 gl, GLU glu)
{
this.gl = gl;
this.glu = glu;
@@ -246,19 +248,19 @@ public class Picking
{
float w = 0.1f;
float h = 0.1f;
- public GLRectangleEntity(GL gl, GLU glu)
+ public GLRectangleEntity(GL2 gl, GLU glu)
{
super(gl, glu);
}
public void _draw()
{
if (outline)
- gl.glPolygonMode(GL.GL_FRONT, GL.GL_LINE);
+ gl.glPolygonMode(GL2.GL_FRONT, GL2.GL_LINE);
else
- gl.glPolygonMode(GL.GL_FRONT, GL.GL_FILL);
+ gl.glPolygonMode(GL2.GL_FRONT, GL2.GL_FILL);
gl.glColor4fv(c, 0);
- gl.glBegin(GL.GL_POLYGON);
+ gl.glBegin(GL2.GL_POLYGON);
gl.glVertex3f(x, y, z);
gl.glVertex3f(x + w, y, z);
gl.glVertex3f(x + w, y + h, z);
diff --git a/src/demos/misc/TiledRendering.java b/src/demos/misc/TiledRendering.java
index f5b857e..6d9806e 100755
--- a/src/demos/misc/TiledRendering.java
+++ b/src/demos/misc/TiledRendering.java
@@ -6,8 +6,9 @@ import java.nio.*;
import javax.imageio.*;
import javax.media.opengl.*;
-import com.sun.opengl.util.*;
+import com.sun.opengl.util.awt.*;
+import com.sun.opengl.util.io.TGAWriter;
import demos.gears.Gears;
/** Demonstrates the TileRenderer class by rendering a large version
@@ -74,7 +75,7 @@ public class TiledRendering {
System.exit(1);
}
- GL gl = pbuffer.getGL();
+ GL2 gl = pbuffer.getGL().getGL2();
gl.glMatrixMode(GL.GL_MODELVIEW);
gl.glLoadIdentity();
gl.glTranslatef(0.0f, 0.0f, -40.0f);
@@ -98,7 +99,7 @@ public class TiledRendering {
}
}
- private static void drawGears(GL gl) {
+ private static void drawGears(GL2 gl) {
float view_rotx = 20.0f, view_roty = 30.0f, view_rotz = 0.0f;
float angle = 0.0f;
float pos[] = { 5.0f, 5.0f, 10.0f, 0.0f };
diff --git a/src/demos/multisample/Multisample.java b/src/demos/multisample/Multisample.java
index 4db572a..c3c9a01 100755
--- a/src/demos/multisample/Multisample.java
+++ b/src/demos/multisample/Multisample.java
@@ -42,6 +42,7 @@ package demos.multisample;
import java.awt.*;
import java.awt.event.*;
import javax.media.opengl.*;
+import javax.media.opengl.awt.GLCanvas;
public class Multisample {
private GLCanvas canvas;
@@ -89,7 +90,7 @@ public class Multisample {
canvas.setSize(512, 512);
frame.add(canvas, BorderLayout.CENTER);
frame.pack();
- frame.show();
+ frame.setVisible(true);
frame.setLocation(0, 0);
canvas.requestFocus();
@@ -109,7 +110,7 @@ public class Multisample {
canvas.setSize(512, 512);
frame.add(canvas, BorderLayout.CENTER);
frame.pack();
- frame.show();
+ frame.setVisible(true);
frame.setLocation(512, 0);
canvas.requestFocus();
@@ -122,7 +123,7 @@ public class Multisample {
class Listener implements GLEventListener {
public void init(GLAutoDrawable drawable) {
- GL gl = drawable.getGL();
+ GL2 gl = drawable.getGL().getGL2();
gl.glClearColor(0, 0, 0, 0);
// gl.glEnable(GL.GL_DEPTH_TEST);
@@ -136,7 +137,7 @@ public class Multisample {
}
public void display(GLAutoDrawable drawable) {
- GL gl = drawable.getGL();
+ GL2 gl = drawable.getGL().getGL2();
gl.glClear(GL.GL_COLOR_BUFFER_BIT | GL.GL_DEPTH_BUFFER_BIT);
diff --git a/src/demos/nurbs/icons/IconFactory.java b/src/demos/nurbs/icons/IconFactory.java
index 88d8539..81c906a 100755
--- a/src/demos/nurbs/icons/IconFactory.java
+++ b/src/demos/nurbs/icons/IconFactory.java
@@ -1,8 +1,8 @@
package demos.nurbs.icons;
+import com.sun.opengl.impl.io.StreamUtil;
import java.io.*;
import javax.swing.ImageIcon;
-import com.sun.opengl.util.StreamUtil;
public class IconFactory {
private IconFactory() {}
@@ -10,7 +10,7 @@ public class IconFactory {
public static ImageIcon getIcon(String resourceName) {
try {
InputStream input = IconFactory.class.getClassLoader().getResourceAsStream(resourceName);
- byte[] data = StreamUtil.readAll(input);
+ byte[] data = StreamUtil.readAll2Array(input);
return new ImageIcon(data, resourceName);
} catch (IOException e) {
return new ImageIcon();
diff --git a/src/demos/nurbs/surfaceapp/GLListener.java b/src/demos/nurbs/surfaceapp/GLListener.java
index fe0918f..d83f28e 100755
--- a/src/demos/nurbs/surfaceapp/GLListener.java
+++ b/src/demos/nurbs/surfaceapp/GLListener.java
@@ -5,7 +5,8 @@ import javax.media.opengl.GLAutoDrawable;
import javax.media.opengl.GLEventListener;
import javax.media.opengl.glu.*;
-import com.sun.opengl.util.GLUT;
+import com.sun.opengl.util.glut.gl2.GLUTgl2;
+import javax.media.opengl.GL2;
/**
* Listener reacting to events occuring on OpenGL canvas
@@ -18,7 +19,7 @@ public class GLListener implements GLEventListener {
* Object realizing OpenGL functions
* objekt realizující základní OpenGL funkce
*/
- private GL gl;
+ private GL2 gl;
/**
* GLU object
@@ -91,7 +92,7 @@ public class GLListener implements GLEventListener {
* GLUT object
* Objekt pro podporu funkcionality GL utility toolkit
*/
- private GLUT glut;
+ private GLUTgl2 glut;
/**
@@ -112,18 +113,18 @@ public class GLListener implements GLEventListener {
* @see javax.media.opengl.GLEventListener#init(javax.media.opengl.GLAutoDrawable)
*/
public void init(GLAutoDrawable drawable) {
- this.gl = drawable.getGL();
+ this.gl = drawable.getGL().getGL2();
this.glu = new GLU();
- this.glut = new GLUT();
+ this.glut = new GLUTgl2();
this.nurbs = glu.gluNewNurbsRenderer();
// gl.glClearColor(0, 0, 0, 0);
gl.glClearColor(1, 1, 1, 0);
- gl.glEnable(GL.GL_DEPTH_TEST);
- gl.glDepthFunc(GL.GL_LESS);
+ gl.glEnable(GL2.GL_DEPTH_TEST);
+ gl.glDepthFunc(GL2.GL_LESS);
gl.glClearDepth(1000.0f);
- gl.glHint(GL.GL_PERSPECTIVE_CORRECTION_HINT, GL.GL_NICEST);
+ gl.glHint(GL2.GL_PERSPECTIVE_CORRECTION_HINT, GL2.GL_NICEST);
}
/* (non-Javadoc)
@@ -131,36 +132,35 @@ public class GLListener implements GLEventListener {
*/
public void display(GLAutoDrawable drawable) {
- gl.glClear(GL.GL_COLOR_BUFFER_BIT| GL.GL_DEPTH_BUFFER_BIT);
+ gl.glClear(GL2.GL_COLOR_BUFFER_BIT| GL2.GL_DEPTH_BUFFER_BIT);
- gl.glMatrixMode(GL.GL_MODELVIEW);
+ gl.glMatrixMode(GL2.GL_MODELVIEW);
gl.glLoadIdentity();
- glu.gluLookAt(0,0,400, 0,0,0, 0,1,0);
-
-
+ glu.gluLookAt(0,0,400, 0,0,0, 0,1,0);
+
// gl.glPushMatrix();
- gl.glShadeModel(GL.GL_SMOOTH);
- gl.glPolygonMode(GL.GL_FRONT, GL.GL_FILL);
- gl.glPolygonMode(GL.GL_BACK, GL.GL_FILL);
- gl.glDisable(GL.GL_CULL_FACE);
+ gl.glShadeModel(GL2.GL_SMOOTH);
+ gl.glPolygonMode(GL2.GL_FRONT, GL2.GL_FILL);
+ gl.glPolygonMode(GL2.GL_BACK, GL2.GL_FILL);
+ gl.glDisable(GL2.GL_CULL_FACE);
- gl.glMaterialfv(GL.GL_FRONT, GL.GL_DIFFUSE, materialDiffuse,0);
- gl.glMaterialfv(GL.GL_BACK, GL.GL_DIFFUSE, materialDiffuse,0);
+ gl.glMaterialfv(GL2.GL_FRONT, GL2.GL_DIFFUSE, materialDiffuse,0);
+ gl.glMaterialfv(GL2.GL_BACK, GL2.GL_DIFFUSE, materialDiffuse,0);
- gl.glLightfv(GL.GL_LIGHT0, GL.GL_POSITION, lightPosition,0);
- gl.glLightfv(GL.GL_LIGHT0, GL.GL_DIFFUSE, materialDiffuse,0);
- gl.glLightfv(GL.GL_LIGHT0, GL.GL_AMBIENT, lightAmbient,0);
- gl.glLightfv(GL.GL_LIGHT0, GL.GL_SPECULAR, lightAmbient,0);
+ gl.glLightfv(GL2.GL_LIGHT0, GL2.GL_POSITION, lightPosition,0);
+ gl.glLightfv(GL2.GL_LIGHT0, GL2.GL_DIFFUSE, materialDiffuse,0);
+ gl.glLightfv(GL2.GL_LIGHT0, GL2.GL_AMBIENT, lightAmbient,0);
+ gl.glLightfv(GL2.GL_LIGHT0, GL2.GL_SPECULAR, lightAmbient,0);
- gl.glLightfv(GL.GL_LIGHT2, GL.GL_POSITION, lightPosition3,0);
- gl.glLightfv(GL.GL_LIGHT2, GL.GL_DIFFUSE, lightDiffuse,0);
+ gl.glLightfv(GL2.GL_LIGHT2, GL2.GL_POSITION, lightPosition3,0);
+ gl.glLightfv(GL2.GL_LIGHT2, GL2.GL_DIFFUSE, lightDiffuse,0);
- if(app.isLightingEnabled())gl.glEnable(GL.GL_LIGHTING);
- else gl.glDisable(GL.GL_LIGHTING);
- gl.glEnable(GL.GL_LIGHT0);
- gl.glEnable(GL.GL_LIGHT2);
+ if(app.isLightingEnabled())gl.glEnable(GL2.GL_LIGHTING);
+ else gl.glDisable(GL2.GL_LIGHTING);
+ gl.glEnable(GL2.GL_LIGHT0);
+ gl.glEnable(GL2.GL_LIGHT2);
// gl.glPopMatrix();
@@ -179,14 +179,14 @@ public class GLListener implements GLEventListener {
- gl.glGetIntegerv(GL.GL_VIEWPORT,viewport,0);
- gl.glGetDoublev(GL.GL_MODELVIEW_MATRIX,mvmatrix,0);
- gl.glGetDoublev(GL.GL_PROJECTION_MATRIX,projmatrix,0);
+ gl.glGetIntegerv(GL2.GL_VIEWPORT,viewport,0);
+ gl.glGetDoublev(GL2.GL_MODELVIEW_MATRIX,mvmatrix,0);
+ gl.glGetDoublev(GL2.GL_PROJECTION_MATRIX,projmatrix,0);
- gl.glEnable(GL.GL_LINE_SMOOTH);
- gl.glEnable(GL.GL_BLEND);
- gl.glBlendFunc(GL.GL_SRC_ALPHA, GL.GL_ONE_MINUS_SRC_ALPHA);
- gl.glHint(GL.GL_LINE_SMOOTH_HINT, GL.GL_DONT_CARE);
+ gl.glEnable(GL2.GL_LINE_SMOOTH);
+ gl.glEnable(GL2.GL_BLEND);
+ gl.glBlendFunc(GL2.GL_SRC_ALPHA, GL2.GL_ONE_MINUS_SRC_ALPHA);
+ gl.glHint(GL2.GL_LINE_SMOOTH_HINT, GL2.GL_DONT_CARE);
gl.glLineWidth(3);
@@ -203,16 +203,16 @@ public class GLListener implements GLEventListener {
ctrlpoints,
Surface.getInstance().getOrderU(),
Surface.getInstance().getOrderV(),
- GL.GL_MAP2_VERTEX_4);
+ GL2.GL_MAP2_VERTEX_4);
glu.gluEndSurface(nurbs);
}
- gl.glDisable(GL.GL_LIGHTING);
+ gl.glDisable(GL2.GL_LIGHTING);
// gl.glColor3f(1,1,1);
gl.glColor3f(0,0,0);
gl.glPointSize(5);
- gl.glBegin(GL.GL_POINTS);
+ gl.glBegin(GL2.GL_POINTS);
for (int i = 0; i < ctrlpoints.length / 4; i++) {
gl.glVertex3d(ctrlpoints[i * 4]/ctrlpoints[i * 4 + 3], ctrlpoints[i * 4 + 1]/ctrlpoints[i * 4 + 3],
ctrlpoints[i * 4 + 2]/ctrlpoints[i * 4 + 3]);
@@ -225,7 +225,7 @@ public class GLListener implements GLEventListener {
ctrlpoints[i * 4 + 2]/ctrlpoints[i * 4 + 3]);
//gl.glRasterPos2f((int)coords[0], (int)(viewport[3]-coords[1]-1-5));
// gl.glRasterPos2d(20,20);
- glut.glutBitmapString(GLUT.BITMAP_HELVETICA_18,String.valueOf(i+1));
+ glut.glutBitmapString(GLUTgl2.BITMAP_HELVETICA_18,String.valueOf(i+1));
}
@@ -234,7 +234,7 @@ public class GLListener implements GLEventListener {
//TODO zobrazovat síť - musí to být pomocí dvou vnořených forcyklů
//TODO draw mesh - it needs two nested for statements
gl.glLineWidth(1);
- // gl.glBegin(GL.GL_LINE_STRIP);
+ // gl.glBegin(GL2.GL_LINE_STRIP);
int baseIndex=0 ;
@@ -243,7 +243,7 @@ public class GLListener implements GLEventListener {
//"příčná žebra"
//"cross ribs"
for(int i=0;i<Surface.getInstance().getPointsInU();i++){
- gl.glBegin(GL.GL_LINE_STRIP);
+ gl.glBegin(GL2.GL_LINE_STRIP);
for(int j=0;j<Surface.getInstance().getPointsInV();j++){
baseIndex=i*Surface.getInstance().getPointsInV()*4+j*4;
gl.glVertex3f(ctrlpoints[baseIndex+0]/ctrlpoints[baseIndex+3],
@@ -255,7 +255,7 @@ public class GLListener implements GLEventListener {
//"podélná žebra"
//"alongway ribs"
for(int j=0;j<Surface.getInstance().getPointsInV();j++){
- gl.glBegin(GL.GL_LINE_STRIP);
+ gl.glBegin(GL2.GL_LINE_STRIP);
for(int i=0;i<Surface.getInstance().getPointsInU();i++){
baseIndex=i*Surface.getInstance().getPointsInV()*4+j*4;
gl.glVertex3f(ctrlpoints[baseIndex+0]/ctrlpoints[baseIndex+3],
@@ -268,7 +268,7 @@ public class GLListener implements GLEventListener {
gl.glColor3f(0,0,1);
if(Surface.getInstance().getBodIndex()>=0){
gl.glPointSize(8);
- gl.glBegin(GL.GL_POINTS);
+ gl.glBegin(GL2.GL_POINTS);
int i=Surface.getInstance().getBodIndex();
gl.glVertex3d(ctrlpoints[i * 4]/ctrlpoints[i * 4 + 3], ctrlpoints[i * 4 + 1]/ctrlpoints[i * 4 + 3],
ctrlpoints[i * 4 + 2]/ctrlpoints[i * 4 + 3]);
@@ -284,7 +284,7 @@ public class GLListener implements GLEventListener {
public void reshape(GLAutoDrawable drawable, int x, int y, int width,
int height) {
gl.glViewport(0, 0, width, height);
- gl.glMatrixMode(GL.GL_PROJECTION);
+ gl.glMatrixMode(GL2.GL_PROJECTION);
gl.glLoadIdentity();
glu.gluPerspective(65.0, (double) width / height, 0.1, 1000.0);
// gl.glScalef(1, -1, 1);
diff --git a/src/demos/nurbs/surfaceapp/SurfaceApp.java b/src/demos/nurbs/surfaceapp/SurfaceApp.java
index 7f2a546..4018967 100755
--- a/src/demos/nurbs/surfaceapp/SurfaceApp.java
+++ b/src/demos/nurbs/surfaceapp/SurfaceApp.java
@@ -9,10 +9,8 @@ import java.awt.event.ActionListener;
import java.awt.event.MouseAdapter;
import java.awt.event.MouseEvent;
-import javax.media.opengl.GLCanvas;
import javax.swing.AbstractAction;
import javax.swing.ButtonGroup;
-import javax.swing.ImageIcon;
import javax.swing.JButton;
import javax.swing.JCheckBox;
import javax.swing.JFrame;
@@ -33,6 +31,7 @@ import javax.swing.ToolTipManager;
import demos.nurbs.icons.*;
import demos.nurbs.knotslidercomponent.JKnotSlider;
+import javax.media.opengl.awt.GLCanvas;
/**
* Main class for application demostrating capabilitues of JOGL library extend by NURBS surface functionalities
diff --git a/src/demos/particles/engine/Engine.java b/src/demos/particles/engine/Engine.java
index 62a6237..2b60175 100755
--- a/src/demos/particles/engine/Engine.java
+++ b/src/demos/particles/engine/Engine.java
@@ -68,7 +68,7 @@ public class Engine {
particles.remove(particles.size()-1);
}
- public void draw(GL gl) {
+ public void draw(GL2 gl) {
gl.glClear(GL.GL_COLOR_BUFFER_BIT | GL.GL_DEPTH_BUFFER_BIT);
gl.glLoadIdentity();
diff --git a/src/demos/particles/engine/GLComponent.java b/src/demos/particles/engine/GLComponent.java
index 299578f..ddde39e 100755
--- a/src/demos/particles/engine/GLComponent.java
+++ b/src/demos/particles/engine/GLComponent.java
@@ -38,9 +38,9 @@ package demos.particles.engine;
import javax.media.opengl.*;
import javax.media.opengl.glu.*;
-import com.sun.opengl.util.*;
+import javax.media.opengl.awt.*;
-import java.io.*;
+import javax.media.opengl.util.FPSAnimator;
public class GLComponent extends GLCanvas implements GLEventListener {
@@ -70,7 +70,7 @@ public class GLComponent extends GLCanvas implements GLEventListener {
}
public void display(GLAutoDrawable drawable) {
- final GL gl = drawable.getGL();
+ final GL2 gl = drawable.getGL().getGL2();
engine.draw(gl);
}
@@ -94,9 +94,9 @@ public class GLComponent extends GLCanvas implements GLEventListener {
gl.glEnable(GL.GL_BLEND);
gl.glBlendFunc(GL.GL_SRC_ALPHA, GL.GL_ONE);
// Get nice perspective calculations.
- gl.glHint(GL.GL_PERSPECTIVE_CORRECTION_HINT, GL.GL_NICEST);
+ gl.glHint(GL2.GL_PERSPECTIVE_CORRECTION_HINT, GL2.GL_NICEST);
// Nice point smoothing.
- gl.glHint(GL.GL_POINT_SMOOTH_HINT, GL.GL_NICEST);
+ gl.glHint(GL2.GL_POINT_SMOOTH_HINT, GL2.GL_NICEST);
// Enable texture mapping.
gl.glEnable(GL.GL_TEXTURE_2D);
diff --git a/src/demos/particles/engine/Particle.java b/src/demos/particles/engine/Particle.java
index 82e0756..ad4955e 100755
--- a/src/demos/particles/engine/Particle.java
+++ b/src/demos/particles/engine/Particle.java
@@ -56,12 +56,12 @@ public class Particle {
(float)Math.random());
}
- public void draw(GL gl, Texture texture, RGBA tendToColor) {
+ public void draw(GL2 gl, Texture texture, RGBA tendToColor) {
adjust(tendToColor);
texture.bind();
gl.glColor4f(rgba.r,rgba.g,rgba.b,rgba.a);
- gl.glBegin(GL.GL_QUADS);
+ gl.glBegin(GL2.GL_QUADS);
gl.glTexCoord2f(0.0f, 0.0f); gl.glVertex3f(currentPos.x, currentPos.y-2, currentPos.z);
gl.glTexCoord2f(1.0f, 0.0f); gl.glVertex3f(currentPos.x+2, currentPos.y-2, currentPos.z);
gl.glTexCoord2f(1.0f, 1.0f); gl.glVertex3f(currentPos.x+2, currentPos.y, currentPos.z);
diff --git a/src/demos/printext/PrintExt.java b/src/demos/printext/PrintExt.java
index fa76031..0d5e101 100755
--- a/src/demos/printext/PrintExt.java
+++ b/src/demos/printext/PrintExt.java
@@ -5,8 +5,13 @@
package demos.printext;
-import java.awt.*;
-import javax.media.opengl.*;
+import java.awt.Frame;
+import javax.media.opengl.GL;
+import javax.media.opengl.GLAutoDrawable;
+import javax.media.opengl.GLEventListener;
+import javax.media.opengl.awt.GLCanvas;
+
+
public class PrintExt {
public static void main(String[] args) {
diff --git a/src/demos/proceduralTexturePhysics/ProceduralTexturePhysics.java b/src/demos/proceduralTexturePhysics/ProceduralTexturePhysics.java
index e20d811..774885a 100644
--- a/src/demos/proceduralTexturePhysics/ProceduralTexturePhysics.java
+++ b/src/demos/proceduralTexturePhysics/ProceduralTexturePhysics.java
@@ -30,19 +30,33 @@
* EVEN IF NVIDIA HAS BEEN ADVISED OF THE POSSIBILITY OF SUCH DAMAGES.
*
*/
-
package demos.proceduralTexturePhysics;
-import java.awt.*;
-import java.awt.event.*;
-import javax.swing.*;
-
-import javax.media.opengl.*;
-import com.sun.opengl.util.*;
-import demos.common.*;
-import demos.util.*;
-import gleem.*;
-import gleem.linalg.*;
+import demos.common.Demo;
+import demos.common.DemoListener;
+import demos.util.DurationTimer;
+import gleem.BSphere;
+import gleem.BSphereProvider;
+import gleem.CameraParameters;
+import gleem.ExaminerViewer;
+import gleem.ManipManager;
+import gleem.MouseButtonHelper;
+import gleem.linalg.Vec3f;
+import java.awt.BorderLayout;
+import java.awt.Frame;
+import java.awt.event.KeyAdapter;
+import java.awt.event.KeyEvent;
+import java.awt.event.MouseAdapter;
+import java.awt.event.MouseEvent;
+import java.awt.event.MouseMotionAdapter;
+import java.awt.event.WindowAdapter;
+import java.awt.event.WindowEvent;
+import javax.media.opengl.GL;
+import javax.media.opengl.GLAutoDrawable;
+import javax.media.opengl.GLException;
+import javax.media.opengl.awt.GLCanvas;
+import javax.media.opengl.util.Animator;
+import javax.swing.JOptionPane;
/**
* Water demonstration by NVidia Corporation - <a href =
@@ -57,325 +71,341 @@ import gleem.linalg.*;
* Ported to Java and ARB_fragment_program by Kenneth Russell
*
*/
-
public class ProceduralTexturePhysics extends Demo {
- public static void main(String[] args) {
- GLCanvas canvas = new GLCanvas();
- ProceduralTexturePhysics demo = new ProceduralTexturePhysics();
- canvas.addGLEventListener(demo);
-
- final Animator animator = new Animator(canvas);
- demo.setDemoListener(new DemoListener() {
- public void shutdownDemo() {
- runExit(animator);
- }
- public void repaint() {}
- });
-
- Frame frame = new Frame("Procedural Texture Waves");
- frame.setLayout(new BorderLayout());
- canvas.setSize(512, 512);
- frame.add(canvas, BorderLayout.CENTER);
- frame.pack();
- frame.show();
- canvas.requestFocus();
-
- frame.addWindowListener(new WindowAdapter() {
- public void windowClosing(WindowEvent e) {
- runExit(animator);
- }
- });
-
- animator.start();
- }
-
- //----------------------------------------------------------------------
- // Internals only below this point
- //
-
- public void shutdownDemo() {
- viewer.detach();
- ManipManager.getManipManager().unregisterWindow(drawable);
- drawable.removeGLEventListener(this);
- super.shutdownDemo();
- }
-
- private volatile boolean drawing;
- private volatile int mousePosX;
- private volatile int mousePosY;
-
- private GLAutoDrawable drawable;
- private Water water = new Water();
- private volatile ExaminerViewer viewer;
- private boolean[] b = new boolean[256];
- private boolean doViewAll = true;
- private float zNear = 0.1f;
- private float zFar = 10.0f;
-
- private DurationTimer timer = new DurationTimer();
- private boolean firstRender = true;
- private int frameCount;
-
- private float blurIncrement = 0.01f;
- private float bumpIncrement = 0.01f;
- private float frequencyIncrement = 0.1f;
-
- public void init(GLAutoDrawable drawable) {
- water.destroy();
- water.initialize("demos/data/images/nvfixed.tga",
- "demos/data/images/nvspin.tga",
- "demos/data/images/droplet.tga",
- "demos/data/cubemaps/CloudyHills_",
- "tga",
- drawable);
-
- GL gl = drawable.getGL();
- gl.setSwapInterval(1);
-
- try {
- checkExtension(gl, "GL_VERSION_1_3"); // For multitexture
- checkExtension(gl, "GL_ARB_vertex_program");
- checkExtension(gl, "GL_ARB_fragment_program");
- checkExtension(gl, "GL_ARB_pbuffer");
- checkExtension(gl, "GL_ARB_pixel_format");
- } catch (GLException e) {
- e.printStackTrace();
- throw(e);
- }
-
- gl.glClearColor(0, 0.2f, 0.5f, 0);
- gl.glDisable(GL.GL_LIGHTING);
- gl.glDisable(GL.GL_DEPTH_TEST);
- gl.glDisable(GL.GL_CULL_FACE);
-
- doViewAll = true;
-
- if (firstRender) {
- firstRender = false;
-
- // Register the window with the ManipManager
- ManipManager manager = ManipManager.getManipManager();
- manager.registerWindow(drawable);
- this.drawable = drawable;
-
- viewer = new ExaminerViewer(MouseButtonHelper.numMouseButtons());
- viewer.setAutoRedrawMode(false);
- viewer.attach(drawable, new BSphereProvider() {
- public BSphere getBoundingSphere() {
- return new BSphere(new Vec3f(0, 0, 0), 1.2f);
- }
+
+ private ProceduralTexturePhysics() {
+
+ GLCanvas canvas = new GLCanvas();
+ ProceduralTexturePhysics demo = new ProceduralTexturePhysics();
+ canvas.addGLEventListener(demo);
+
+ canvas.addKeyListener(new KeyAdapter() {
+
+ public void keyPressed(KeyEvent e) {
+ dispatchKey(e.getKeyChar());
+ }
});
- viewer.setVertFOV((float) (15.0f * Math.PI / 32.0f));
- viewer.setZNear(zNear);
- viewer.setZFar(zFar);
-
- drawable.addKeyListener(new KeyAdapter() {
- public void keyPressed(KeyEvent e) {
- dispatchKey(e.getKeyChar());
- }
+
+ canvas.addMouseListener(new MouseAdapter() {
+
+ public void mousePressed(MouseEvent e) {
+ if (e.getButton() == MouseEvent.BUTTON1 &&
+ !e.isAltDown() && !e.isMetaDown()) {
+ drawing = true;
+ }
+ }
+
+ public void mouseReleased(MouseEvent e) {
+ if (e.getButton() == MouseEvent.BUTTON1) {
+ drawing = false;
+ }
+ }
});
- drawable.addMouseListener(new MouseAdapter() {
- public void mousePressed(MouseEvent e) {
- if (e.getButton() == MouseEvent.BUTTON1 &&
- !e.isAltDown() && !e.isMetaDown()) {
- drawing = true;
+ canvas.addMouseMotionListener(new MouseMotionAdapter() {
+
+ public void mouseDragged(MouseEvent e) {
+ mousePosX = e.getX();
+ mousePosY = e.getY();
}
- }
+ });
+
+ final Animator animator = new Animator(canvas);
+ demo.setDemoListener(new DemoListener() {
- public void mouseReleased(MouseEvent e) {
- if (e.getButton() == MouseEvent.BUTTON1) {
- drawing = false;
+ public void shutdownDemo() {
+ runExit(animator);
+ }
+
+ public void repaint() {
}
- }
});
- drawable.addMouseMotionListener(new MouseMotionAdapter() {
- public void mouseDragged(MouseEvent e) {
- mousePosX = e.getX();
- mousePosY = e.getY();
- }
+ Frame frame = new Frame("Procedural Texture Waves");
+ frame.setLayout(new BorderLayout());
+ canvas.setSize(512, 512);
+ frame.add(canvas, BorderLayout.CENTER);
+ frame.pack();
+ frame.setVisible(true);
+ canvas.requestFocus();
+
+ frame.addWindowListener(new WindowAdapter() {
+
+ public void windowClosing(WindowEvent e) {
+ runExit(animator);
+ }
});
- timer.start();
+ animator.start();
}
- }
-
- public void display(GLAutoDrawable drawable) {
- if (++frameCount == 30) {
- timer.stop();
- System.err.println("Frames per second: " + (30.0f / timer.getDurationAsSeconds()));
- timer.reset();
- timer.start();
- frameCount = 0;
+
+ public void shutdownDemo() {
+ viewer.detach();
+ ManipManager.getManipManager().unregisterWindow(drawable);
+ drawable.removeGLEventListener(this);
+ super.shutdownDemo();
}
+ private volatile boolean drawing;
+ private volatile int mousePosX;
+ private volatile int mousePosY;
+ private GLAutoDrawable drawable;
+ private Water water = new Water();
+ private volatile ExaminerViewer viewer;
+ private boolean[] b = new boolean[256];
+ private boolean doViewAll = true;
+ private float zNear = 0.1f;
+ private float zFar = 10.0f;
+ private DurationTimer timer = new DurationTimer();
+ private boolean firstRender = true;
+ private int frameCount;
+ private float blurIncrement = 0.01f;
+ private float bumpIncrement = 0.01f;
+ private float frequencyIncrement = 0.1f;
+
+ public void init(GLAutoDrawable drawable) {
+ water.destroy();
+ water.initialize("demos/data/images/nvfixed.tga",
+ "demos/data/images/nvspin.tga",
+ "demos/data/images/droplet.tga",
+ "demos/data/cubemaps/CloudyHills_",
+ "tga",
+ drawable);
+
+ GL gl = drawable.getGL();
+ gl.setSwapInterval(1);
+
+ try {
+ checkExtension(gl, "GL_VERSION_1_3"); // For multitexture
+ checkExtension(gl, "GL_ARB_vertex_program");
+ checkExtension(gl, "GL_ARB_fragment_program");
+ checkExtension(gl, "GL_ARB_pbuffer");
+ checkExtension(gl, "GL_ARB_pixel_format");
+ } catch (GLException e) {
+ e.printStackTrace();
+ throw (e);
+ }
- GL gl = drawable.getGL();
+ gl.glClearColor(0, 0.2f, 0.5f, 0);
+ gl.glDisable(GL.GL_LIGHTING);
+ gl.glDisable(GL.GL_DEPTH_TEST);
+ gl.glDisable(GL.GL_CULL_FACE);
- gl.glClear(GL.GL_COLOR_BUFFER_BIT | GL.GL_DEPTH_BUFFER_BIT);
+ doViewAll = true;
- if (doViewAll) {
- viewer.viewAll(gl);
- doViewAll = false;
- }
+ if (firstRender) {
+ firstRender = false;
+
+ // Register the window with the ManipManager
+ ManipManager manager = ManipManager.getManipManager();
+ manager.registerWindow(drawable);
+ this.drawable = drawable;
+
+ viewer = new ExaminerViewer(MouseButtonHelper.numMouseButtons());
+ viewer.setAutoRedrawMode(false);
+ viewer.attach(drawable, new BSphereProvider() {
- viewer.update(gl);
- ManipManager.getManipManager().updateCameraParameters(drawable, viewer.getCameraParameters());
- ManipManager.getManipManager().render(drawable, gl);
+ public BSphere getBoundingSphere() {
+ return new BSphere(new Vec3f(0, 0, 0), 1.2f);
+ }
+ });
+ viewer.setVertFOV((float) (15.0f * Math.PI / 32.0f));
+ viewer.setZNear(zNear);
+ viewer.setZFar(zFar);
- if (drawing) {
- int w = drawable.getWidth();
- int h = drawable.getHeight();
- water.addDroplet(new Water.Droplet( 2 * (mousePosX / (float) w - 0.5f),
- -2 * (mousePosY / (float) h - 0.5f),
- 0.08f));
+ timer.start();
+ }
}
- water.tick();
- CameraParameters params = viewer.getCameraParameters();
- water.draw(gl, params.getOrientation().inverse());
- }
+ public void display(GLAutoDrawable drawable) {
+ if (++frameCount == 30) {
+ timer.stop();
+ System.err.println("Frames per second: " + (30.0f / timer.getDurationAsSeconds()));
+ timer.reset();
+ timer.start();
+ frameCount = 0;
+ }
- public void reshape(GLAutoDrawable drawable, int x, int y, int width, int height) {}
+ GL gl = drawable.getGL();
- // Unused routines
- public void displayChanged(GLAutoDrawable drawable, boolean modeChanged, boolean deviceChanged) {}
+ gl.glClear(GL.GL_COLOR_BUFFER_BIT | GL.GL_DEPTH_BUFFER_BIT);
- private void setFlag(char key, boolean val) {
- b[((int) key) & 0xFF] = val;
- }
+ if (doViewAll) {
+ viewer.viewAll(gl);
+ doViewAll = false;
+ }
- private boolean getFlag(char key) {
- return b[((int) key) & 0xFF];
- }
+ viewer.update(gl);
+ ManipManager.getManipManager().updateCameraParameters(drawable, viewer.getCameraParameters());
+ ManipManager.getManipManager().render(drawable, gl);
- private void checkExtension(GL gl, String extensionName) {
- if (!gl.isExtensionAvailable(extensionName)) {
- String message = "Unable to initialize " + extensionName + " OpenGL extension";
- JOptionPane.showMessageDialog(null, message, "Unavailable extension", JOptionPane.ERROR_MESSAGE);
- shutdownDemo();
+ if (drawing) {
+ int w = drawable.getWidth();
+ int h = drawable.getHeight();
+ water.addDroplet(new Water.Droplet(2 * (mousePosX / (float) w - 0.5f),
+ -2 * (mousePosY / (float) h - 0.5f),
+ 0.08f));
+ }
+ water.tick();
+
+ CameraParameters params = viewer.getCameraParameters();
+ water.draw(gl, params.getOrientation().inverse());
+ }
+
+ public void reshape(GLAutoDrawable drawable, int x, int y, int width, int height) {
}
- }
-
- private void dispatchKey(char k) {
- setFlag(k, !getFlag(k));
-
- switch (k) {
- case 27:
- case 'q':
- shutdownDemo();
- break;
- case 'w':
- water.enableWireframe(getFlag('w'));
- break;
- case 'd':
- // FIXME
- /*
- if (getKey('d')) {
- glutMouseFunc(glh::glut_mouse_function);
- glutMotionFunc(glh::glut_motion_function);
- }
- else
- {
- glutMouseFunc(Mouse);
- glutMotionFunc(Motion);
- }
- */
- break;
- case ' ':
- water.enableAnimation(getFlag(' '));
- break;
- case 'b':
- water.enableBorderWrapping(getFlag('b'));
- break;
- case 'n':
- water.singleStep();
- break;
- case 's':
- water.enableSlowAnimation(getFlag('s'));
- break;
- case '1':
- water.setRenderMode(Water.CA_FULLSCREEN_REFLECT);
- break;
- case '2':
- water.setRenderMode(Water.CA_FULLSCREEN_HEIGHT);
- break;
- case '3':
- water.setRenderMode(Water.CA_FULLSCREEN_FORCE);
- break;
- case '4':
- water.setRenderMode(Water.CA_FULLSCREEN_NORMALMAP);
- break;
- case '5':
- water.setRenderMode(Water.CA_TILED_THREE_WINDOWS);
- break;
- case 'r':
- water.reset();
- break;
- case 'i':
- // FIXME: make sure this is what this does
- doViewAll = true;
- // gluPerspective(90, 1, .01, 10);
- break;
- case 'c': {
- float dist = water.getBlurDistance();
- if (dist > blurIncrement)
- water.setBlurDistance(dist - blurIncrement);
- break;
+ // Unused routines
+ public void displayChanged(GLAutoDrawable drawable, boolean modeChanged, boolean deviceChanged) {
}
- case 'v': {
- float dist = water.getBlurDistance();
- if (dist < 1)
- water.setBlurDistance(dist + blurIncrement);
- break;
+
+ private void setFlag(char key, boolean val) {
+ b[((int) key) & 0xFF] = val;
}
- case '-': {
- float scale = water.getBumpScale();
- if (scale > -1)
- water.setBumpScale(scale - bumpIncrement);
- break;
+
+ private boolean getFlag(char key) {
+ return b[((int) key) & 0xFF];
}
- case '=': {
- float scale = water.getBumpScale();
- if (scale < 1)
- water.setBumpScale(scale + bumpIncrement);
- break;
+
+ private void checkExtension(GL gl, String extensionName) {
+ if (!gl.isExtensionAvailable(extensionName)) {
+ String message = "Unable to initialize " + extensionName + " OpenGL extension";
+ JOptionPane.showMessageDialog(null, message, "Unavailable extension", JOptionPane.ERROR_MESSAGE);
+ shutdownDemo();
+ }
}
- case 'l':
- water.enableBoundaryApplication(getFlag('l'));
- break;
- case 'o':
- water.enableSpinningLogo(getFlag('o'));
- break;
- case '.': {
- float frequency = water.getBumpScale();
- if (frequency < 1)
- water.setDropFrequency(frequency + frequencyIncrement);
- break;
+
+ private void dispatchKey(char k) {
+ setFlag(k, !getFlag(k));
+
+ switch (k) {
+ case 27:
+ case 'q':
+ shutdownDemo();
+ break;
+ case 'w':
+ water.enableWireframe(getFlag('w'));
+ break;
+ case 'd':
+ // FIXME
+ /*
+
+ if (getKey('d')) {
+ glutMouseFunc(glh::glut_mouse_function);
+ glutMotionFunc(glh::glut_motion_function);
+ }
+ else
+ {
+ glutMouseFunc(Mouse);
+ glutMotionFunc(Motion);
+ }
+ */
+ break;
+ case ' ':
+ water.enableAnimation(getFlag(' '));
+ break;
+ case 'b':
+ water.enableBorderWrapping(getFlag('b'));
+ break;
+ case 'n':
+ water.singleStep();
+ break;
+ case 's':
+ water.enableSlowAnimation(getFlag('s'));
+ break;
+ case '1':
+ water.setRenderMode(Water.CA_FULLSCREEN_REFLECT);
+ break;
+ case '2':
+ water.setRenderMode(Water.CA_FULLSCREEN_HEIGHT);
+ break;
+ case '3':
+ water.setRenderMode(Water.CA_FULLSCREEN_FORCE);
+ break;
+ case '4':
+ water.setRenderMode(Water.CA_FULLSCREEN_NORMALMAP);
+ break;
+ case '5':
+ water.setRenderMode(Water.CA_TILED_THREE_WINDOWS);
+ break;
+ case 'r':
+ water.reset();
+ break;
+ case 'i':
+ // FIXME: make sure this is what this does
+ doViewAll = true;
+ // gluPerspective(90, 1, .01, 10);
+ break;
+ case 'c': {
+ float dist = water.getBlurDistance();
+ if (dist > blurIncrement) {
+ water.setBlurDistance(dist - blurIncrement);
+ }
+ break;
+ }
+ case 'v': {
+ float dist = water.getBlurDistance();
+ if (dist < 1) {
+ water.setBlurDistance(dist + blurIncrement);
+ }
+ break;
+ }
+ case '-': {
+ float scale = water.getBumpScale();
+ if (scale > -1) {
+ water.setBumpScale(scale - bumpIncrement);
+ }
+ break;
+ }
+ case '=': {
+ float scale = water.getBumpScale();
+ if (scale < 1) {
+ water.setBumpScale(scale + bumpIncrement);
+ }
+ break;
+ }
+ case 'l':
+ water.enableBoundaryApplication(getFlag('l'));
+ break;
+ case 'o':
+ water.enableSpinningLogo(getFlag('o'));
+ break;
+ case '.': {
+ float frequency = water.getBumpScale();
+ if (frequency < 1) {
+ water.setDropFrequency(frequency + frequencyIncrement);
+ }
+ break;
+ }
+ case ',': {
+ float frequency = water.getBumpScale();
+ if (frequency > 0) {
+ water.setDropFrequency(frequency - frequencyIncrement);
+ }
+ break;
+ }
+ default:
+ break;
+ }
}
- case ',': {
- float frequency = water.getBumpScale();
- if (frequency > 0)
- water.setDropFrequency(frequency - frequencyIncrement);
- break;
+
+ private static void runExit(final Animator animator) {
+ // Note: calling System.exit() synchronously inside the draw,
+ // reshape or init callbacks can lead to deadlocks on certain
+ // platforms (in particular, X11) because the JAWT's locking
+ // routines cause a global AWT lock to be grabbed. Run the
+ // exit routine in another thread.
+ new Thread(new Runnable() {
+
+ public void run() {
+ animator.stop();
+ System.exit(0);
+ }
+ }).start();
}
- default:
- break;
+
+
+
+ public static void main(String[] args) {
+ new ProceduralTexturePhysics();
}
- }
-
- private static void runExit(final Animator animator) {
- // Note: calling System.exit() synchronously inside the draw,
- // reshape or init callbacks can lead to deadlocks on certain
- // platforms (in particular, X11) because the JAWT's locking
- // routines cause a global AWT lock to be grabbed. Run the
- // exit routine in another thread.
- new Thread(new Runnable() {
- public void run() {
- animator.stop();
- System.exit(0);
- }
- }).start();
- }
}
diff --git a/src/demos/proceduralTexturePhysics/Water.java b/src/demos/proceduralTexturePhysics/Water.java
index 50be158..566b848 100644
--- a/src/demos/proceduralTexturePhysics/Water.java
+++ b/src/demos/proceduralTexturePhysics/Water.java
@@ -33,19 +33,28 @@
package demos.proceduralTexturePhysics;
-import java.awt.Image;
-import java.awt.image.*;
-import java.io.*;
-import java.nio.*;
-import java.text.*;
-import java.util.*;
-
-import gleem.linalg.*;
-import javax.media.opengl.*;
-import javax.media.opengl.glu.*;
-import com.sun.opengl.util.*;
-import com.sun.opengl.util.texture.*;
-import demos.util.*;
+import com.sun.opengl.impl.io.FileUtil;
+import com.sun.opengl.util.texture.Texture;
+import com.sun.opengl.util.texture.TextureData;
+import com.sun.opengl.util.texture.TextureIO;
+import demos.util.Cubemap;
+import gleem.linalg.Mat4f;
+import gleem.linalg.Rotf;
+import java.io.IOException;
+import java.util.ArrayList;
+import java.util.Iterator;
+import java.util.List;
+import javax.media.opengl.GL;
+import javax.media.opengl.GL2;
+import javax.media.opengl.GLAutoDrawable;
+import javax.media.opengl.GLCapabilities;
+import javax.media.opengl.GLDrawableFactory;
+import javax.media.opengl.GLEventListener;
+import javax.media.opengl.GLException;
+import javax.media.opengl.GLPbuffer;
+import javax.media.opengl.glu.GLU;
+
+
/**
* Auxiliary Water simulation class used by ProceduralTexturePhysics
@@ -226,22 +235,22 @@ public class Water {
pbuffer.display();
}
- public void draw(GL gl, Rotf cameraOrientation) {
+ public void draw(GL2 gl, Rotf cameraOrientation) {
this.cameraOrientation.set(cameraOrientation);
if (skipCount >= skipInterval && renderMode != CA_DO_NOT_RENDER) {
skipCount = 0;
// Display the results of the rendering to texture
if (wireframe) {
- gl.glPolygonMode(GL.GL_FRONT_AND_BACK, GL.GL_LINE);
+ gl.glPolygonMode(GL2.GL_FRONT_AND_BACK, GL2.GL_LINE);
// chances are the texture will be all dark, so lets not use a texture
- gl.glDisable(GL.GL_TEXTURE_2D);
+ gl.glDisable(GL2.GL_TEXTURE_2D);
} else {
- gl.glPolygonMode(GL.GL_FRONT_AND_BACK, GL.GL_FILL);
+ gl.glPolygonMode(GL2.GL_FRONT_AND_BACK, GL2.GL_FILL);
- gl.glActiveTexture(GL.GL_TEXTURE0);
- gl.glEnable(GL.GL_TEXTURE_2D);
+ gl.glActiveTexture(GL2.GL_TEXTURE0);
+ gl.glEnable(GL2.GL_TEXTURE_2D);
}
switch (renderMode) {
@@ -259,51 +268,51 @@ public class Water {
gl.glCallList(displayListIDs[CA_FRAGMENT_PROGRAM_REFLECT]);
// Draw quad over full display
- gl.glActiveTexture(GL.GL_TEXTURE0);
+ gl.glActiveTexture(GL2.GL_TEXTURE0);
dynamicTextures[CA_TEXTURE_NORMAL_MAP].bind();
dynamicTextures[CA_TEXTURE_NORMAL_MAP].disable();
- gl.glActiveTexture(GL.GL_TEXTURE3);
+ gl.glActiveTexture(GL2.GL_TEXTURE3);
cubemap.bind();
cubemap.enable();
gl.glColor4f(1, 1, 1, 1);
- gl.glBegin(GL.GL_QUADS);
+ gl.glBegin(GL2.GL_QUADS);
- gl.glMultiTexCoord2f(GL.GL_TEXTURE0, 0,0);
- gl.glMultiTexCoord4f(GL.GL_TEXTURE1, matRot.get(0,0), matRot.get(0,1), matRot.get(0,2), 1);
- gl.glMultiTexCoord4f(GL.GL_TEXTURE2, matRot.get(1,0), matRot.get(1,1), matRot.get(1,2), 1);
- gl.glMultiTexCoord4f(GL.GL_TEXTURE3, matRot.get(2,0), matRot.get(2,1), matRot.get(2,2), 1);
+ gl.glMultiTexCoord2f(GL2.GL_TEXTURE0, 0,0);
+ gl.glMultiTexCoord4f(GL2.GL_TEXTURE1, matRot.get(0,0), matRot.get(0,1), matRot.get(0,2), 1);
+ gl.glMultiTexCoord4f(GL2.GL_TEXTURE2, matRot.get(1,0), matRot.get(1,1), matRot.get(1,2), 1);
+ gl.glMultiTexCoord4f(GL2.GL_TEXTURE3, matRot.get(2,0), matRot.get(2,1), matRot.get(2,2), 1);
gl.glVertex2f(-1,-1);
- gl.glMultiTexCoord2f(GL.GL_TEXTURE0, 1,0);
- gl.glMultiTexCoord4f(GL.GL_TEXTURE1, matRot.get(0,0), matRot.get(0,1), matRot.get(0,2), -1);
- gl.glMultiTexCoord4f(GL.GL_TEXTURE2, matRot.get(1,0), matRot.get(1,1), matRot.get(1,2), 1);
- gl.glMultiTexCoord4f(GL.GL_TEXTURE3, matRot.get(2,0), matRot.get(2,1), matRot.get(2,2), 1);
+ gl.glMultiTexCoord2f(GL2.GL_TEXTURE0, 1,0);
+ gl.glMultiTexCoord4f(GL2.GL_TEXTURE1, matRot.get(0,0), matRot.get(0,1), matRot.get(0,2), -1);
+ gl.glMultiTexCoord4f(GL2.GL_TEXTURE2, matRot.get(1,0), matRot.get(1,1), matRot.get(1,2), 1);
+ gl.glMultiTexCoord4f(GL2.GL_TEXTURE3, matRot.get(2,0), matRot.get(2,1), matRot.get(2,2), 1);
gl.glVertex2f( 1,-1);
- gl.glMultiTexCoord2f(GL.GL_TEXTURE0, 1,1);
- gl.glMultiTexCoord4f(GL.GL_TEXTURE1, matRot.get(0,0), matRot.get(0,1), matRot.get(0,2), -1);
- gl.glMultiTexCoord4f(GL.GL_TEXTURE2, matRot.get(1,0), matRot.get(1,1), matRot.get(1,2), -1);
- gl.glMultiTexCoord4f(GL.GL_TEXTURE3, matRot.get(2,0), matRot.get(2,1), matRot.get(2,2), 1);
+ gl.glMultiTexCoord2f(GL2.GL_TEXTURE0, 1,1);
+ gl.glMultiTexCoord4f(GL2.GL_TEXTURE1, matRot.get(0,0), matRot.get(0,1), matRot.get(0,2), -1);
+ gl.glMultiTexCoord4f(GL2.GL_TEXTURE2, matRot.get(1,0), matRot.get(1,1), matRot.get(1,2), -1);
+ gl.glMultiTexCoord4f(GL2.GL_TEXTURE3, matRot.get(2,0), matRot.get(2,1), matRot.get(2,2), 1);
gl.glVertex2f( 1, 1);
- gl.glMultiTexCoord2f(GL.GL_TEXTURE0, 0,1);
- gl.glMultiTexCoord4f(GL.GL_TEXTURE1, matRot.get(0,0), matRot.get(0,1), matRot.get(0,2), 1);
- gl.glMultiTexCoord4f(GL.GL_TEXTURE2, matRot.get(1,0), matRot.get(1,1), matRot.get(1,2), -1);
- gl.glMultiTexCoord4f(GL.GL_TEXTURE3, matRot.get(2,0), matRot.get(2,1), matRot.get(2,2), 1);
+ gl.glMultiTexCoord2f(GL2.GL_TEXTURE0, 0,1);
+ gl.glMultiTexCoord4f(GL2.GL_TEXTURE1, matRot.get(0,0), matRot.get(0,1), matRot.get(0,2), 1);
+ gl.glMultiTexCoord4f(GL2.GL_TEXTURE2, matRot.get(1,0), matRot.get(1,1), matRot.get(1,2), -1);
+ gl.glMultiTexCoord4f(GL2.GL_TEXTURE3, matRot.get(2,0), matRot.get(2,1), matRot.get(2,2), 1);
gl.glVertex2f(-1, 1);
gl.glEnd();
cubemap.disable();
- gl.glDisable(GL.GL_FRAGMENT_PROGRAM_ARB);
+ gl.glDisable(GL2.GL_FRAGMENT_PROGRAM);
break;
}
case CA_FULLSCREEN_NORMALMAP: {
// Draw quad over full display
- gl.glActiveTexture(GL.GL_TEXTURE0);
+ gl.glActiveTexture(GL2.GL_TEXTURE0);
dynamicTextures[CA_TEXTURE_NORMAL_MAP].bind();
gl.glCallList(displayListIDs[CA_DRAW_SCREEN_QUAD]);
@@ -312,8 +321,8 @@ public class Water {
case CA_FULLSCREEN_HEIGHT: {
// Draw quad over full display
- gl.glActiveTexture(GL.GL_TEXTURE0);
- gl.glBindTexture(GL.GL_TEXTURE_2D, texHeightOutput);
+ gl.glActiveTexture(GL2.GL_TEXTURE0);
+ gl.glBindTexture(GL2.GL_TEXTURE_2D, texHeightOutput);
gl.glCallList(displayListIDs[CA_DRAW_SCREEN_QUAD]);
break;
@@ -321,7 +330,7 @@ public class Water {
case CA_FULLSCREEN_FORCE: {
// Draw quad over full display
- gl.glActiveTexture(GL.GL_TEXTURE0);
+ gl.glActiveTexture(GL2.GL_TEXTURE0);
dynamicTextures[CA_TEXTURE_FORCE_TARGET].bind();
gl.glCallList(displayListIDs[CA_DRAW_SCREEN_QUAD]);
@@ -331,9 +340,9 @@ public class Water {
case CA_TILED_THREE_WINDOWS: {
// Draw quad over full display
// lower left
- gl.glActiveTexture(GL.GL_TEXTURE0);
+ gl.glActiveTexture(GL2.GL_TEXTURE0);
dynamicTextures[CA_TEXTURE_FORCE_TARGET].bind();
- gl.glMatrixMode(GL.GL_MODELVIEW);
+ gl.glMatrixMode(GL2.GL_MODELVIEW);
gl.glPushMatrix();
gl.glTranslatef(-0.5f, -0.5f, 0);
@@ -342,7 +351,7 @@ public class Water {
gl.glPopMatrix();
// lower right
- gl.glBindTexture(GL.GL_TEXTURE_2D, texVelocityOutput);
+ gl.glBindTexture(GL2.GL_TEXTURE_2D, texVelocityOutput);
gl.glPushMatrix();
gl.glTranslatef(0.5f, -0.5f, 0);
@@ -352,7 +361,7 @@ public class Water {
// upper left
dynamicTextures[CA_TEXTURE_NORMAL_MAP].bind();
- gl.glMatrixMode(GL.GL_MODELVIEW);
+ gl.glMatrixMode(GL2.GL_MODELVIEW);
gl.glPushMatrix();
gl.glTranslatef(-0.5f, 0.5f, 0);
@@ -361,8 +370,8 @@ public class Water {
gl.glPopMatrix();
// upper right
- gl.glBindTexture(GL.GL_TEXTURE_2D, texHeightOutput);
- gl.glMatrixMode(GL.GL_MODELVIEW);
+ gl.glBindTexture(GL2.GL_TEXTURE_2D, texHeightOutput);
+ gl.glMatrixMode(GL2.GL_MODELVIEW);
gl.glPushMatrix();
gl.glTranslatef(0.5f, 0.5f, 0);
@@ -426,14 +435,16 @@ public class Water {
//
class Listener implements GLEventListener {
+
public void init(GLAutoDrawable drawable) {
- GL gl = drawable.getGL();
+ GL2 gl = drawable.getGL().getGL2();
initOpenGL(gl);
}
public void display(GLAutoDrawable drawable) {
- GL gl = drawable.getGL();
+
+ GL2 gl = drawable.getGL().getGL2();
if (mustUpdateBlurOffsets) {
updateBlurVertOffset(gl);
mustUpdateBlurOffsets = false;
@@ -442,7 +453,7 @@ public class Water {
// Take a single step in the cellular automaton
// Disable culling
- gl.glDisable(GL.GL_CULL_FACE);
+ gl.glDisable(GL2.GL_CULL_FACE);
if (reset) {
reset = false;
@@ -488,7 +499,7 @@ public class Water {
initialMapDimensions[1] = initialMapData.getHeight();
}
- private void initOpenGL(GL gl) {
+ private void initOpenGL(GL2 gl) {
try {
loadTextures(gl, tmpSpinFilename, tmpDropletFilename, tmpCubeMapFilenamePrefix, tmpCubeMapFilenameSuffix);
} catch (IOException e) {
@@ -499,30 +510,30 @@ public class Water {
tmpCubeMapFilenamePrefix = null;
tmpCubeMapFilenameSuffix = null;
- gl.glMatrixMode(GL.GL_MODELVIEW);
+ gl.glMatrixMode(GL2.GL_MODELVIEW);
gl.glLoadIdentity();
- gl.glMatrixMode(GL.GL_PROJECTION);
+ gl.glMatrixMode(GL2.GL_PROJECTION);
gl.glLoadIdentity();
glu.gluOrtho2D(-1, 1, -1, 1);
gl.glClearColor(0, 0, 0, 0);
- gl.glDisable(GL.GL_LIGHTING);
- gl.glDisable(GL.GL_DEPTH_TEST);
+ gl.glDisable(GL2.GL_LIGHTING);
+ gl.glDisable(GL2.GL_DEPTH_TEST);
createAndWriteUVOffsets(gl, initialMapDimensions[0], initialMapDimensions[1]);
- checkExtension(gl, "GL_ARB_vertex_program");
- checkExtension(gl, "GL_ARB_fragment_program");
- checkExtension(gl, "GL_ARB_multitexture");
+ checkExtension(gl, "GL_vertex_program");
+ checkExtension(gl, "GL_fragment_program");
+ checkExtension(gl, "GL_multitexture");
///////////////////////////////////////////////////////////////////////////
// UV Offset Vertex Program
///////////////////////////////////////////////////////////////////////////
int[] tmpInt = new int[1];
- gl.glGenProgramsARB(1, tmpInt, 0);
+ gl.glGenPrograms(1, tmpInt, 0);
vertexProgramID = tmpInt[0];
- gl.glBindProgramARB(GL.GL_VERTEX_PROGRAM_ARB, vertexProgramID);
+ gl.glBindProgram(GL2.GL_VERTEX_PROGRAM, vertexProgramID);
String programBuffer =
"!!ARBvp1.0\n" +
@@ -600,9 +611,9 @@ public class Water {
// set up constants (not currently used in the vertex program, though)
float[] rCVConsts = new float[] { 0, 0.5f, 1.0f, 2.0f };
- gl.glProgramEnvParameter4fvARB(GL.GL_VERTEX_PROGRAM_ARB, CV_CONSTS_1, rCVConsts, 0);
+ gl.glProgramEnvParameter4fv(GL2.GL_VERTEX_PROGRAM, CV_CONSTS_1, rCVConsts, 0);
- loadProgram(gl, GL.GL_VERTEX_PROGRAM_ARB, programBuffer);
+ loadProgram(gl, GL2.GL_VERTEX_PROGRAM, programBuffer);
///////////////////////////////////////////////////////////////////////////
// fragment program setup for equal weight combination of texels
@@ -650,9 +661,9 @@ public class Water {
// display list to render a single screen space quad.
///////////////////////////////////////////////////////////////////////////
displayListIDs[CA_DRAW_SCREEN_QUAD] = gl.glGenLists(1);
- gl.glNewList(displayListIDs[CA_DRAW_SCREEN_QUAD], GL.GL_COMPILE);
+ gl.glNewList(displayListIDs[CA_DRAW_SCREEN_QUAD], GL2.GL_COMPILE);
gl.glColor4f(1, 1, 1, 1);
- gl.glBegin(GL.GL_TRIANGLE_STRIP);
+ gl.glBegin(GL2.GL_TRIANGLE_STRIP);
gl.glTexCoord2f(0, 1); gl.glVertex2f(-1, 1);
gl.glTexCoord2f(0, 0); gl.glVertex2f(-1, -1);
gl.glTexCoord2f(1, 1); gl.glVertex2f( 1, 1);
@@ -667,7 +678,7 @@ public class Water {
}
}
- private void doSingleTimeStep(GL gl) {
+ private void doSingleTimeStep(GL2 gl) {
int temp;
// Swap texture source & target indices & pointers
@@ -684,14 +695,14 @@ public class Water {
// Clear initial velocity texture to 0x80 == gray
gl.glClearColor(0.5f, 0.5f, 0.5f, 1.0f);
- gl.glClear(GL.GL_COLOR_BUFFER_BIT);
+ gl.glClear(GL2.GL_COLOR_BUFFER_BIT);
// Now we need to copy the resulting pixels into the intermediate force field texture
- gl.glActiveTexture(GL.GL_TEXTURE0);
- gl.glBindTexture(GL.GL_TEXTURE_2D, texVelocityInput);
+ gl.glActiveTexture(GL2.GL_TEXTURE0);
+ gl.glBindTexture(GL2.GL_TEXTURE_2D, texVelocityInput);
// use CopyTexSubImage for speed (even though we copy all of it) since we pre-allocated the texture
- gl.glCopyTexSubImage2D(GL.GL_TEXTURE_2D, 0, 0, 0, 0, 0, initialMapDimensions[0], initialMapDimensions[1]);
+ gl.glCopyTexSubImage2D(GL2.GL_TEXTURE_2D, 0, 0, 0, 0, 0, initialMapDimensions[0], initialMapDimensions[1]);
break;
@@ -718,7 +729,7 @@ public class Water {
}
// even if wireframe mode, render to texture as solid
- gl.glPolygonMode(GL.GL_FRONT_AND_BACK, GL.GL_FILL);
+ gl.glPolygonMode(GL2.GL_FRONT_AND_BACK, GL2.GL_FILL);
/////////////////////////////////////////////////////////////
// Render first 3 components of force from three neighbors
@@ -732,36 +743,36 @@ public class Water {
// set current source texture for stage 0 texture
for (int i = 0; i < 4; i++)
{
- gl.glActiveTexture(GL.GL_TEXTURE0 + i);
- gl.glBindTexture(GL.GL_TEXTURE_2D, texHeightInput);
- gl.glEnable(GL.GL_TEXTURE_2D);
+ gl.glActiveTexture(GL2.GL_TEXTURE0 + i);
+ gl.glBindTexture(GL2.GL_TEXTURE_2D, texHeightInput);
+ gl.glEnable(GL2.GL_TEXTURE_2D);
}
- int wrapMode = wrap ? GL.GL_REPEAT : GL.GL_CLAMP_TO_EDGE;
- gl.glTexParameteri(GL.GL_TEXTURE_2D, GL.GL_TEXTURE_WRAP_S, wrapMode);
- gl.glTexParameteri(GL.GL_TEXTURE_2D, GL.GL_TEXTURE_WRAP_T, wrapMode);
+ int wrapMode = wrap ? GL2.GL_REPEAT : GL2.GL_CLAMP_TO_EDGE;
+ gl.glTexParameteri(GL2.GL_TEXTURE_2D, GL2.GL_TEXTURE_WRAP_S, wrapMode);
+ gl.glTexParameteri(GL2.GL_TEXTURE_2D, GL2.GL_TEXTURE_WRAP_T, wrapMode);
// disable blending
- gl.glDisable(GL.GL_BLEND);
+ gl.glDisable(GL2.GL_BLEND);
// render using offset 1 (type 1 -- center + 3 of 4 nearest neighbors).
- gl.glProgramEnvParameter4fARB(GL.GL_VERTEX_PROGRAM_ARB, CV_UV_OFFSET_TO_USE, 1, 0, 0, 0);
+ gl.glProgramEnvParameter4f(GL2.GL_VERTEX_PROGRAM, CV_UV_OFFSET_TO_USE, 1, 0, 0, 0);
// bind the vertex program to be used for this step and the next one.
- gl.glBindProgramARB(GL.GL_VERTEX_PROGRAM_ARB, vertexProgramID);
- gl.glEnable(GL.GL_VERTEX_PROGRAM_ARB);
+ gl.glBindProgram(GL2.GL_VERTEX_PROGRAM, vertexProgramID);
+ gl.glEnable(GL2.GL_VERTEX_PROGRAM);
// render a screen quad. with texture coords doing difference of nearby texels for force calc.
gl.glCallList(displayListIDs[CA_DRAW_SCREEN_QUAD]);
- gl.glDisable(GL.GL_FRAGMENT_PROGRAM_ARB);
+ gl.glDisable(GL2.GL_FRAGMENT_PROGRAM);
// Now we need to copy the resulting pixels into the intermediate force field texture
- gl.glActiveTexture(GL.GL_TEXTURE2);
+ gl.glActiveTexture(GL2.GL_TEXTURE2);
dynamicTextures[CA_TEXTURE_FORCE_INTERMEDIATE].bind();
// use CopyTexSubImage for speed (even though we copy all of it) since we pre-allocated the texture
- gl.glCopyTexSubImage2D(GL.GL_TEXTURE_2D, 0, 0, 0, 0, 0, initialMapDimensions[0], initialMapDimensions[1]);
+ gl.glCopyTexSubImage2D(GL2.GL_TEXTURE_2D, 0, 0, 0, 0, 0, initialMapDimensions[0], initialMapDimensions[1]);
////////////////////////////////////////////////////////////////
// Now add in last component of force for the 4th neighbor
@@ -783,27 +794,27 @@ public class Water {
//; t2 = previous partial result texture sampled at center (result of last phase copied to texture)
//; t3 = not used (disable now)
- gl.glTexParameterf(GL.GL_TEXTURE_2D, GL.GL_TEXTURE_WRAP_S, wrapMode);
- gl.glTexParameterf(GL.GL_TEXTURE_2D, GL.GL_TEXTURE_WRAP_T, wrapMode);
+ gl.glTexParameterf(GL2.GL_TEXTURE_2D, GL2.GL_TEXTURE_WRAP_S, wrapMode);
+ gl.glTexParameterf(GL2.GL_TEXTURE_2D, GL2.GL_TEXTURE_WRAP_T, wrapMode);
- gl.glActiveTexture(GL.GL_TEXTURE3);
- gl.glDisable(GL.GL_TEXTURE_2D);
+ gl.glActiveTexture(GL2.GL_TEXTURE3);
+ gl.glDisable(GL2.GL_TEXTURE_2D);
// vertex program already bound.
// render using offset 2 (type 2 -- final nearest neighbor plus center of previous result).
- gl.glProgramEnvParameter4fARB(GL.GL_VERTEX_PROGRAM_ARB, CV_UV_OFFSET_TO_USE, 2, 0, 0, 0);
+ gl.glProgramEnvParameter4f(GL2.GL_VERTEX_PROGRAM, CV_UV_OFFSET_TO_USE, 2, 0, 0, 0);
// render a screen quad
gl.glCallList(displayListIDs[CA_DRAW_SCREEN_QUAD]);
- gl.glDisable(GL.GL_FRAGMENT_PROGRAM_ARB);
+ gl.glDisable(GL2.GL_FRAGMENT_PROGRAM);
// Now we need to copy the resulting pixels into the intermediate force field texture
- gl.glActiveTexture(GL.GL_TEXTURE1);
+ gl.glActiveTexture(GL2.GL_TEXTURE1);
dynamicTextures[CA_TEXTURE_FORCE_TARGET].bind();
// use CopyTexSubImage for speed (even though we copy all of it) since we pre-allocated the texture
- gl.glCopyTexSubImage2D(GL.GL_TEXTURE_2D, 0, 0, 0, 0, 0, initialMapDimensions[0], initialMapDimensions[1]);
+ gl.glCopyTexSubImage2D(GL2.GL_TEXTURE_2D, 0, 0, 0, 0, 0, initialMapDimensions[0], initialMapDimensions[1]);
/////////////////////////////////////////////////////////////////
// Apply the force with a scale factor to reduce it's magnitude.
@@ -812,23 +823,23 @@ public class Water {
gl.glCallList(displayListIDs[CA_FRAGMENT_PROGRAM_APPLY_FORCE]);
// use offsets of zero
- gl.glProgramEnvParameter4fARB(GL.GL_VERTEX_PROGRAM_ARB, CV_UV_OFFSET_TO_USE, 0, 0, 0, 0);
+ gl.glProgramEnvParameter4f(GL2.GL_VERTEX_PROGRAM, CV_UV_OFFSET_TO_USE, 0, 0, 0, 0);
// bind the vertex program to be used for this step and the next one.
- gl.glActiveTexture(GL.GL_TEXTURE0);
- gl.glBindTexture(GL.GL_TEXTURE_2D, texVelocityInput);
- gl.glActiveTexture(GL.GL_TEXTURE1);
+ gl.glActiveTexture(GL2.GL_TEXTURE0);
+ gl.glBindTexture(GL2.GL_TEXTURE_2D, texVelocityInput);
+ gl.glActiveTexture(GL2.GL_TEXTURE1);
dynamicTextures[CA_TEXTURE_FORCE_TARGET].bind();
- gl.glActiveTexture(GL.GL_TEXTURE2);
- gl.glDisable(GL.GL_TEXTURE_2D);
- gl.glActiveTexture(GL.GL_TEXTURE3);
- gl.glDisable(GL.GL_TEXTURE_2D);
+ gl.glActiveTexture(GL2.GL_TEXTURE2);
+ gl.glDisable(GL2.GL_TEXTURE_2D);
+ gl.glActiveTexture(GL2.GL_TEXTURE3);
+ gl.glDisable(GL2.GL_TEXTURE_2D);
// Draw the quad to add in force.
gl.glCallList(displayListIDs[CA_DRAW_SCREEN_QUAD]);
- gl.glDisable(GL.GL_FRAGMENT_PROGRAM_ARB);
+ gl.glDisable(GL2.GL_FRAGMENT_PROGRAM);
///////////////////////////////////////////////////////////////////
// With velocity texture selected, render new excitation droplets
@@ -851,36 +862,36 @@ public class Water {
}
// Now we need to copy the resulting pixels into the velocity texture
- gl.glActiveTexture(GL.GL_TEXTURE1);
- gl.glBindTexture(GL.GL_TEXTURE_2D, texVelocityOutput);
+ gl.glActiveTexture(GL2.GL_TEXTURE1);
+ gl.glBindTexture(GL2.GL_TEXTURE_2D, texVelocityOutput);
// use CopyTexSubImage for speed (even though we copy all of it) since we pre-allocated the texture
- gl.glCopyTexSubImage2D(GL.GL_TEXTURE_2D, 0, 0, 0, 0, 0, initialMapDimensions[0], initialMapDimensions[1]);
+ gl.glCopyTexSubImage2D(GL2.GL_TEXTURE_2D, 0, 0, 0, 0, 0, initialMapDimensions[0], initialMapDimensions[1]);
//////////////////////////////////////////////////////////////////////
// Apply velocity to position
gl.glCallList(displayListIDs[CA_FRAGMENT_PROGRAM_APPLY_VELOCITY]);
- gl.glEnable(GL.GL_VERTEX_PROGRAM_ARB);
+ gl.glEnable(GL2.GL_VERTEX_PROGRAM);
- gl.glActiveTexture(GL.GL_TEXTURE0);
- gl.glBindTexture(GL.GL_TEXTURE_2D, texHeightInput);
- gl.glActiveTexture(GL.GL_TEXTURE1); // velocity output already bound
- gl.glEnable(GL.GL_TEXTURE_2D);
+ gl.glActiveTexture(GL2.GL_TEXTURE0);
+ gl.glBindTexture(GL2.GL_TEXTURE_2D, texHeightInput);
+ gl.glActiveTexture(GL2.GL_TEXTURE1); // velocity output already bound
+ gl.glEnable(GL2.GL_TEXTURE_2D);
// use offsets of zero
- gl.glProgramEnvParameter4fARB(GL.GL_VERTEX_PROGRAM_ARB, CV_UV_OFFSET_TO_USE, 0, 0, 0, 0);
+ gl.glProgramEnvParameter4f(GL2.GL_VERTEX_PROGRAM, CV_UV_OFFSET_TO_USE, 0, 0, 0, 0);
// Draw the quad to add in force.
gl.glCallList(displayListIDs[CA_DRAW_SCREEN_QUAD]);
- gl.glDisable(GL.GL_FRAGMENT_PROGRAM_ARB);
+ gl.glDisable(GL2.GL_FRAGMENT_PROGRAM);
// Now we need to copy the resulting pixels into the input height texture
- gl.glActiveTexture(GL.GL_TEXTURE0);
- gl.glBindTexture(GL.GL_TEXTURE_2D, texHeightInput);
+ gl.glActiveTexture(GL2.GL_TEXTURE0);
+ gl.glBindTexture(GL2.GL_TEXTURE_2D, texHeightInput);
// use CopyTexSubImage for speed (even though we copy all of it) since we pre-allocated the texture
- gl.glCopyTexSubImage2D(GL.GL_TEXTURE_2D, 0, 0, 0, 0, 0, initialMapDimensions[0], initialMapDimensions[1]);
+ gl.glCopyTexSubImage2D(GL2.GL_TEXTURE_2D, 0, 0, 0, 0, 0, initialMapDimensions[0], initialMapDimensions[1]);
///////////////////////////////////////////////////////////////////
// blur positions to smooth noise & generaly dampen things
@@ -888,31 +899,31 @@ public class Water {
// offsets with bilinear on
for (int i = 1; i < 4; i++) {
- gl.glActiveTexture(GL.GL_TEXTURE0 + i);
- gl.glBindTexture(GL.GL_TEXTURE_2D, texHeightInput);
- gl.glEnable(GL.GL_TEXTURE_2D);
+ gl.glActiveTexture(GL2.GL_TEXTURE0 + i);
+ gl.glBindTexture(GL2.GL_TEXTURE_2D, texHeightInput);
+ gl.glEnable(GL2.GL_TEXTURE_2D);
}
// use offsets of 3
- gl.glProgramEnvParameter4fARB(GL.GL_VERTEX_PROGRAM_ARB, CV_UV_OFFSET_TO_USE, 3, 0, 0, 0);
+ gl.glProgramEnvParameter4f(GL2.GL_VERTEX_PROGRAM, CV_UV_OFFSET_TO_USE, 3, 0, 0, 0);
gl.glCallList(displayListIDs[CA_FRAGMENT_PROGRAM_EQ_WEIGHT_COMBINE]);
gl.glCallList(displayListIDs[CA_DRAW_SCREEN_QUAD]);
- gl.glDisable(GL.GL_FRAGMENT_PROGRAM_ARB);
+ gl.glDisable(GL2.GL_FRAGMENT_PROGRAM);
// Draw the logo in the water.
if (applyInteriorBoundaries) {
- gl.glDisable(GL.GL_VERTEX_PROGRAM_ARB);
+ gl.glDisable(GL2.GL_VERTEX_PROGRAM);
drawInteriorBoundaryObjects(gl);
}
// Now we need to copy the resulting pixels into the velocity texture
- gl.glActiveTexture(GL.GL_TEXTURE0);
- gl.glBindTexture(GL.GL_TEXTURE_2D, texHeightOutput);
+ gl.glActiveTexture(GL2.GL_TEXTURE0);
+ gl.glBindTexture(GL2.GL_TEXTURE_2D, texHeightOutput);
// use CopyTexSubImage for speed (even though we copy all of it) since we pre-allocated the texture
- gl.glCopyTexSubImage2D(GL.GL_TEXTURE_2D, 0, 0, 0, 0, 0, initialMapDimensions[0], initialMapDimensions[1]);
+ gl.glCopyTexSubImage2D(GL2.GL_TEXTURE_2D, 0, 0, 0, 0, 0, initialMapDimensions[0], initialMapDimensions[1]);
///////////////////////////////////////////////////////////////////
// If selected, create a normal map from the height
@@ -936,67 +947,67 @@ public class Water {
}
}
- private void createNormalMap(GL gl) {
+ private void createNormalMap(GL2 gl) {
// use the height output on all four texture stages
for (int i = 0; i < 4; i++) {
- gl.glActiveTexture(GL.GL_TEXTURE0 + i);
- gl.glBindTexture(GL.GL_TEXTURE_2D, texHeightOutput);
- gl.glEnable(GL.GL_TEXTURE_2D);
+ gl.glActiveTexture(GL2.GL_TEXTURE0 + i);
+ gl.glBindTexture(GL2.GL_TEXTURE_2D, texHeightOutput);
+ gl.glEnable(GL2.GL_TEXTURE_2D);
}
// Set constants for red & green scale factors (also essential color masks)
// Red mask first
float[] pixMasks = new float[] { normalSTScale, 0.0f, 0.0f, 0.0f };
- gl.glProgramEnvParameter4fvARB(GL.GL_FRAGMENT_PROGRAM_ARB, 0, pixMasks, 0);
+ gl.glProgramEnvParameter4fv(GL2.GL_FRAGMENT_PROGRAM, 0, pixMasks, 0);
// Now green mask & scale:
pixMasks[0] = 0.0f;
pixMasks[1] = normalSTScale;
- gl.glProgramEnvParameter4fvARB(GL.GL_FRAGMENT_PROGRAM_ARB, 1, pixMasks, 0);
+ gl.glProgramEnvParameter4fv(GL2.GL_FRAGMENT_PROGRAM, 1, pixMasks, 0);
gl.glCallList(displayListIDs[CA_FRAGMENT_PROGRAM_CREATE_NORMAL_MAP]);
// set vp offsets to nearest neighbors
- gl.glProgramEnvParameter4fARB(GL.GL_VERTEX_PROGRAM_ARB, CV_UV_OFFSET_TO_USE, 4, 0, 0, 0);
- gl.glEnable(GL.GL_VERTEX_PROGRAM_ARB);
+ gl.glProgramEnvParameter4f(GL2.GL_VERTEX_PROGRAM, CV_UV_OFFSET_TO_USE, 4, 0, 0, 0);
+ gl.glEnable(GL2.GL_VERTEX_PROGRAM);
gl.glCallList(displayListIDs[CA_DRAW_SCREEN_QUAD]);
- gl.glDisable(GL.GL_FRAGMENT_PROGRAM_ARB);
+ gl.glDisable(GL2.GL_FRAGMENT_PROGRAM);
// Now we need to copy the resulting pixels into the normal map
- gl.glActiveTexture(GL.GL_TEXTURE0);
+ gl.glActiveTexture(GL2.GL_TEXTURE0);
dynamicTextures[CA_TEXTURE_NORMAL_MAP].bind();
// use CopyTexSubImage for speed (even though we copy all of it) since we pre-allocated the texture
- gl.glCopyTexSubImage2D(GL.GL_TEXTURE_2D, 0, 0, 0, 0, 0, initialMapDimensions[0], initialMapDimensions[1]);
+ gl.glCopyTexSubImage2D(GL2.GL_TEXTURE_2D, 0, 0, 0, 0, 0, initialMapDimensions[0], initialMapDimensions[1]);
}
- private void drawInteriorBoundaryObjects(GL gl) {
- gl.glDisable(GL.GL_REGISTER_COMBINERS_NV);
+ private void drawInteriorBoundaryObjects(GL2 gl) {
+ gl.glDisable(GL2.GL_REGISTER_COMBINERS_NV);
- gl.glActiveTexture(GL.GL_TEXTURE0);
+ gl.glActiveTexture(GL2.GL_TEXTURE0);
initialMapTex.bind();
initialMapTex.enable();
- gl.glEnable(GL.GL_ALPHA_TEST);
+ gl.glEnable(GL2.GL_ALPHA_TEST);
// disable other texture units.
for (int i = 1; i < 4; i++) {
- gl.glActiveTexture(GL.GL_TEXTURE0 + i);
- gl.glDisable(GL.GL_TEXTURE_2D);
+ gl.glActiveTexture(GL2.GL_TEXTURE0 + i);
+ gl.glDisable(GL2.GL_TEXTURE_2D);
}
- gl.glBlendFunc(GL.GL_SRC_ALPHA, GL.GL_ONE_MINUS_SRC_ALPHA);
- gl.glEnable(GL.GL_BLEND);
+ gl.glBlendFunc(GL2.GL_SRC_ALPHA, GL2.GL_ONE_MINUS_SRC_ALPHA);
+ gl.glEnable(GL2.GL_BLEND);
gl.glCallList(displayListIDs[CA_DRAW_SCREEN_QUAD]);
if (spinLogo) {
- gl.glActiveTexture(GL.GL_TEXTURE0);
+ gl.glActiveTexture(GL2.GL_TEXTURE0);
spinTex.bind();
- gl.glMatrixMode(GL.GL_MODELVIEW);
+ gl.glMatrixMode(GL2.GL_MODELVIEW);
gl.glPushMatrix();
gl.glRotatef(angle, 0, 0, 1);
angle += 1;
@@ -1006,8 +1017,8 @@ public class Water {
gl.glPopMatrix();
}
- gl.glDisable(GL.GL_ALPHA_TEST);
- gl.glDisable(GL.GL_BLEND);
+ gl.glDisable(GL2.GL_ALPHA_TEST);
+ gl.glDisable(GL2.GL_BLEND);
}
private void loadTextures(GL gl,
@@ -1045,7 +1056,7 @@ public class Water {
texVelocityOutput = dynamicTextures[CA_TEXTURE_VELOCITY_TARGET].getTextureObject(); // next velocity.
}
- private void createAndWriteUVOffsets(GL gl, int width, int height) {
+ private void createAndWriteUVOffsets(GL2 gl, int width, int height) {
// This sets vertex shader constants used to displace the
// source texture over several additive samples. This is
// used to accumulate neighboring texel information that we
@@ -1105,14 +1116,14 @@ public class Water {
float type2Offset[] = { type2OffsetX[i], type2OffsetY[i], 0.0f, 0.0f };
float type4Offset[] = { type4OffsetX[i], type4OffsetY[i], 0.0f, 0.0f };
- gl.glProgramEnvParameter4fvARB(GL.GL_VERTEX_PROGRAM_ARB, CV_UV_T0_NO_OFFSET + 5 * i, noOffset, 0);
- gl.glProgramEnvParameter4fvARB(GL.GL_VERTEX_PROGRAM_ARB, CV_UV_T0_TYPE1 + 5 * i, type1Offset, 0);
- gl.glProgramEnvParameter4fvARB(GL.GL_VERTEX_PROGRAM_ARB, CV_UV_T0_TYPE2 + 5 * i, type2Offset, 0);
- gl.glProgramEnvParameter4fvARB(GL.GL_VERTEX_PROGRAM_ARB, CV_UV_T0_TYPE4 + 5 * i, type4Offset, 0);
+ gl.glProgramEnvParameter4fv(GL2.GL_VERTEX_PROGRAM, CV_UV_T0_NO_OFFSET + 5 * i, noOffset, 0);
+ gl.glProgramEnvParameter4fv(GL2.GL_VERTEX_PROGRAM, CV_UV_T0_TYPE1 + 5 * i, type1Offset, 0);
+ gl.glProgramEnvParameter4fv(GL2.GL_VERTEX_PROGRAM, CV_UV_T0_TYPE2 + 5 * i, type2Offset, 0);
+ gl.glProgramEnvParameter4fv(GL2.GL_VERTEX_PROGRAM, CV_UV_T0_TYPE4 + 5 * i, type4Offset, 0);
}
}
- private void updateBlurVertOffset(GL gl) {
+ private void updateBlurVertOffset(GL2 gl) {
float[] type3OffsetX = new float[] { -perTexelWidth * 0.5f,
perTexelWidth,
perTexelWidth * 0.5f,
@@ -1128,25 +1139,25 @@ public class Water {
for (int i = 0; i < 4; ++i) {
offsets[0] = blurDist * ( type3OffsetX[i]);
offsets[1] = blurDist * ( type3OffsetY[i]);
- gl.glProgramEnvParameter4fvARB(GL.GL_VERTEX_PROGRAM_ARB, CV_UV_T0_TYPE3 + 5 * i, offsets, 0);
+ gl.glProgramEnvParameter4fv(GL2.GL_VERTEX_PROGRAM, CV_UV_T0_TYPE3 + 5 * i, offsets, 0);
}
}
- private synchronized void drawDroplets(GL gl) {
- gl.glDisable(GL.GL_FRAGMENT_PROGRAM_ARB);
- gl.glDisable(GL.GL_VERTEX_PROGRAM_ARB);
+ private synchronized void drawDroplets(GL2 gl) {
+ gl.glDisable(GL2.GL_FRAGMENT_PROGRAM);
+ gl.glDisable(GL2.GL_VERTEX_PROGRAM);
- gl.glActiveTexture(GL.GL_TEXTURE0);
+ gl.glActiveTexture(GL2.GL_TEXTURE0);
dropletTex.bind();
dropletTex.enable();
- gl.glActiveTexture(GL.GL_TEXTURE1);
- gl.glDisable(GL.GL_TEXTURE_2D);
+ gl.glActiveTexture(GL2.GL_TEXTURE1);
+ gl.glDisable(GL2.GL_TEXTURE_2D);
- gl.glBlendFunc(GL.GL_ONE, GL.GL_ONE);
- gl.glEnable(GL.GL_BLEND);
+ gl.glBlendFunc(GL2.GL_ONE, GL2.GL_ONE);
+ gl.glEnable(GL2.GL_BLEND);
- gl.glBegin(GL.GL_QUADS);
+ gl.glBegin(GL2.GL_QUADS);
gl.glColor4f(1, 1, 1, 1);
for (Iterator iter = droplets.iterator(); iter.hasNext(); ) {
Droplet droplet = (Droplet) iter.next();
@@ -1164,14 +1175,14 @@ public class Water {
}
gl.glEnd();
- gl.glDisable(GL.GL_BLEND);
+ gl.glDisable(GL2.GL_BLEND);
}
//----------------------------------------------------------------------
// Inlined register combiner and texture shader programs
// (don't want to port nvparse as it's a dead-end; we'll focus on Cg instead)
- private void initEqWeightCombine_PostMult(GL gl, int displayListID) {
+ private void initEqWeightCombine_PostMult(GL2 gl, int displayListID) {
// Take samples of all four texture inputs and average them,
// adding on a bias
//
@@ -1212,9 +1223,9 @@ public class Water {
float[] const0 = new float[] { 0.5f, 0.5f, 0.5f, 1.0f };
int[] tmpInt = new int[1];
- gl.glGenProgramsARB(1, tmpInt, 0);
+ gl.glGenPrograms(1, tmpInt, 0);
int fragProg = tmpInt[0];
- gl.glBindProgramARB(GL.GL_FRAGMENT_PROGRAM_ARB, fragProg);
+ gl.glBindProgram(GL2.GL_FRAGMENT_PROGRAM, fragProg);
String program =
"!!ARBfp1.0\n" +
@@ -1236,16 +1247,16 @@ public class Water {
"\n" +
"END\n";
- loadProgram(gl, GL.GL_FRAGMENT_PROGRAM_ARB, program);
+ loadProgram(gl, GL2.GL_FRAGMENT_PROGRAM, program);
- gl.glNewList(displayListID, GL.GL_COMPILE);
- gl.glProgramEnvParameter4fvARB(GL.GL_FRAGMENT_PROGRAM_ARB, 0, const0, 0);
- gl.glBindProgramARB(GL.GL_FRAGMENT_PROGRAM_ARB, fragProg);
- gl.glEnable(GL.GL_FRAGMENT_PROGRAM_ARB);
+ gl.glNewList(displayListID, GL2.GL_COMPILE);
+ gl.glProgramEnvParameter4fv(GL2.GL_FRAGMENT_PROGRAM, 0, const0, 0);
+ gl.glBindProgram(GL2.GL_FRAGMENT_PROGRAM, fragProg);
+ gl.glEnable(GL2.GL_FRAGMENT_PROGRAM);
gl.glEndList();
}
- private void initNeighborForceCalcStep1(GL gl, int displayListID) {
+ private void initNeighborForceCalcStep1(GL2 gl, int displayListID) {
// Step one in the nearest-neighbor force calculation for height-based water
// simulation. NeighborForceCalc2 is the second step.
//
@@ -1339,9 +1350,9 @@ public class Water {
float[] const0 = new float[] { 0.5f, 0.5f, 0.5f, 1.0f };
int[] tmpInt = new int[1];
- gl.glGenProgramsARB(1, tmpInt, 0);
+ gl.glGenPrograms(1, tmpInt, 0);
int fragProg = tmpInt[0];
- gl.glBindProgramARB(GL.GL_FRAGMENT_PROGRAM_ARB, fragProg);
+ gl.glBindProgram(GL2.GL_FRAGMENT_PROGRAM, fragProg);
String program =
"!!ARBfp1.0\n" +
@@ -1380,16 +1391,16 @@ public class Water {
"\n" +
"END\n";
- loadProgram(gl, GL.GL_FRAGMENT_PROGRAM_ARB, program);
+ loadProgram(gl, GL2.GL_FRAGMENT_PROGRAM, program);
- gl.glNewList(displayListID, GL.GL_COMPILE);
- gl.glProgramEnvParameter4fvARB(GL.GL_FRAGMENT_PROGRAM_ARB, 0, const0, 0);
- gl.glBindProgramARB(GL.GL_FRAGMENT_PROGRAM_ARB, fragProg);
- gl.glEnable(GL.GL_FRAGMENT_PROGRAM_ARB);
+ gl.glNewList(displayListID, GL2.GL_COMPILE);
+ gl.glProgramEnvParameter4fv(GL2.GL_FRAGMENT_PROGRAM, 0, const0, 0);
+ gl.glBindProgram(GL2.GL_FRAGMENT_PROGRAM, fragProg);
+ gl.glEnable(GL2.GL_FRAGMENT_PROGRAM);
gl.glEndList();
}
- private void initNeighborForceCalcStep2(GL gl, int displayListID) {
+ private void initNeighborForceCalcStep2(GL2 gl, int displayListID) {
// 2nd step of force calc for render-to-texture
// water simulation.
//
@@ -1426,9 +1437,9 @@ public class Water {
// }
int[] tmpInt = new int[1];
- gl.glGenProgramsARB(1, tmpInt, 0);
+ gl.glGenPrograms(1, tmpInt, 0);
int fragProg = tmpInt[0];
- gl.glBindProgramARB(GL.GL_FRAGMENT_PROGRAM_ARB, fragProg);
+ gl.glBindProgram(GL2.GL_FRAGMENT_PROGRAM, fragProg);
String program =
"!!ARBfp1.0\n" +
@@ -1444,15 +1455,15 @@ public class Water {
"\n" +
"END\n";
- loadProgram(gl, GL.GL_FRAGMENT_PROGRAM_ARB, program);
+ loadProgram(gl, GL2.GL_FRAGMENT_PROGRAM, program);
- gl.glNewList(displayListID, GL.GL_COMPILE);
- gl.glBindProgramARB(GL.GL_FRAGMENT_PROGRAM_ARB, fragProg);
- gl.glEnable(GL.GL_FRAGMENT_PROGRAM_ARB);
+ gl.glNewList(displayListID, GL2.GL_COMPILE);
+ gl.glBindProgram(GL2.GL_FRAGMENT_PROGRAM, fragProg);
+ gl.glEnable(GL2.GL_FRAGMENT_PROGRAM);
gl.glEndList();
}
- private void initApplyForce(GL gl, int displayListID) {
+ private void initApplyForce(GL2 gl, int displayListID) {
// This shader samples t1, biases its value to a signed number, and applies this
// value multiplied by a scale factor to the t0 sample.
//
@@ -1498,9 +1509,9 @@ public class Water {
float[] const1 = new float[] { 0.5f, 0.5f, 0.5f, 1.0f };
int[] tmpInt = new int[1];
- gl.glGenProgramsARB(1, tmpInt, 0);
+ gl.glGenPrograms(1, tmpInt, 0);
int fragProg = tmpInt[0];
- gl.glBindProgramARB(GL.GL_FRAGMENT_PROGRAM_ARB, fragProg);
+ gl.glBindProgram(GL2.GL_FRAGMENT_PROGRAM, fragProg);
String program =
"!!ARBfp1.0\n" +
@@ -1521,17 +1532,17 @@ public class Water {
"\n" +
"END\n";
- loadProgram(gl, GL.GL_FRAGMENT_PROGRAM_ARB, program);
+ loadProgram(gl, GL2.GL_FRAGMENT_PROGRAM, program);
- gl.glNewList(displayListID, GL.GL_COMPILE);
- gl.glProgramEnvParameter4fvARB(GL.GL_FRAGMENT_PROGRAM_ARB, 0, const0, 0);
- gl.glProgramEnvParameter4fvARB(GL.GL_FRAGMENT_PROGRAM_ARB, 1, const1, 0);
- gl.glBindProgramARB(GL.GL_FRAGMENT_PROGRAM_ARB, fragProg);
- gl.glEnable(GL.GL_FRAGMENT_PROGRAM_ARB);
+ gl.glNewList(displayListID, GL2.GL_COMPILE);
+ gl.glProgramEnvParameter4fv(GL2.GL_FRAGMENT_PROGRAM, 0, const0, 0);
+ gl.glProgramEnvParameter4fv(GL2.GL_FRAGMENT_PROGRAM, 1, const1, 0);
+ gl.glBindProgram(GL2.GL_FRAGMENT_PROGRAM, fragProg);
+ gl.glEnable(GL2.GL_FRAGMENT_PROGRAM);
gl.glEndList();
}
- private void initApplyVelocity(GL gl, int displayListID) {
+ private void initApplyVelocity(GL2 gl, int displayListID) {
// This shader samples t1, biases its value to a signed number, and applies this
// value multiplied by a scale factor to the t0 sample.
//
@@ -1577,9 +1588,9 @@ public class Water {
float[] const0 = new float[] { 0.5f, 0.5f, 0.5f, 1.0f };
int[] tmpInt = new int[1];
- gl.glGenProgramsARB(1, tmpInt, 0);
+ gl.glGenPrograms(1, tmpInt, 0);
int fragProg = tmpInt[0];
- gl.glBindProgramARB(GL.GL_FRAGMENT_PROGRAM_ARB, fragProg);
+ gl.glBindProgram(GL2.GL_FRAGMENT_PROGRAM, fragProg);
String program =
"!!ARBfp1.0\n" +
@@ -1599,16 +1610,16 @@ public class Water {
"\n" +
"END\n";
- loadProgram(gl, GL.GL_FRAGMENT_PROGRAM_ARB, program);
+ loadProgram(gl, GL2.GL_FRAGMENT_PROGRAM, program);
- gl.glNewList(displayListID, GL.GL_COMPILE);
- gl.glProgramEnvParameter4fvARB(GL.GL_FRAGMENT_PROGRAM_ARB, 0, const0, 0);
- gl.glBindProgramARB(GL.GL_FRAGMENT_PROGRAM_ARB, fragProg);
- gl.glEnable(GL.GL_FRAGMENT_PROGRAM_ARB);
+ gl.glNewList(displayListID, GL2.GL_COMPILE);
+ gl.glProgramEnvParameter4fv(GL2.GL_FRAGMENT_PROGRAM, 0, const0, 0);
+ gl.glBindProgram(GL2.GL_FRAGMENT_PROGRAM, fragProg);
+ gl.glEnable(GL2.GL_FRAGMENT_PROGRAM);
gl.glEndList();
}
- private void initCreateNormalMap(GL gl, int displayListID) {
+ private void initCreateNormalMap(GL2 gl, int displayListID) {
// Neighbor-differencing for RGB normal map creation. Scale factors for s and t
// axis components are set in program code.
// This does a crude 1-s^2-t^2 calculation for the blue component in order to
@@ -1694,9 +1705,9 @@ public class Water {
float[] const0 = new float[] { 0.5f, 0.5f, 0.5f, 1.0f };
int[] tmpInt = new int[1];
- gl.glGenProgramsARB(1, tmpInt, 0);
+ gl.glGenPrograms(1, tmpInt, 0);
int fragProg = tmpInt[0];
- gl.glBindProgramARB(GL.GL_FRAGMENT_PROGRAM_ARB, fragProg);
+ gl.glBindProgram(GL2.GL_FRAGMENT_PROGRAM, fragProg);
String program =
"!!ARBfp1.0\n" +
@@ -1730,15 +1741,15 @@ public class Water {
"\n" +
"END\n";
- loadProgram(gl, GL.GL_FRAGMENT_PROGRAM_ARB, program);
+ loadProgram(gl, GL2.GL_FRAGMENT_PROGRAM, program);
- gl.glNewList(displayListID, GL.GL_COMPILE);
- gl.glBindProgramARB(GL.GL_FRAGMENT_PROGRAM_ARB, fragProg);
- gl.glEnable(GL.GL_FRAGMENT_PROGRAM_ARB);
+ gl.glNewList(displayListID, GL2.GL_COMPILE);
+ gl.glBindProgram(GL2.GL_FRAGMENT_PROGRAM, fragProg);
+ gl.glEnable(GL2.GL_FRAGMENT_PROGRAM);
gl.glEndList();
}
- private void initDotProductReflect(GL gl, int displayListID) {
+ private void initDotProductReflect(GL2 gl, int displayListID) {
// Pseudocode for this operation, derived from the NVidia
// texture_shader.txt documentation at
// http://oss.sgi.com/projects/ogl-sample/registry/NV/texture_shader.txt
@@ -1769,9 +1780,9 @@ public class Water {
// of a visual difference so they are skipped as well.
int[] tmpInt = new int[1];
- gl.glGenProgramsARB(1, tmpInt, 0);
+ gl.glGenPrograms(1, tmpInt, 0);
int fragProg = tmpInt[0];
- gl.glBindProgramARB(GL.GL_FRAGMENT_PROGRAM_ARB, fragProg);
+ gl.glBindProgram(GL2.GL_FRAGMENT_PROGRAM, fragProg);
String program =
"!!ARBfp1.0\n" +
@@ -1793,29 +1804,29 @@ public class Water {
"\n" +
"END";
- loadProgram(gl, GL.GL_FRAGMENT_PROGRAM_ARB, program);
+ loadProgram(gl, GL2.GL_FRAGMENT_PROGRAM, program);
- gl.glNewList(displayListID, GL.GL_COMPILE);
- gl.glBindProgramARB(GL.GL_FRAGMENT_PROGRAM_ARB, fragProg);
- gl.glEnable(GL.GL_FRAGMENT_PROGRAM_ARB);
+ gl.glNewList(displayListID, GL2.GL_COMPILE);
+ gl.glBindProgram(GL2.GL_FRAGMENT_PROGRAM, fragProg);
+ gl.glEnable(GL2.GL_FRAGMENT_PROGRAM);
gl.glEndList();
}
- private void loadProgram(GL gl,
+ private void loadProgram(GL2 gl,
int target,
String programBuffer) {
- gl.glProgramStringARB(target, GL.GL_PROGRAM_FORMAT_ASCII_ARB, programBuffer.length(), programBuffer);
+ gl.glProgramString(target, GL2.GL_PROGRAM_FORMAT_ASCII, programBuffer.length(), programBuffer);
int[] errPos = new int[1];
- gl.glGetIntegerv(GL.GL_PROGRAM_ERROR_POSITION_ARB, errPos, 0);
+ gl.glGetIntegerv(GL2.GL_PROGRAM_ERROR_POSITION, errPos, 0);
if (errPos[0] >= 0) {
String kind = "Program";
- if (target == GL.GL_VERTEX_PROGRAM_ARB) {
+ if (target == GL2.GL_VERTEX_PROGRAM) {
kind = "Vertex program";
- } else if (target == GL.GL_FRAGMENT_PROGRAM_ARB) {
+ } else if (target == GL2.GL_FRAGMENT_PROGRAM) {
kind = "Fragment program";
}
System.out.println(kind + " failed to load:");
- String errMsg = gl.glGetString(GL.GL_PROGRAM_ERROR_STRING_ARB);
+ String errMsg = gl.glGetString(GL2.GL_PROGRAM_ERROR_STRING);
if (errMsg == null) {
System.out.println("[No error message available]");
} else {
@@ -1829,10 +1840,10 @@ public class Water {
System.out.println(programBuffer.substring(errPos[0], endPos));
throw new GLException("Error loading " + kind);
} else {
- if (target == GL.GL_FRAGMENT_PROGRAM_ARB) {
+ if (target == GL2.GL_FRAGMENT_PROGRAM) {
int[] isNative = new int[1];
- gl.glGetProgramivARB(GL.GL_FRAGMENT_PROGRAM_ARB,
- GL.GL_PROGRAM_UNDER_NATIVE_LIMITS_ARB,
+ gl.glGetProgramiv(GL2.GL_FRAGMENT_PROGRAM,
+ GL2.GL_PROGRAM_UNDER_NATIVE_LIMITS,
isNative, 0);
if (isNative[0] != 1) {
System.out.println("WARNING: fragment program is over native resource limits");
diff --git a/src/demos/tess/Tess.java b/src/demos/tess/Tess.java
index 555214f..9709de7 100644
--- a/src/demos/tess/Tess.java
+++ b/src/demos/tess/Tess.java
@@ -42,6 +42,17 @@
package demos.tess;
+import java.awt.Frame;
+import java.awt.event.WindowAdapter;
+import java.awt.event.WindowEvent;
+import javax.media.opengl.DebugGL2;
+import javax.media.opengl.GL2;
+import javax.media.opengl.GLAutoDrawable;
+import javax.media.opengl.GLEventListener;
+import javax.media.opengl.awt.GLCanvas;
+import javax.media.opengl.glu.GLU;
+import javax.media.opengl.glu.GLUtessellator;
+
/**
* tess.java
* This program demonstrates polygon tessellation.
@@ -58,13 +69,7 @@ package demos.tess;
* @author Ported by Nathan Parker Burg, July 2003
*/
-import javax.media.opengl.*;
-import javax.media.opengl.glu.*;
-import com.sun.opengl.util.*;
-import java.awt.*;
-import java.awt.event.WindowAdapter;
-import java.awt.event.WindowEvent;
public class Tess {
public static void main(String[] args) {
@@ -87,21 +92,22 @@ public class Tess {
}).start();
}
});
- frame.show();
+ frame.setVisible(true);
} catch (Exception e) {
e.printStackTrace();
}
}
public static class TessRenderer implements GLEventListener {
- private GL gl;
+ private GL2 gl;
private GLU glu = new GLU();
private int startList;
public void init(GLAutoDrawable drawable) {
- drawable.setGL(new DebugGL(drawable.getGL()));
- gl = drawable.getGL();
+ gl = drawable.getGL().getGL2();
+
+ drawable.setGL(new DebugGL2(gl));
double[][] rect = new double[][]{{50.0, 50.0, 0.0},
{200.0, 50.0, 0.0},
@@ -128,8 +134,8 @@ public class Tess {
glu.gluTessCallback(tobj, GLU.GLU_TESS_END, tessCallback);
glu.gluTessCallback(tobj, GLU.GLU_TESS_ERROR, tessCallback);
- gl.glNewList(startList, GL.GL_COMPILE);
- gl.glShadeModel(GL.GL_FLAT);
+ gl.glNewList(startList, GL2.GL_COMPILE);
+ gl.glShadeModel(GL2.GL_FLAT);
glu.gluTessBeginPolygon(tobj, null);
glu.gluTessBeginContour(tobj);
glu.gluTessVertex(tobj, rect[0], 0, rect[0]);
@@ -151,8 +157,8 @@ public class Tess {
glu.gluTessCallback(tobj, GLU.GLU_TESS_ERROR, tessCallback);
glu.gluTessCallback(tobj, GLU.GLU_TESS_COMBINE, tessCallback);
- gl.glNewList(startList + 1, GL.GL_COMPILE);
- gl.glShadeModel(GL.GL_SMOOTH);
+ gl.glNewList(startList + 1, GL2.GL_COMPILE);
+ gl.glShadeModel(GL2.GL_SMOOTH);
glu.gluTessProperty(tobj, GLU.GLU_TESS_WINDING_RULE, GLU.GLU_TESS_WINDING_POSITIVE);
glu.gluTessBeginPolygon(tobj, null);
glu.gluTessBeginContour(tobj);
@@ -169,10 +175,10 @@ public class Tess {
public void reshape(GLAutoDrawable drawable, int x, int y, int width, int height) {
- gl.glMatrixMode(GL.GL_PROJECTION);
+ gl.glMatrixMode(GL2.GL_PROJECTION);
gl.glLoadIdentity();
gl.glOrtho( 0, 450, 0, 250, -1, 1 );
- gl.glMatrixMode(GL.GL_MODELVIEW);
+ gl.glMatrixMode(GL2.GL_MODELVIEW);
gl.glLoadIdentity();
}
@@ -180,7 +186,7 @@ public class Tess {
}
public void display(GLAutoDrawable drawable) {
- gl.glClear(GL.GL_COLOR_BUFFER_BIT);
+ gl.glClear(GL2.GL_COLOR_BUFFER_BIT);
gl.glColor3d(1.0, 1.0, 1.0);
gl.glCallList(startList);
gl.glCallList(startList + 1);
@@ -191,10 +197,10 @@ public class Tess {
public static class TessCallback extends javax.media.opengl.glu.GLUtessellatorCallbackAdapter {
- GL gl;
+ GL2 gl;
GLU glu;
- public TessCallback(GL gl, GLU glu) {
+ public TessCallback(GL2 gl, GLU glu) {
this.gl = gl;
this.glu = glu;
};
diff --git a/src/demos/testContextDestruction/TestContextDestruction.java b/src/demos/testContextDestruction/TestContextDestruction.java
index 1355d11..a2344bc 100755
--- a/src/demos/testContextDestruction/TestContextDestruction.java
+++ b/src/demos/testContextDestruction/TestContextDestruction.java
@@ -39,13 +39,28 @@
package demos.testContextDestruction;
-import java.awt.*;
-import java.awt.event.*;
-import java.util.*;
-import javax.swing.*;
+import java.awt.BorderLayout;
+import java.awt.Canvas;
+import java.awt.Color;
+import java.awt.Component;
+import java.awt.Frame;
+import java.awt.GridLayout;
+import java.awt.event.ActionEvent;
+import java.awt.event.ActionListener;
+import java.awt.event.WindowAdapter;
+import java.awt.event.WindowEvent;
+import java.awt.event.WindowListener;
+import javax.media.opengl.DebugGL2;
+import javax.media.opengl.GL;
+import javax.media.opengl.GL2;
+import javax.media.opengl.GLAutoDrawable;
+import javax.media.opengl.GLEventListener;
+import javax.media.opengl.awt.GLCanvas;
+import javax.media.opengl.util.Animator;
+import javax.swing.JButton;
+import javax.swing.JFrame;
+
-import javax.media.opengl.*;
-import com.sun.opengl.util.*;
/** A simple demonstration exercising context creation and destruction
as a GLCanvas is added to and removed from its parent container. */
@@ -88,9 +103,9 @@ public class TestContextDestruction {
frame2ContainedComponent = emptyCanvas;
frame1.pack();
- frame1.show();
+ frame1.setVisible(true);
frame2.pack();
- frame2.show();
+ frame2.setVisible(true);
frame2.setLocation(256 + BORDER_WIDTH, 0);
JFrame uiFrame = new JFrame("Controls");
@@ -153,7 +168,7 @@ public class TestContextDestruction {
});
uiFrame.getContentPane().add(button);
uiFrame.pack();
- uiFrame.show();
+ uiFrame.setVisible(true);
uiFrame.setLocation(512 + BORDER_WIDTH + BORDER_WIDTH, 0);
final Animator animator = new Animator(canvas);
@@ -178,21 +193,24 @@ public class TestContextDestruction {
class Listener implements GLEventListener {
public void init(GLAutoDrawable drawable) {
+
System.out.println("Listener.init()");
- drawable.setGL(new DebugGL(drawable.getGL()));
- GL gl = drawable.getGL();
+ GL2 gl = drawable.getGL().getGL2();
+
+ drawable.setGL(new DebugGL2(gl));
+
float pos[] = { 5.0f, 5.0f, 10.0f, 0.0f };
- gl.glLightfv(GL.GL_LIGHT0, GL.GL_POSITION, pos, 0);
- gl.glEnable(GL.GL_CULL_FACE);
- gl.glEnable(GL.GL_LIGHTING);
- gl.glEnable(GL.GL_LIGHT0);
- gl.glEnable(GL.GL_DEPTH_TEST);
+ gl.glLightfv(GL2.GL_LIGHT0, GL2.GL_POSITION, pos, 0);
+ gl.glEnable(GL2.GL_CULL_FACE);
+ gl.glEnable(GL2.GL_LIGHTING);
+ gl.glEnable(GL2.GL_LIGHT0);
+ gl.glEnable(GL2.GL_DEPTH_TEST);
initializeDisplayList(gl);
- gl.glEnable(GL.GL_NORMALIZE);
+ gl.glEnable(GL2.GL_NORMALIZE);
reshape(drawable, 0, 0, drawable.getWidth(), drawable.getHeight());
}
@@ -200,9 +218,9 @@ public class TestContextDestruction {
public void display(GLAutoDrawable drawable) {
angle += 2.0f;
- GL gl = drawable.getGL();
+ GL2 gl = drawable.getGL().getGL2();
- gl.glClear(GL.GL_COLOR_BUFFER_BIT | GL.GL_DEPTH_BUFFER_BIT);
+ gl.glClear(GL2.GL_COLOR_BUFFER_BIT | GL2.GL_DEPTH_BUFFER_BIT);
gl.glPushMatrix();
gl.glRotatef(angle, 0.0f, 0.0f, 1.0f);
@@ -212,21 +230,21 @@ public class TestContextDestruction {
public void reshape(GLAutoDrawable drawable, int x, int y, int width, int height) {
System.out.println("Listener.reshape()");
- GL gl = drawable.getGL();
+ GL2 gl = drawable.getGL().getGL2();
float h = (float)height / (float)width;
- gl.glMatrixMode(GL.GL_PROJECTION);
+ gl.glMatrixMode(GL2.GL_PROJECTION);
gl.glLoadIdentity();
gl.glFrustum(-1.0f, 1.0f, -h, h, 5.0f, 60.0f);
- gl.glMatrixMode(GL.GL_MODELVIEW);
+ gl.glMatrixMode(GL2.GL_MODELVIEW);
gl.glLoadIdentity();
gl.glTranslatef(0.0f, 0.0f, -40.0f);
}
public void destroy(GLAutoDrawable drawable) {
System.out.println("Listener.destroy()");
- GL gl = drawable.getGL();
+ GL2 gl = drawable.getGL().getGL2();
gl.glDeleteLists(gearDisplayList, 1);
gearDisplayList = 0;
}
@@ -235,16 +253,16 @@ public class TestContextDestruction {
public void displayChanged(GLAutoDrawable drawable, boolean modeChanged, boolean deviceChanged) {}
}
- private synchronized void initializeDisplayList(GL gl) {
+ private synchronized void initializeDisplayList(GL2 gl) {
gearDisplayList = gl.glGenLists(1);
- gl.glNewList(gearDisplayList, GL.GL_COMPILE);
+ gl.glNewList(gearDisplayList, GL2.GL_COMPILE);
float red[] = { 0.8f, 0.1f, 0.0f, 1.0f };
- gl.glMaterialfv(GL.GL_FRONT, GL.GL_AMBIENT_AND_DIFFUSE, red, 0);
+ gl.glMaterialfv(GL2.GL_FRONT, GL2.GL_AMBIENT_AND_DIFFUSE, red, 0);
gear(gl, 1.0f, 4.0f, 1.0f, 20, 0.7f);
gl.glEndList();
}
- private void gear(GL gl,
+ private void gear(GL2 gl,
float inner_radius,
float outer_radius,
float width,
@@ -262,12 +280,12 @@ public class TestContextDestruction {
da = 2.0f * (float) Math.PI / teeth / 4.0f;
- gl.glShadeModel(GL.GL_FLAT);
+ gl.glShadeModel(GL2.GL_FLAT);
gl.glNormal3f(0.0f, 0.0f, 1.0f);
/* draw front face */
- gl.glBegin(GL.GL_QUAD_STRIP);
+ gl.glBegin(GL2.GL_QUAD_STRIP);
for (i = 0; i <= teeth; i++)
{
angle = i * 2.0f * (float) Math.PI / teeth;
@@ -282,7 +300,7 @@ public class TestContextDestruction {
gl.glEnd();
/* draw front sides of teeth */
- gl.glBegin(GL.GL_QUADS);
+ gl.glBegin(GL2.GL_QUADS);
for (i = 0; i < teeth; i++)
{
angle = i * 2.0f * (float) Math.PI / teeth;
@@ -294,7 +312,7 @@ public class TestContextDestruction {
gl.glEnd();
/* draw back face */
- gl.glBegin(GL.GL_QUAD_STRIP);
+ gl.glBegin(GL2.GL_QUAD_STRIP);
for (i = 0; i <= teeth; i++)
{
angle = i * 2.0f * (float) Math.PI / teeth;
@@ -306,7 +324,7 @@ public class TestContextDestruction {
gl.glEnd();
/* draw back sides of teeth */
- gl.glBegin(GL.GL_QUADS);
+ gl.glBegin(GL2.GL_QUADS);
for (i = 0; i < teeth; i++)
{
angle = i * 2.0f * (float) Math.PI / teeth;
@@ -318,7 +336,7 @@ public class TestContextDestruction {
gl.glEnd();
/* draw outward faces of teeth */
- gl.glBegin(GL.GL_QUAD_STRIP);
+ gl.glBegin(GL2.GL_QUAD_STRIP);
for (i = 0; i < teeth; i++)
{
angle = i * 2.0f * (float) Math.PI / teeth;
@@ -346,10 +364,10 @@ public class TestContextDestruction {
gl.glVertex3f(r1 * (float)Math.cos(0), r1 * (float)Math.sin(0), -width * 0.5f);
gl.glEnd();
- gl.glShadeModel(GL.GL_SMOOTH);
+ gl.glShadeModel(GL2.GL_SMOOTH);
/* draw inside radius cylinder */
- gl.glBegin(GL.GL_QUAD_STRIP);
+ gl.glBegin(GL2.GL_QUAD_STRIP);
for (i = 0; i <= teeth; i++)
{
angle = i * 2.0f * (float) Math.PI / teeth;
diff --git a/src/demos/testContextSharing/TestContextSharing.java b/src/demos/testContextSharing/TestContextSharing.java
index d0be0c1..d83dced 100644
--- a/src/demos/testContextSharing/TestContextSharing.java
+++ b/src/demos/testContextSharing/TestContextSharing.java
@@ -39,10 +39,16 @@
package demos.testContextSharing;
-import java.awt.*;
-import java.util.*;
+import java.awt.BorderLayout;
+import java.awt.Frame;
+import java.util.Random;
+import javax.media.opengl.DebugGL2;
+import javax.media.opengl.GL2;
+import javax.media.opengl.GLAutoDrawable;
+import javax.media.opengl.GLEventListener;
+import javax.media.opengl.awt.GLCanvas;
+
-import javax.media.opengl.*;
/** A simple demonstration of sharing of display lists between drawables. */
@@ -80,7 +86,7 @@ public class TestContextSharing {
}
System.err.println("Showing first frame");
frame.pack();
- frame.show();
+ frame.setVisible(true);
new Thread(new Runnable() {
public void run() {
try {
@@ -89,48 +95,50 @@ public class TestContextSharing {
}
System.err.println("Showing other frame");
delayedFrame.pack();
- delayedFrame.show();
+ delayedFrame.setVisible(true);
delayedFrame.setLocation(256, 0);
}
}).start();
}
class Listener implements GLEventListener {
+
public void init(GLAutoDrawable drawable) {
- drawable.setGL(new DebugGL(drawable.getGL()));
- GL gl = drawable.getGL();
+ GL2 gl = drawable.getGL().getGL2();
+
+ drawable.setGL(new DebugGL2(gl));
float pos[] = { 5.0f, 5.0f, 10.0f, 0.0f };
- gl.glLightfv(GL.GL_LIGHT0, GL.GL_POSITION, pos, 0);
- gl.glEnable(GL.GL_CULL_FACE);
- gl.glEnable(GL.GL_LIGHTING);
- gl.glEnable(GL.GL_LIGHT0);
- gl.glEnable(GL.GL_DEPTH_TEST);
+ gl.glLightfv(GL2.GL_LIGHT0, GL2.GL_POSITION, pos, 0);
+ gl.glEnable(GL2.GL_CULL_FACE);
+ gl.glEnable(GL2.GL_LIGHTING);
+ gl.glEnable(GL2.GL_LIGHT0);
+ gl.glEnable(GL2.GL_DEPTH_TEST);
initializeDisplayList(gl);
- gl.glEnable(GL.GL_NORMALIZE);
+ gl.glEnable(GL2.GL_NORMALIZE);
}
public void display(GLAutoDrawable drawable) {
- GL gl = drawable.getGL();
+ GL2 gl = drawable.getGL().getGL2();
- gl.glClear(GL.GL_COLOR_BUFFER_BIT | GL.GL_DEPTH_BUFFER_BIT);
+ gl.glClear(GL2.GL_COLOR_BUFFER_BIT | GL2.GL_DEPTH_BUFFER_BIT);
System.err.println("Drawing display list " + gearDisplayList);
gl.glCallList(gearDisplayList);
}
public void reshape(GLAutoDrawable drawable, int x, int y, int width, int height) {
- GL gl = drawable.getGL();
+ GL2 gl = drawable.getGL().getGL2();
float h = (float)height / (float)width;
- gl.glMatrixMode(GL.GL_PROJECTION);
+ gl.glMatrixMode(GL2.GL_PROJECTION);
gl.glLoadIdentity();
gl.glFrustum(-1.0f, 1.0f, -h, h, 5.0f, 60.0f);
- gl.glMatrixMode(GL.GL_MODELVIEW);
+ gl.glMatrixMode(GL2.GL_MODELVIEW);
gl.glLoadIdentity();
gl.glTranslatef(0.0f, 0.0f, -40.0f);
}
@@ -139,20 +147,20 @@ public class TestContextSharing {
public void displayChanged(GLAutoDrawable drawable, boolean modeChanged, boolean deviceChanged) {}
}
- private synchronized void initializeDisplayList(GL gl) {
+ private synchronized void initializeDisplayList(GL2 gl) {
if (gearDisplayList != 0) {
return;
}
gearDisplayList = gl.glGenLists(1);
- gl.glNewList(gearDisplayList, GL.GL_COMPILE);
+ gl.glNewList(gearDisplayList, GL2.GL_COMPILE);
float red[] = { 0.8f, 0.1f, 0.0f, 1.0f };
- gl.glMaterialfv(GL.GL_FRONT, GL.GL_AMBIENT_AND_DIFFUSE, red, 0);
+ gl.glMaterialfv(GL2.GL_FRONT, GL2.GL_AMBIENT_AND_DIFFUSE, red, 0);
gear(gl, 1.0f, 4.0f, 1.0f, 20, 0.7f);
gl.glEndList();
}
- private void gear(GL gl,
+ private void gear(GL2 gl,
float inner_radius,
float outer_radius,
float width,
@@ -170,12 +178,12 @@ public class TestContextSharing {
da = 2.0f * (float) Math.PI / teeth / 4.0f;
- gl.glShadeModel(GL.GL_FLAT);
+ gl.glShadeModel(GL2.GL_FLAT);
gl.glNormal3f(0.0f, 0.0f, 1.0f);
/* draw front face */
- gl.glBegin(GL.GL_QUAD_STRIP);
+ gl.glBegin(GL2.GL_QUAD_STRIP);
for (i = 0; i <= teeth; i++)
{
angle = i * 2.0f * (float) Math.PI / teeth;
@@ -190,7 +198,7 @@ public class TestContextSharing {
gl.glEnd();
/* draw front sides of teeth */
- gl.glBegin(GL.GL_QUADS);
+ gl.glBegin(GL2.GL_QUADS);
for (i = 0; i < teeth; i++)
{
angle = i * 2.0f * (float) Math.PI / teeth;
@@ -202,7 +210,7 @@ public class TestContextSharing {
gl.glEnd();
/* draw back face */
- gl.glBegin(GL.GL_QUAD_STRIP);
+ gl.glBegin(GL2.GL_QUAD_STRIP);
for (i = 0; i <= teeth; i++)
{
angle = i * 2.0f * (float) Math.PI / teeth;
@@ -214,7 +222,7 @@ public class TestContextSharing {
gl.glEnd();
/* draw back sides of teeth */
- gl.glBegin(GL.GL_QUADS);
+ gl.glBegin(GL2.GL_QUADS);
for (i = 0; i < teeth; i++)
{
angle = i * 2.0f * (float) Math.PI / teeth;
@@ -226,7 +234,7 @@ public class TestContextSharing {
gl.glEnd();
/* draw outward faces of teeth */
- gl.glBegin(GL.GL_QUAD_STRIP);
+ gl.glBegin(GL2.GL_QUAD_STRIP);
for (i = 0; i < teeth; i++)
{
angle = i * 2.0f * (float) Math.PI / teeth;
@@ -254,10 +262,10 @@ public class TestContextSharing {
gl.glVertex3f(r1 * (float)Math.cos(0), r1 * (float)Math.sin(0), -width * 0.5f);
gl.glEnd();
- gl.glShadeModel(GL.GL_SMOOTH);
+ gl.glShadeModel(GL2.GL_SMOOTH);
/* draw inside radius cylinder */
- gl.glBegin(GL.GL_QUAD_STRIP);
+ gl.glBegin(GL2.GL_QUAD_STRIP);
for (i = 0; i <= teeth; i++)
{
angle = i * 2.0f * (float) Math.PI / teeth;
diff --git a/src/demos/texture/TestSubImage.java b/src/demos/texture/TestSubImage.java
index b4e395e..f7ddde4 100755
--- a/src/demos/texture/TestSubImage.java
+++ b/src/demos/texture/TestSubImage.java
@@ -39,20 +39,41 @@
package demos.texture;
+import com.sun.opengl.util.texture.Texture;
+import com.sun.opengl.util.texture.TextureCoords;
+import com.sun.opengl.util.texture.TextureData;
+import com.sun.opengl.util.texture.TextureIO;
import java.awt.AlphaComposite;
import java.awt.Color;
import java.awt.GradientPaint;
-import java.awt.Graphics;
import java.awt.Graphics2D;
import java.awt.Rectangle;
-import java.awt.event.*;
-import java.awt.image.*;
-import javax.swing.*;
-import java.util.*;
+import java.awt.event.ActionEvent;
+import java.awt.event.ActionListener;
+import java.awt.event.InputEvent;
+import java.awt.event.KeyEvent;
+import java.awt.event.MouseAdapter;
+import java.awt.event.MouseEvent;
+import java.awt.event.MouseMotionAdapter;
+import java.awt.image.BufferedImage;
+import java.util.ArrayList;
+import java.util.Iterator;
+import java.util.List;
+import javax.media.opengl.GL;
+import javax.media.opengl.GL2;
+import javax.media.opengl.GLAutoDrawable;
+import javax.media.opengl.GLEventListener;
+import javax.media.opengl.awt.GLCanvas;
+import javax.media.opengl.glu.GLU;
+import javax.swing.JCheckBoxMenuItem;
+import javax.swing.JFrame;
+import javax.swing.JMenu;
+import javax.swing.JMenuBar;
+import javax.swing.JMenuItem;
+import javax.swing.JPopupMenu;
+import javax.swing.KeyStroke;
+
-import javax.media.opengl.*;
-import javax.media.opengl.glu.*;
-import com.sun.opengl.util.texture.*;
/** Demonstrates and tests updates of sub-rectangles of a Texture
generated from a BufferedImage. Draws a cursor in texel space
@@ -87,7 +108,7 @@ public class TestSubImage {
}
public void display(GLAutoDrawable drawable) {
- GL gl = drawable.getGL();
+ GL2 gl = drawable.getGL().getGL2();
gl.glClear(GL.GL_COLOR_BUFFER_BIT | GL.GL_DEPTH_BUFFER_BIT);
if (convertedImage == null) {
@@ -165,9 +186,9 @@ public class TestSubImage {
// Now draw one quad with the texture
texture.enable();
texture.bind();
- gl.glTexEnvi(GL.GL_TEXTURE_ENV, GL.GL_TEXTURE_ENV_MODE, GL.GL_REPLACE);
+ gl.glTexEnvi(GL2.GL_TEXTURE_ENV, GL2.GL_TEXTURE_ENV_MODE, GL2.GL_REPLACE);
TextureCoords coords = texture.getImageTexCoords();
- gl.glBegin(GL.GL_QUADS);
+ gl.glBegin(GL2.GL_QUADS);
gl.glTexCoord2f(coords.left(), coords.bottom());
gl.glVertex3f(0, 0, 0);
gl.glTexCoord2f(coords.right(), coords.bottom());
diff --git a/src/demos/texture/TestTexture.java b/src/demos/texture/TestTexture.java
index ff0ff14..c32fc8c 100755
--- a/src/demos/texture/TestTexture.java
+++ b/src/demos/texture/TestTexture.java
@@ -39,14 +39,34 @@
package demos.texture;
-import java.awt.geom.*;
-import java.awt.event.*;
-import java.io.*;
-import javax.swing.*;
+import com.sun.opengl.util.texture.Texture;
+import com.sun.opengl.util.texture.TextureCoords;
+import com.sun.opengl.util.texture.TextureIO;
+import java.awt.event.ActionEvent;
+import java.awt.event.ActionListener;
+import java.awt.event.InputEvent;
+import java.awt.event.KeyEvent;
+import java.io.ByteArrayOutputStream;
+import java.io.File;
+import java.io.IOException;
+import java.io.PrintStream;
+import javax.media.opengl.DebugGL2;
+import javax.media.opengl.GL;
+import javax.media.opengl.GL2;
+import javax.media.opengl.GLAutoDrawable;
+import javax.media.opengl.GLEventListener;
+import javax.media.opengl.awt.GLCanvas;
+import javax.media.opengl.glu.GLU;
+import javax.swing.JFileChooser;
+import javax.swing.JFrame;
+import javax.swing.JMenu;
+import javax.swing.JMenuBar;
+import javax.swing.JMenuItem;
+import javax.swing.JOptionPane;
+import javax.swing.JPopupMenu;
+import javax.swing.KeyStroke;
+
-import javax.media.opengl.*;
-import javax.media.opengl.glu.*;
-import com.sun.opengl.util.texture.*;
/** Demonstrates simple use of the TextureIO texture loader. */
@@ -109,7 +129,7 @@ public class TestTexture implements GLEventListener {
frame.getContentPane().add(canvas);
frame.setJMenuBar(menuBar);
frame.setSize(800, 600);
- frame.show();
+ frame.setVisible(true);
}
private boolean newTexture;
@@ -128,9 +148,10 @@ public class TestTexture implements GLEventListener {
}
public void init(GLAutoDrawable drawable) {
- drawable.setGL(new DebugGL(drawable.getGL()));
GL gl = drawable.getGL();
+ drawable.setGL(new DebugGL2(gl.getGL2()));
+
gl.glClearColor(0, 0, 0, 0);
gl.glEnable(GL.GL_DEPTH_TEST);
}
@@ -145,7 +166,7 @@ public class TestTexture implements GLEventListener {
}
public void display(GLAutoDrawable drawable) {
- GL gl = drawable.getGL();
+ GL2 gl = drawable.getGL().getGL2();
gl.glClear(GL.GL_COLOR_BUFFER_BIT | GL.GL_DEPTH_BUFFER_BIT);
if (flushTexture) {
@@ -183,10 +204,10 @@ public class TestTexture implements GLEventListener {
if (texture != null) {
texture.enable();
texture.bind();
- gl.glTexEnvi(GL.GL_TEXTURE_ENV, GL.GL_TEXTURE_ENV_MODE, GL.GL_REPLACE);
+ gl.glTexEnvi(GL2.GL_TEXTURE_ENV, GL2.GL_TEXTURE_ENV_MODE, GL.GL_REPLACE);
TextureCoords coords = texture.getImageTexCoords();
- gl.glBegin(GL.GL_QUADS);
+ gl.glBegin(GL2.GL_QUADS);
gl.glTexCoord2f(coords.left(), coords.bottom());
gl.glVertex3f(0, 0, 0);
gl.glTexCoord2f(coords.right(), coords.bottom());
diff --git a/src/demos/texture/TextureConvert.java b/src/demos/texture/TextureConvert.java
index 728aa9c..cd0a033 100755
--- a/src/demos/texture/TextureConvert.java
+++ b/src/demos/texture/TextureConvert.java
@@ -39,12 +39,18 @@
package demos.texture;
-import java.io.*;
+import com.sun.opengl.impl.io.FileUtil;
+import com.sun.opengl.util.texture.Texture;
+import com.sun.opengl.util.texture.TextureData;
+import com.sun.opengl.util.texture.TextureIO;
+import java.io.File;
+import java.io.IOException;
+import javax.media.opengl.GL;
+import javax.media.opengl.GLCapabilities;
+import javax.media.opengl.GLDrawableFactory;
+import javax.media.opengl.GLPbuffer;
+
-import javax.media.opengl.*;
-import javax.media.opengl.glu.*;
-import com.sun.opengl.util.*;
-import com.sun.opengl.util.texture.*;
/** Demonstrates how the TextureIO subsystem may be used to convert
textures between multiple file formats, including texture
diff --git a/src/demos/util/Bunny.java b/src/demos/util/Bunny.java
index b9565d6..c4afd0c 100644
--- a/src/demos/util/Bunny.java
+++ b/src/demos/util/Bunny.java
@@ -57,7 +57,7 @@ import javax.media.opengl.*;
public class Bunny {
/** Generates and returns a display list for the bunny model. */
- public static int gen3DObjectList(GL gl) throws IOException {
+ public static int gen3DObjectList(GL2 gl) throws IOException {
StreamTokenizer tok = new StreamTokenizer(new BufferedReader(new InputStreamReader(
Bunny.class.getClassLoader().getResourceAsStream("demos/data/models/bunny.txt"))));
// Reset tokenizer's syntax so numbers are not parsed
@@ -96,7 +96,7 @@ public class Bunny {
}
int lid = gl.glGenLists(1);
- gl.glNewList(lid, GL.GL_COMPILE);
+ gl.glNewList(lid, GL2.GL_COMPILE);
gl.glBegin(GL.GL_TRIANGLES);
for (int i = 0; i < faceIndices.length; i += 6) {
diff --git a/src/demos/util/Cubemap.java b/src/demos/util/Cubemap.java
index 52e2977..61b942a 100755
--- a/src/demos/util/Cubemap.java
+++ b/src/demos/util/Cubemap.java
@@ -39,15 +39,20 @@
package demos.util;
-import java.io.*;
+import com.sun.opengl.impl.io.FileUtil;
+import com.sun.opengl.util.texture.Texture;
+import com.sun.opengl.util.texture.TextureData;
+import com.sun.opengl.util.texture.TextureIO;
+import java.io.IOException;
+import javax.media.opengl.GL;
+import javax.media.opengl.GLException;
+
-import javax.media.opengl.*;
-import com.sun.opengl.util.*;
-import com.sun.opengl.util.texture.*;
/** Helper class for loading cubemaps from a set of textures. */
public class Cubemap {
+
private static final String[] suffixes = { "posx", "negx", "posy", "negy", "posz", "negz" };
private static final int[] targets = { GL.GL_TEXTURE_CUBE_MAP_POSITIVE_X,
GL.GL_TEXTURE_CUBE_MAP_NEGATIVE_X,
diff --git a/src/demos/util/DxTex.java b/src/demos/util/DxTex.java
index 433a2b4..fbe1963 100644
--- a/src/demos/util/DxTex.java
+++ b/src/demos/util/DxTex.java
@@ -101,7 +101,7 @@ public class DxTex {
desktop = new JDesktopPane();
frame.getContentPane().add(desktop);
frame.setSize(640, 480);
- frame.show();
+ frame.setVisible(true);
frameListener = new InternalFrameAdapter() {
public void internalFrameActivated(InternalFrameEvent e) {
@@ -219,7 +219,7 @@ public class DxTex {
try {
ImageFrame fr = new ImageFrame(filename, image, mipMapLevel);
desktop.add(fr);
- fr.show();
+ fr.setVisible(true);
} catch (Exception e) {
showMessageDialog("Error while loading file:" + endl +
exceptionToString(e),
diff --git a/src/demos/util/FPSCounter.java b/src/demos/util/FPSCounter.java
index b0ca200..1251d64 100755
--- a/src/demos/util/FPSCounter.java
+++ b/src/demos/util/FPSCounter.java
@@ -39,12 +39,14 @@
package demos.util;
+import com.sun.opengl.util.texture.Texture;
import java.awt.Font;
-import java.awt.geom.*;
-import java.text.*;
+import java.awt.geom.Rectangle2D;
+import java.text.DecimalFormat;
+import javax.media.opengl.GLDrawable;
+import javax.media.opengl.GLException;
+
-import javax.media.opengl.*;
-import com.sun.opengl.util.j2d.*;
/** A simple class which uses the TextRenderer to provide an FPS
counter overlaid on top of the scene. */
diff --git a/src/demos/util/ObjReader.java b/src/demos/util/ObjReader.java
index 51da398..33f5c21 100644
--- a/src/demos/util/ObjReader.java
+++ b/src/demos/util/ObjReader.java
@@ -39,11 +39,22 @@
package demos.util;
-import java.io.*;
-import java.nio.*;
-import java.util.*;
+import java.io.BufferedReader;
+import java.io.File;
+import java.io.FileReader;
+import java.io.IOException;
+import java.io.InputStream;
+import java.io.InputStreamReader;
+import java.io.Reader;
+import java.nio.FloatBuffer;
+import java.util.ArrayList;
+import java.util.HashMap;
+import java.util.Iterator;
+import java.util.List;
+import java.util.StringTokenizer;
+import javax.media.opengl.util.BufferUtil;
+
-import com.sun.opengl.util.*;
/** Simple parser for Wavefront .OBJ files. Does not support all file
options -- currently requires vertices and normals (only) to be
diff --git a/src/demos/util/Triceratops.java b/src/demos/util/Triceratops.java
index c7fa115..55857f0 100644
--- a/src/demos/util/Triceratops.java
+++ b/src/demos/util/Triceratops.java
@@ -39,9 +39,15 @@
package demos.util;
-import java.io.*;
+import java.io.BufferedReader;
+import java.io.IOException;
+import java.io.InputStreamReader;
+import java.io.Reader;
+import java.io.StreamTokenizer;
+import javax.media.opengl.GL;
+import javax.media.opengl.GL2;
+
-import javax.media.opengl.*;
/** Renders a triceratops. <P>
@@ -55,7 +61,7 @@ public class Triceratops {
/** Draws the triceratops object. Callers should capture the result
in a display list. */
- public static void drawObject(GL gl) throws IOException {
+ public static void drawObject(GL2 gl) throws IOException {
Reader reader = new BufferedReader(new InputStreamReader(
Triceratops.class.getClassLoader().getResourceAsStream("demos/data/models/triceratops.txt")));
StreamTokenizer tok = new StreamTokenizer(reader);
@@ -97,7 +103,7 @@ public class Triceratops {
reader.close();
float sf = 0.1f;
- gl.glBegin(GL.GL_TRIANGLES);
+ gl.glBegin(GL2.GL_TRIANGLES);
for (int i = 0; i < faceIndices.length; i += 9) {
for (int j = 0; j < 3; j++) {
int vi = faceIndices[i + j ] & 0xFFFF;
diff --git a/src/demos/vertexArrayRange/VertexArrayRange.java b/src/demos/vertexArrayRange/VertexArrayRange.java
index 8007232..a91cb10 100644
--- a/src/demos/vertexArrayRange/VertexArrayRange.java
+++ b/src/demos/vertexArrayRange/VertexArrayRange.java
@@ -33,18 +33,27 @@
package demos.vertexArrayRange;
-import java.awt.*;
-import java.awt.event.*;
-import java.nio.*;
-import java.util.*;
-import javax.swing.*;
-
-import javax.media.opengl.*;
-import javax.media.opengl.glu.*;
-import com.sun.opengl.util.*;
-import com.sun.opengl.util.*;
-import demos.common.*;
-import demos.util.*;
+import demos.common.Demo;
+import demos.common.DemoListener;
+import java.awt.BorderLayout;
+import java.awt.Frame;
+import java.awt.event.KeyAdapter;
+import java.awt.event.KeyEvent;
+import java.awt.event.WindowAdapter;
+import java.awt.event.WindowEvent;
+import java.nio.ByteBuffer;
+import java.nio.ByteOrder;
+import java.nio.FloatBuffer;
+import java.nio.IntBuffer;
+import javax.media.opengl.GL;
+import javax.media.opengl.GL2;
+import javax.media.opengl.GLAutoDrawable;
+import javax.media.opengl.awt.GLCanvas;
+import javax.media.opengl.glu.GLU;
+import javax.media.opengl.util.Animator;
+import javax.swing.JOptionPane;
+
+
/** <P> A port of NVidia's [tm] Vertex Array Range demonstration to
OpenGL[tm] for Java[tm] and the Java programming language. The
@@ -119,7 +128,7 @@ public class VertexArrayRange extends Demo {
canvas.setSize(800, 800);
frame.add(canvas, BorderLayout.CENTER);
frame.pack();
- frame.show();
+ frame.setVisible(true);
canvas.requestFocus();
animator.start();
@@ -168,7 +177,7 @@ public class VertexArrayRange extends Demo {
private float[] cosArray;
// Primitive: GL_QUAD_STRIP, GL_LINE_STRIP, or GL_POINTS
- private int primitive = GL.GL_QUAD_STRIP;
+ private int primitive = GL2.GL_QUAD_STRIP;
// Animation parameters
private float hicoef = .06f;
@@ -273,7 +282,7 @@ public class VertexArrayRange extends Demo {
// drawable.setGL(new TraceGL(drawable.getGL(), System.err));
// drawable.setGL(new DebugGL(drawable.getGL()));
- GL gl = drawable.getGL();
+ GL2 gl = drawable.getGL().getGL2();
// Try and disable synch-to-retrace for fastest framerate
gl.setSwapInterval(0);
@@ -303,7 +312,7 @@ public class VertexArrayRange extends Demo {
gl.glMaterialf(GL.GL_FRONT_AND_BACK, GL.GL_SHININESS, 128.f);
gl.glLightfv(GL.GL_LIGHT0, GL.GL_POSITION, new float[] { .5f, 0, .5f, 0}, 0);
- gl.glLightModeli(GL.GL_LIGHT_MODEL_LOCAL_VIEWER, 0);
+ gl.glLightModeli(GL2.GL_LIGHT_MODEL_LOCAL_VIEWER, 0);
// NOTE: it looks like GLUT (or something else) sets up the
// projection matrix in the C version of this demo.
@@ -325,7 +334,7 @@ public class VertexArrayRange extends Demo {
}
if (getFlag('v')) {
- gl.glEnableClientState(GL.GL_VERTEX_ARRAY_RANGE_NV);
+ gl.glEnableClientState(GL2.GL_VERTEX_ARRAY_RANGE_NV);
gl.glVertexArrayRangeNV(bufferSize, bigArrayVar);
bigArray = bigArrayVar;
} else {
@@ -382,17 +391,17 @@ public class VertexArrayRange extends Demo {
if (k == 'w') {
if (getFlag(k)) {
- primitive = GL.GL_LINE_STRIP;
+ primitive = GL2.GL_LINE_STRIP;
} else {
- primitive = GL.GL_QUAD_STRIP;
+ primitive = GL2.GL_QUAD_STRIP;
}
}
if (k == 'p') {
if (getFlag(k)) {
- primitive = GL.GL_POINTS;
+ primitive = GL2.GL_POINTS;
} else {
- primitive = GL.GL_QUAD_STRIP;
+ primitive = GL2.GL_QUAD_STRIP;
}
}
@@ -451,7 +460,7 @@ public class VertexArrayRange extends Demo {
}
public void display(GLAutoDrawable drawable) {
- GL gl = drawable.getGL();
+ GL2 gl = drawable.getGL().getGL2();
// Check to see whether to animate
if (getFlag(' ')) {
@@ -500,10 +509,10 @@ public class VertexArrayRange extends Demo {
if(getFlag('i')) {
// infinite light
gl.glLightfv(GL.GL_LIGHT0, GL.GL_POSITION, new float[] { .5f, 0, .5f, 0 }, 0);
- gl.glLightModeli(GL.GL_LIGHT_MODEL_LOCAL_VIEWER, 0);
+ gl.glLightModeli(GL2.GL_LIGHT_MODEL_LOCAL_VIEWER, 0);
} else {
gl.glLightfv(GL.GL_LIGHT0, GL.GL_POSITION, new float[] { .5f, 0, -.5f, 1 }, 0);
- gl.glLightModeli(GL.GL_LIGHT_MODEL_LOCAL_VIEWER, 1);
+ gl.glLightModeli(GL2.GL_LIGHT_MODEL_LOCAL_VIEWER, 1);
}
toggleLightingModel = false;
}
diff --git a/src/demos/vertexBufferObject/VertexBufferObject.java b/src/demos/vertexBufferObject/VertexBufferObject.java
index e58d0fa..efd8ee0 100644
--- a/src/demos/vertexBufferObject/VertexBufferObject.java
+++ b/src/demos/vertexBufferObject/VertexBufferObject.java
@@ -33,17 +33,29 @@
package demos.vertexBufferObject;
-import java.awt.*;
-import java.awt.event.*;
-import java.nio.*;
-import java.util.*;
-import javax.swing.*;
-
-import javax.media.opengl.*;
-import javax.media.opengl.glu.*;
-import com.sun.opengl.util.*;
-import demos.common.*;
-import demos.util.*;
+import demos.common.Demo;
+import demos.common.DemoListener;
+import java.awt.BorderLayout;
+import java.awt.Frame;
+import java.awt.event.KeyAdapter;
+import java.awt.event.KeyEvent;
+import java.awt.event.WindowAdapter;
+import java.awt.event.WindowEvent;
+import java.nio.Buffer;
+import java.nio.ByteBuffer;
+import java.nio.ByteOrder;
+import java.nio.FloatBuffer;
+import java.nio.IntBuffer;
+import javax.media.opengl.GL;
+import javax.media.opengl.GL2;
+import javax.media.opengl.GLAutoDrawable;
+import javax.media.opengl.awt.GLCanvas;
+import javax.media.opengl.glu.GLU;
+import javax.media.opengl.util.Animator;
+import javax.media.opengl.util.BufferUtil;
+import javax.swing.JOptionPane;
+
+
/** <P> A port of NVidia's [tm] Vertex Array Range demonstration to
OpenGL[tm] for Java[tm], the Java programming language, and the
@@ -55,7 +67,7 @@ import demos.util.*;
<ul>
<li> A JDK 1.4 implementation
- <li> A card supporting the GL_ARB_vertex_buffer_object extension
+ <li> A card supporting the GL_vertex_buffer_object extension
(only in recent drivers)
</ul>
@@ -64,12 +76,14 @@ import demos.util.*;
<P> This demonstration illustrates the use of the java.nio direct
buffer classes in JDK 1.4 to access memory outside of the Java
garbage-collected heap, in particular that returned from the call
- glMapBufferARB, to achieve higher performance than accessing the
+ glMapBuffer, to achieve higher performance than accessing the
same data in system memory allows. </P>
*/
public class VertexBufferObject extends Demo {
+
public static void main(String[] args) {
+
boolean vboEnabled = true;
if (args.length > 1) {
@@ -85,10 +99,16 @@ public class VertexBufferObject extends Demo {
}
GLCanvas canvas = new GLCanvas();
- VertexBufferObject demo = new VertexBufferObject();
+ final VertexBufferObject demo = new VertexBufferObject();
demo.vboEnabled = vboEnabled;
canvas.addGLEventListener(demo);
+ canvas.addKeyListener(new KeyAdapter() {
+ public void keyTyped(KeyEvent e) {
+ demo.dispatchKey(e.getKeyChar());
+ }
+ });
+
final Animator animator = new Animator(canvas);
animator.setRunAsFastAsPossible(true);
demo.setDemoListener(new DemoListener() {
@@ -108,7 +128,7 @@ public class VertexBufferObject extends Demo {
canvas.setSize(800, 800);
frame.add(canvas, BorderLayout.CENTER);
frame.pack();
- frame.show();
+ frame.setVisible(true);
canvas.requestFocus();
animator.start();
@@ -164,7 +184,7 @@ public class VertexBufferObject extends Demo {
private float[] cosArray;
// Primitive: GL_QUAD_STRIP, GL_LINE_STRIP, or GL_POINTS
- private int primitive = GL.GL_QUAD_STRIP;
+ private int primitive = GL2.GL_QUAD_STRIP;
// Animation parameters
private float hicoef = .06f;
@@ -187,7 +207,6 @@ public class VertexBufferObject extends Demo {
private volatile boolean toggleLighting = false;
private volatile boolean toggleLightingModel = false;
private volatile boolean recomputeElements = false;
- private volatile boolean quit = false;
// Frames-per-second computation
private boolean firstProfiledFrame;
@@ -275,13 +294,13 @@ public class VertexBufferObject extends Demo {
// drawable.setGL(new TraceGL(drawable.getGL(), System.err));
// drawable.setGL(new DebugGL(drawable.getGL()));
- GL gl = drawable.getGL();
+ GL2 gl = drawable.getGL().getGL2();
// Try and disable synch-to-retrace for fastest framerate
gl.setSwapInterval(0);
try {
- initExtension(gl, "GL_ARB_vertex_buffer_object");
+ initExtension(gl, "GL_vertex_buffer_object");
} catch (RuntimeException e) {
throw (e);
}
@@ -299,7 +318,7 @@ public class VertexBufferObject extends Demo {
gl.glMaterialf(GL.GL_FRONT_AND_BACK, GL.GL_SHININESS, 128.f);
gl.glLightfv(GL.GL_LIGHT0, GL.GL_POSITION, new float[] { .5f, 0, .5f, 0}, 0);
- gl.glLightModeli(GL.GL_LIGHT_MODEL_LOCAL_VIEWER, 0);
+ gl.glLightModeli(GL2.GL_LIGHT_MODEL_LOCAL_VIEWER, 0);
// NOTE: it looks like GLUT (or something else) sets up the
// projection matrix in the C version of this demo.
@@ -331,11 +350,6 @@ public class VertexBufferObject extends Demo {
computeElements(gl);
- drawable.addKeyListener(new KeyAdapter() {
- public void keyTyped(KeyEvent e) {
- dispatchKey(e.getKeyChar());
- }
- });
initComplete = true;
}
@@ -378,7 +392,7 @@ public class VertexBufferObject extends Demo {
if (getFlag(k)) {
primitive = GL.GL_LINE_STRIP;
} else {
- primitive = GL.GL_QUAD_STRIP;
+ primitive = GL2.GL_QUAD_STRIP;
}
}
@@ -386,7 +400,7 @@ public class VertexBufferObject extends Demo {
if (getFlag(k)) {
primitive = GL.GL_POINTS;
} else {
- primitive = GL.GL_QUAD_STRIP;
+ primitive = GL2.GL_QUAD_STRIP;
}
}
@@ -449,7 +463,7 @@ public class VertexBufferObject extends Demo {
return;
}
- GL gl = drawable.getGL();
+ GL2 gl = drawable.getGL().getGL2();
// Check to see whether to animate
if (getFlag(' ')) {
@@ -494,10 +508,10 @@ public class VertexBufferObject extends Demo {
if(getFlag('i')) {
// infinite light
gl.glLightfv(GL.GL_LIGHT0, GL.GL_POSITION, new float[] { .5f, 0, .5f, 0 }, 0);
- gl.glLightModeli(GL.GL_LIGHT_MODEL_LOCAL_VIEWER, 0);
+ gl.glLightModeli(GL2.GL_LIGHT_MODEL_LOCAL_VIEWER, 0);
} else {
gl.glLightfv(GL.GL_LIGHT0, GL.GL_POSITION, new float[] { .5f, 0, -.5f,1 }, 0);
- gl.glLightModeli(GL.GL_LIGHT_MODEL_LOCAL_VIEWER, 1);
+ gl.glLightModeli(GL2.GL_LIGHT_MODEL_LOCAL_VIEWER, 1);
}
toggleLightingModel = false;
}
@@ -527,16 +541,16 @@ public class VertexBufferObject extends Demo {
int numSlabs = tileSize / STRIP_SIZE;
if (vboEnabled) {
- gl.glBindBufferARB(GL.GL_ARRAY_BUFFER_ARB, bigBufferObject);
+ gl.glBindBuffer(GL.GL_ARRAY_BUFFER, bigBufferObject);
} else {
- gl.glBindBufferARB(GL.GL_ARRAY_BUFFER_ARB, 0);
+ gl.glBindBuffer(GL.GL_ARRAY_BUFFER, 0);
}
for(int slab = numSlabs; --slab>=0; ) {
cur = slab % numBuffers;
if (vboEnabled) {
- ByteBuffer tmp = gl.glMapBufferARB(GL.GL_ARRAY_BUFFER_ARB, GL.GL_WRITE_ONLY_ARB);
+ ByteBuffer tmp = gl.glMapBuffer(GL.GL_ARRAY_BUFFER, GL2.GL_WRITE_ONLY);
if (tmp == null) {
throw new RuntimeException("Unable to map vertex buffer object");
}
@@ -618,27 +632,27 @@ public class VertexBufferObject extends Demo {
hiX.reset();
if (vboEnabled) {
- gl.glUnmapBufferARB(GL.GL_ARRAY_BUFFER_ARB);
+ gl.glUnmapBuffer(GL.GL_ARRAY_BUFFER);
}
if (getFlag('m')) {
// Elements merged into buffer object (doesn't seem to improve performance)
int len = tileSize - 1;
- gl.glBindBufferARB(GL.GL_ELEMENT_ARRAY_BUFFER_ARB, elementBufferObject);
+ gl.glBindBuffer(GL.GL_ELEMENT_ARRAY_BUFFER, elementBufferObject);
for (int i = 0; i < len; i++) {
++numDrawElementsCalls;
- gl.glDrawElements(primitive, 2 * STRIP_SIZE, GL.GL_UNSIGNED_INT,
+ gl.glDrawElements(primitive, 2 * STRIP_SIZE, GL2.GL_UNSIGNED_INT,
i * 2 * STRIP_SIZE * BufferUtil.SIZEOF_INT);
if(getFlag('f')) {
gl.glFlush();
}
}
- gl.glBindBufferARB(GL.GL_ELEMENT_ARRAY_BUFFER_ARB, 0);
+ gl.glBindBuffer(GL.GL_ELEMENT_ARRAY_BUFFER, 0);
} else {
for (int i = 0; i < elements.length; i++) {
++numDrawElementsCalls;
- gl.glDrawElements(primitive, elements[i].remaining(), GL.GL_UNSIGNED_INT, elements[i]);
+ gl.glDrawElements(primitive, elements[i].remaining(), GL2.GL_UNSIGNED_INT, elements[i]);
if(getFlag('f')) {
gl.glFlush();
}
@@ -674,20 +688,20 @@ public class VertexBufferObject extends Demo {
// Unused routines
public void displayChanged(GLAutoDrawable drawable, boolean modeChanged, boolean deviceChanged) {}
- private void allocateBigArray(GL gl) {
+ private void allocateBigArray(GL2 gl) {
bigArraySystem = setupBuffer(ByteBuffer.allocateDirect(bufferSize));
int[] tmp = new int[1];
- gl.glGenBuffersARB(1, tmp, 0);
+ gl.glGenBuffers(1, tmp, 0);
bigBufferObject = tmp[0];
- gl.glBindBufferARB(GL.GL_ARRAY_BUFFER_ARB, bigBufferObject);
+ gl.glBindBuffer(GL.GL_ARRAY_BUFFER, bigBufferObject);
// Initialize data store of buffer object
- gl.glBufferDataARB(GL.GL_ARRAY_BUFFER_ARB, bufferSize, (Buffer) null, GL.GL_DYNAMIC_DRAW_ARB);
- bigArrayVBOBytes = gl.glMapBufferARB(GL.GL_ARRAY_BUFFER_ARB, GL.GL_WRITE_ONLY_ARB);
+ gl.glBufferData(GL.GL_ARRAY_BUFFER, bufferSize, (Buffer) null, GL.GL_DYNAMIC_DRAW);
+ bigArrayVBOBytes = gl.glMapBuffer(GL.GL_ARRAY_BUFFER, GL2.GL_WRITE_ONLY);
bigArrayVBO = setupBuffer(bigArrayVBOBytes);
- gl.glUnmapBufferARB(GL.GL_ARRAY_BUFFER_ARB);
+ gl.glUnmapBuffer(GL.GL_ARRAY_BUFFER);
// Unbind buffer; will be bound again in main loop
- gl.glBindBufferARB(GL.GL_ARRAY_BUFFER_ARB, 0);
+ gl.glBindBuffer(GL.GL_ARRAY_BUFFER, 0);
float megabytes = (bufferSize / 1000000.f);
System.err.println("Allocated " + megabytes + " megabytes of fast memory");
@@ -707,7 +721,7 @@ public class VertexBufferObject extends Demo {
return ret;
}
- private void computeElements(GL gl) {
+ private void computeElements(GL2 gl) {
xyArray = new float[tileSize];
for (int i = 0; i < tileSize; i++) {
xyArray[i] = i / (tileSize - 1.0f) - 0.5f;
@@ -732,14 +746,14 @@ public class VertexBufferObject extends Demo {
}
}
int[] tmp = new int[1];
- gl.glGenBuffersARB(1, tmp, 0);
+ gl.glGenBuffers(1, tmp, 0);
elementBufferObject = tmp[0];
- gl.glBindBufferARB(GL.GL_ELEMENT_ARRAY_BUFFER_ARB, elementBufferObject);
- gl.glBufferDataARB(GL.GL_ELEMENT_ARRAY_BUFFER_ARB,
+ gl.glBindBuffer(GL.GL_ELEMENT_ARRAY_BUFFER, elementBufferObject);
+ gl.glBufferData(GL.GL_ELEMENT_ARRAY_BUFFER,
linearElements.remaining() * BufferUtil.SIZEOF_INT,
linearElements,
- GL.GL_STATIC_DRAW_ARB);
- gl.glBindBufferARB(GL.GL_ELEMENT_ARRAY_BUFFER_ARB, 0);
+ GL.GL_STATIC_DRAW);
+ gl.glBindBuffer(GL.GL_ELEMENT_ARRAY_BUFFER, 0);
}
private static void runExit(final Animator animator) {
diff --git a/src/demos/vertexProgRefract/VertexProgRefract.java b/src/demos/vertexProgRefract/VertexProgRefract.java
index 11daed9..7717a36 100644
--- a/src/demos/vertexProgRefract/VertexProgRefract.java
+++ b/src/demos/vertexProgRefract/VertexProgRefract.java
@@ -33,24 +33,37 @@
package demos.vertexProgRefract;
-import java.awt.*;
-import java.awt.event.*;
-import java.awt.image.*;
-import java.io.*;
-import java.nio.*;
-import java.util.*;
-import javax.imageio.*;
-import javax.imageio.stream.*;
-import javax.swing.*;
-
-import javax.media.opengl.*;
-import javax.media.opengl.glu.*;
-import com.sun.opengl.util.*;
-import com.sun.opengl.util.texture.*;
-import demos.common.*;
-import demos.util.*;
-import gleem.*;
-import gleem.linalg.*;
+import com.sun.opengl.util.glut.gl2.GLUTgl2;
+import com.sun.opengl.util.texture.Texture;
+import demos.common.Demo;
+import demos.common.DemoListener;
+import demos.util.Bunny;
+import demos.util.Cubemap;
+import demos.util.SystemTime;
+import demos.util.Time;
+import gleem.BSphere;
+import gleem.BSphereProvider;
+import gleem.ExaminerViewer;
+import gleem.ManipManager;
+import gleem.MouseButtonHelper;
+import gleem.linalg.Rotf;
+import gleem.linalg.Vec3f;
+import java.awt.BorderLayout;
+import java.awt.Frame;
+import java.awt.event.KeyAdapter;
+import java.awt.event.KeyEvent;
+import java.awt.event.WindowAdapter;
+import java.awt.event.WindowEvent;
+import java.io.IOException;
+import javax.media.opengl.GL;
+import javax.media.opengl.GL2;
+import javax.media.opengl.GLAutoDrawable;
+import javax.media.opengl.awt.GLCanvas;
+import javax.media.opengl.glu.GLU;
+import javax.media.opengl.util.Animator;
+import javax.swing.JOptionPane;
+
+
/**
Wavelength-dependent refraction demo<br>
@@ -66,9 +79,16 @@ import gleem.linalg.*;
public class VertexProgRefract extends Demo {
public static void main(String[] args) {
+
GLCanvas canvas = new GLCanvas();
- VertexProgRefract demo = new VertexProgRefract();
+ final VertexProgRefract demo = new VertexProgRefract();
+
canvas.addGLEventListener(demo);
+ canvas.addKeyListener(new KeyAdapter() {
+ public void keyTyped(KeyEvent e) {
+ demo.dispatchKey(e.getKeyChar());
+ }
+ });
final Animator animator = new Animator(canvas);
demo.setDemoListener(new DemoListener() {
@@ -83,7 +103,7 @@ public class VertexProgRefract extends Demo {
canvas.setSize(512, 512);
frame.add(canvas, BorderLayout.CENTER);
frame.pack();
- frame.show();
+ frame.setVisible(true);
canvas.requestFocus();
frame.addWindowListener(new WindowAdapter() {
@@ -105,7 +125,7 @@ public class VertexProgRefract extends Demo {
private int obj;
private GLU glu = new GLU();
- private GLUT glut = new GLUT();
+ private GLUTgl2 glut = new GLUTgl2();
private GLAutoDrawable drawable;
private ExaminerViewer viewer;
@@ -224,21 +244,24 @@ public class VertexProgRefract extends Demo {
"END\n";
public void init(GLAutoDrawable drawable) {
+
initComplete = false;
- GL gl = drawable.getGL();
+
+ GL2 gl = drawable.getGL().getGL2();
+
float cc = 1.0f;
gl.glClearColor(cc, cc, cc, 1);
gl.glColor3f(1,1,1);
gl.glEnable(GL.GL_DEPTH_TEST);
try {
- initExtension(gl, "GL_ARB_vertex_program");
+ initExtension(gl, "GL_vertex_program");
initExtension(gl, "GL_VERSION_1_3"); // For multitexturing support
- if (!gl.isExtensionAvailable("GL_ARB_fragment_program")) {
+ if (!gl.isExtensionAvailable("GL_fragment_program")) {
if (gl.isExtensionAvailable("GL_NV_register_combiners")) {
useRegisterCombiners = true;
} else {
- final String message = "This demo requires either the GL_ARB_fragment_program\n" +
+ final String message = "This demo requires either the GL_fragment_program\n" +
"or GL_NV_register_combiners extension";
new Thread(new Runnable() {
public void run() {
@@ -257,17 +280,17 @@ public class VertexProgRefract extends Demo {
b[' '] = true; // animate by default
int[] vtxProgTmp = new int[1];
- gl.glGenProgramsARB(1, vtxProgTmp, 0);
+ gl.glGenPrograms(1, vtxProgTmp, 0);
vtxProg = vtxProgTmp[0];
- gl.glBindProgramARB (GL.GL_VERTEX_PROGRAM_ARB, vtxProg);
- gl.glProgramStringARB(GL.GL_VERTEX_PROGRAM_ARB, GL.GL_PROGRAM_FORMAT_ASCII_ARB, transformRefract.length(), transformRefract);
+ gl.glBindProgram(GL2.GL_VERTEX_PROGRAM, vtxProg);
+ gl.glProgramString(GL2.GL_VERTEX_PROGRAM, GL2.GL_PROGRAM_FORMAT_ASCII, transformRefract.length(), transformRefract);
- gl.glProgramEnvParameter4fARB(GL.GL_VERTEX_PROGRAM_ARB, 0, 0.0f, 0.0f, 0.0f, 1.0f); // eye position
+ gl.glProgramEnvParameter4f(GL2.GL_VERTEX_PROGRAM, 0, 0.0f, 0.0f, 0.0f, 1.0f); // eye position
- gl.glProgramEnvParameter4fARB(GL.GL_VERTEX_PROGRAM_ARB, 1, fresnel, fresnel, fresnel, 1.0f); // fresnel multiplier
+ gl.glProgramEnvParameter4f(GL2.GL_VERTEX_PROGRAM, 1, fresnel, fresnel, fresnel, 1.0f); // fresnel multiplier
- gl.glProgramEnvParameter4fARB(GL.GL_VERTEX_PROGRAM_ARB, 2, 1.0f, -1.0f, 1.0f, 0.0f); // texture scale
- gl.glProgramEnvParameter4fARB(GL.GL_VERTEX_PROGRAM_ARB, 3, 0.0f, 1.0f, 2.0f, 3.0f); // misc constants
+ gl.glProgramEnvParameter4f(GL2.GL_VERTEX_PROGRAM, 2, 1.0f, -1.0f, 1.0f, 0.0f); // texture scale
+ gl.glProgramEnvParameter4f(GL2.GL_VERTEX_PROGRAM, 3, 0.0f, 1.0f, 2.0f, 3.0f); // misc constants
try {
cubemap = Cubemap.loadFromStreams(getClass().getClassLoader(),
@@ -279,7 +302,7 @@ public class VertexProgRefract extends Demo {
throw new RuntimeException(e);
}
- gl.glTexEnvi(GL.GL_TEXTURE_ENV, GL.GL_TEXTURE_ENV_MODE, GL.GL_REPLACE);
+ gl.glTexEnvi(GL2.GL_TEXTURE_ENV, GL2.GL_TEXTURE_ENV_MODE, GL.GL_REPLACE);
gl.glDisable(GL.GL_CULL_FACE);
@@ -302,12 +325,6 @@ public class VertexProgRefract extends Demo {
if (firstRender) {
firstRender = false;
- drawable.addKeyListener(new KeyAdapter() {
- public void keyTyped(KeyEvent e) {
- dispatchKey(e.getKeyChar());
- }
- });
-
// Register the window with the ManipManager
ManipManager manager = ManipManager.getManipManager();
manager.registerWindow(drawable);
@@ -336,7 +353,7 @@ public class VertexProgRefract extends Demo {
time.update();
- GL gl = drawable.getGL();
+ GL2 gl = drawable.getGL().getGL2();
gl.glClear(GL.GL_COLOR_BUFFER_BIT|GL.GL_DEPTH_BUFFER_BIT);
if (doViewAll) {
@@ -352,9 +369,9 @@ public class VertexProgRefract extends Demo {
toggleWire = false;
wire = !wire;
if (wire) {
- gl.glPolygonMode(GL.GL_FRONT_AND_BACK, GL.GL_LINE);
+ gl.glPolygonMode(GL.GL_FRONT_AND_BACK, GL2.GL_LINE);
} else {
- gl.glPolygonMode(GL.GL_FRONT_AND_BACK, GL.GL_FILL);
+ gl.glPolygonMode(GL.GL_FRONT_AND_BACK, GL2.GL_FILL);
}
}
@@ -369,10 +386,10 @@ public class VertexProgRefract extends Demo {
ManipManager.getManipManager().updateCameraParameters(drawable, viewer.getCameraParameters());
ManipManager.getManipManager().render(drawable, gl);
- gl.glBindProgramARB(GL.GL_VERTEX_PROGRAM_ARB, vtxProg);
+ gl.glBindProgram(GL2.GL_VERTEX_PROGRAM, vtxProg);
- gl.glEnable(GL.GL_VERTEX_PROGRAM_ARB);
- gl.glProgramEnvParameter4fARB(GL.GL_VERTEX_PROGRAM_ARB, 62, fresnel, fresnel, fresnel, 1.0f);
+ gl.glEnable(GL2.GL_VERTEX_PROGRAM);
+ gl.glProgramEnvParameter4f(GL2.GL_VERTEX_PROGRAM, 62, fresnel, fresnel, fresnel, 1.0f);
// set texture transforms
gl.glActiveTexture(GL.GL_TEXTURE0);
@@ -390,10 +407,10 @@ public class VertexProgRefract extends Demo {
viewer.updateInverseRotation(gl);
if (useRegisterCombiners) {
- gl.glEnable(GL.GL_REGISTER_COMBINERS_NV);
+ gl.glEnable(GL2.GL_REGISTER_COMBINERS_NV);
} else {
- gl.glBindProgramARB(GL.GL_FRAGMENT_PROGRAM_ARB, fragProg);
- gl.glEnable(GL.GL_FRAGMENT_PROGRAM_ARB);
+ gl.glBindProgram(GL2.GL_FRAGMENT_PROGRAM, fragProg);
+ gl.glEnable(GL2.GL_FRAGMENT_PROGRAM);
}
gl.glColor3f(1.0f, 1.0f, 1.0f);
@@ -428,11 +445,11 @@ public class VertexProgRefract extends Demo {
}
if (useRegisterCombiners) {
- gl.glDisable(GL.GL_REGISTER_COMBINERS_NV);
+ gl.glDisable(GL2.GL_REGISTER_COMBINERS_NV);
} else {
- gl.glDisable(GL.GL_FRAGMENT_PROGRAM_ARB);
+ gl.glDisable(GL2.GL_FRAGMENT_PROGRAM);
}
- gl.glDisable(GL.GL_VERTEX_PROGRAM_ARB);
+ gl.glDisable(GL2.GL_VERTEX_PROGRAM);
gl.glMatrixMode(GL.GL_MODELVIEW);
gl.glPopMatrix();
@@ -540,9 +557,9 @@ public class VertexProgRefract extends Demo {
gl.glFinalCombinerInputNV(GL.GL_VARIABLE_D_NV, GL.GL_ZERO, GL.GL_UNSIGNED_IDENTITY_NV, GL.GL_RGB);
}
- private void initFragmentProgram(GL gl) {
+ private void initFragmentProgram(GL2 gl) {
int[] fragProgTmp = new int[1];
- gl.glGenProgramsARB(1, fragProgTmp, 0);
+ gl.glGenPrograms(1, fragProgTmp, 0);
fragProg = fragProgTmp[0];
String combineFragProg =
"!!ARBfp1.0\n" +
@@ -559,14 +576,14 @@ public class VertexProgRefract extends Demo {
"MOV result.color, texSamp0;\n" +
"END";
- gl.glBindProgramARB (GL.GL_FRAGMENT_PROGRAM_ARB, fragProg);
- gl.glProgramStringARB(GL.GL_FRAGMENT_PROGRAM_ARB, GL.GL_PROGRAM_FORMAT_ASCII_ARB,
+ gl.glBindProgram(GL2.GL_FRAGMENT_PROGRAM, fragProg);
+ gl.glProgramString(GL2.GL_FRAGMENT_PROGRAM, GL2.GL_PROGRAM_FORMAT_ASCII,
combineFragProg.length(), combineFragProg);
int[] errPos = new int[1];
- gl.glGetIntegerv(GL.GL_PROGRAM_ERROR_POSITION_ARB, errPos, 0);
+ gl.glGetIntegerv(GL2.GL_PROGRAM_ERROR_POSITION, errPos, 0);
if (errPos[0] >= 0) {
System.out.println("Fragment program failed to load:");
- String errMsg = gl.glGetString(GL.GL_PROGRAM_ERROR_STRING_ARB);
+ String errMsg = gl.glGetString(GL2.GL_PROGRAM_ERROR_STRING);
if (errMsg == null) {
System.out.println("[No error message available]");
} else {
@@ -581,7 +598,7 @@ public class VertexProgRefract extends Demo {
}
}
- private void drawSkyBox(GL gl) {
+ private void drawSkyBox(GL2 gl) {
// Compensates for ExaminerViewer's modification of modelview matrix
gl.glMatrixMode(GL.GL_MODELVIEW);
gl.glLoadIdentity();
@@ -599,15 +616,15 @@ public class VertexProgRefract extends Demo {
// causes the normals to be sent down. Thanks to Ken Dyke.
gl.glEnable(GL.GL_LIGHTING);
- gl.glTexGeni(GL.GL_S, GL.GL_TEXTURE_GEN_MODE, GL.GL_NORMAL_MAP);
- gl.glTexGeni(GL.GL_T, GL.GL_TEXTURE_GEN_MODE, GL.GL_NORMAL_MAP);
- gl.glTexGeni(GL.GL_R, GL.GL_TEXTURE_GEN_MODE, GL.GL_NORMAL_MAP);
+ gl.glTexGeni(GL2.GL_S, GL2.GL_TEXTURE_GEN_MODE, GL2.GL_NORMAL_MAP);
+ gl.glTexGeni(GL2.GL_T, GL2.GL_TEXTURE_GEN_MODE, GL2.GL_NORMAL_MAP);
+ gl.glTexGeni(GL2.GL_R, GL2.GL_TEXTURE_GEN_MODE, GL2.GL_NORMAL_MAP);
- gl.glEnable(GL.GL_TEXTURE_GEN_S);
- gl.glEnable(GL.GL_TEXTURE_GEN_T);
- gl.glEnable(GL.GL_TEXTURE_GEN_R);
+ gl.glEnable(GL2.GL_TEXTURE_GEN_S);
+ gl.glEnable(GL2.GL_TEXTURE_GEN_T);
+ gl.glEnable(GL2.GL_TEXTURE_GEN_R);
- gl.glTexEnvi(GL.GL_TEXTURE_ENV, GL.GL_TEXTURE_ENV_MODE, GL.GL_REPLACE);
+ gl.glTexEnvi(GL2.GL_TEXTURE_ENV, GL2.GL_TEXTURE_ENV_MODE, GL.GL_REPLACE);
gl.glMatrixMode(GL.GL_TEXTURE);
gl.glPushMatrix();
@@ -621,12 +638,12 @@ public class VertexProgRefract extends Demo {
gl.glPopMatrix();
gl.glMatrixMode(GL.GL_MODELVIEW);
- gl.glDisable(GL.GL_TEXTURE_GEN_S);
- gl.glDisable(GL.GL_TEXTURE_GEN_T);
- gl.glDisable(GL.GL_TEXTURE_GEN_R);
+ gl.glDisable(GL2.GL_TEXTURE_GEN_S);
+ gl.glDisable(GL2.GL_TEXTURE_GEN_T);
+ gl.glDisable(GL2.GL_TEXTURE_GEN_R);
}
- private void drawObj(GL gl, int obj) {
+ private void drawObj(GL2 gl, int obj) {
switch(obj) {
case 0:
gl.glCallList(bunnydl);
@@ -646,12 +663,12 @@ public class VertexProgRefract extends Demo {
}
}
- private void setRefraction(GL gl, float index) {
- gl.glProgramEnvParameter4fARB(GL.GL_VERTEX_PROGRAM_ARB, 4, index, index*index, 0.0f, 0.0f);
+ private void setRefraction(GL2 gl, float index) {
+ gl.glProgramEnvParameter4f(GL2.GL_VERTEX_PROGRAM, 4, index, index*index, 0.0f, 0.0f);
}
// draw square subdivided into quad strips
- private void drawPlane(GL gl, float w, float h, int rows, int cols) {
+ private void drawPlane(GL2 gl, float w, float h, int rows, int cols) {
int x, y;
float vx, vy, s, t;
float ts, tt, tw, th;
@@ -665,7 +682,7 @@ public class VertexProgRefract extends Demo {
gl.glNormal3f(0.0f, 0.0f, 1.0f);
for(y=0; y<rows; y++) {
- gl.glBegin(GL.GL_QUAD_STRIP);
+ gl.glBegin(GL2.GL_QUAD_STRIP);
for(x=0; x<=cols; x++) {
vx = tw * x -(w/2.0f);
vy = th * y -(h/2.0f);
diff --git a/src/demos/vertexProgWarp/VertexProgWarp.java b/src/demos/vertexProgWarp/VertexProgWarp.java
index 4eab14d..c013647 100644
--- a/src/demos/vertexProgWarp/VertexProgWarp.java
+++ b/src/demos/vertexProgWarp/VertexProgWarp.java
@@ -33,20 +33,35 @@
package demos.vertexProgWarp;
-import java.awt.*;
-import java.awt.event.*;
-import java.io.*;
-import java.nio.*;
-import java.util.*;
-import javax.swing.*;
-
-import javax.media.opengl.*;
-import javax.media.opengl.glu.*;
-import com.sun.opengl.util.*;
-import demos.common.*;
-import demos.util.*;
-import gleem.*;
-import gleem.linalg.*;
+import demos.common.Demo;
+import demos.common.DemoListener;
+import demos.util.DurationTimer;
+import demos.util.SystemTime;
+import demos.util.Time;
+import demos.util.Triceratops;
+import gleem.BSphere;
+import gleem.BSphereProvider;
+import gleem.ExaminerViewer;
+import gleem.ManipManager;
+import gleem.MouseButtonHelper;
+import gleem.linalg.Vec3f;
+import java.awt.BorderLayout;
+import java.awt.Frame;
+import java.awt.event.KeyAdapter;
+import java.awt.event.KeyEvent;
+import java.awt.event.WindowAdapter;
+import java.awt.event.WindowEvent;
+import java.io.IOException;
+import javax.media.opengl.GL;
+import javax.media.opengl.GL2;
+import javax.media.opengl.GLAutoDrawable;
+import javax.media.opengl.awt.GLCanvas;
+import javax.media.opengl.glu.GLU;
+import javax.media.opengl.glu.GLUquadric;
+import javax.media.opengl.util.Animator;
+import javax.swing.JOptionPane;
+
+
/**
Simple space-warp/distortion vertex program demo<br>
@@ -94,7 +109,7 @@ public class VertexProgWarp extends Demo {
canvas.setSize(512, 512);
frame.add(canvas, BorderLayout.CENTER);
frame.pack();
- frame.show();
+ frame.setVisible(true);
canvas.requestFocus();
frame.addWindowListener(new WindowAdapter() {
@@ -144,7 +159,7 @@ public class VertexProgWarp extends Demo {
public void init(GLAutoDrawable drawable) {
initComplete = false;
- GL gl = drawable.getGL();
+ GL2 gl = drawable.getGL().getGL2();
float cc = 0.0f;
gl.glClearColor(cc, cc, cc, 1);
@@ -154,45 +169,45 @@ public class VertexProgWarp extends Demo {
gl.glDisable(GL.GL_CULL_FACE);
try {
- initExtension(gl, "GL_ARB_vertex_program");
+ initExtension(gl, "GL_vertex_program");
} catch (RuntimeException e) {
shutdownDemo();
throw(e);
}
for(int i=0; i<NUM_OBJS; i++) {
- gl.glNewList(i+1, GL.GL_COMPILE);
+ gl.glNewList(i+1, GL2.GL_COMPILE);
drawObject(gl, i);
gl.glEndList();
}
for(int i=0; i<NUM_PROGS; i++) {
int[] vtxProgTmp = new int[1];
- gl.glGenProgramsARB(1, vtxProgTmp, 0);
+ gl.glGenPrograms(1, vtxProgTmp, 0);
programs[i] = vtxProgTmp[0];
- gl.glBindProgramARB(GL.GL_VERTEX_PROGRAM_ARB, programs[i]);
- gl.glProgramStringARB(GL.GL_VERTEX_PROGRAM_ARB, GL.GL_PROGRAM_FORMAT_ASCII_ARB, programTexts[i].length(), programTexts[i]);
+ gl.glBindProgram(GL2.GL_VERTEX_PROGRAM, programs[i]);
+ gl.glProgramString(GL2.GL_VERTEX_PROGRAM, GL2.GL_PROGRAM_FORMAT_ASCII, programTexts[i].length(), programTexts[i]);
}
- gl.glProgramEnvParameter4fARB(GL.GL_VERTEX_PROGRAM_ARB, 0, 0.0f, 0.0f, 1.0f, 0.0f); // light position/direction
- gl.glProgramEnvParameter4fARB(GL.GL_VERTEX_PROGRAM_ARB, 1, 0.0f, 1.0f, 0.0f, 0.0f); // diffuse color
- gl.glProgramEnvParameter4fARB(GL.GL_VERTEX_PROGRAM_ARB, 2, 1.0f, 1.0f, 1.0f, 0.0f); // specular color
+ gl.glProgramEnvParameter4f(GL2.GL_VERTEX_PROGRAM, 0, 0.0f, 0.0f, 1.0f, 0.0f); // light position/direction
+ gl.glProgramEnvParameter4f(GL2.GL_VERTEX_PROGRAM, 1, 0.0f, 1.0f, 0.0f, 0.0f); // diffuse color
+ gl.glProgramEnvParameter4f(GL2.GL_VERTEX_PROGRAM, 2, 1.0f, 1.0f, 1.0f, 0.0f); // specular color
- gl.glProgramEnvParameter4fARB(GL.GL_VERTEX_PROGRAM_ARB, 3, 0.0f, 1.0f, 2.0f, 3.0f); // smoothstep constants
+ gl.glProgramEnvParameter4f(GL2.GL_VERTEX_PROGRAM, 3, 0.0f, 1.0f, 2.0f, 3.0f); // smoothstep constants
// sin Taylor series constants - 1, 1/3!, 1/5!, 1/7!
- gl.glProgramEnvParameter4fARB(GL.GL_VERTEX_PROGRAM_ARB, 4, 1.0f, 1.0f / (3*2), 1.0f / (5*4*3*2), 1.0f / (7*6*5*4*3*2));
+ gl.glProgramEnvParameter4f(GL2.GL_VERTEX_PROGRAM, 4, 1.0f, 1.0f / (3*2), 1.0f / (5*4*3*2), 1.0f / (7*6*5*4*3*2));
- gl.glProgramEnvParameter4fARB(GL.GL_VERTEX_PROGRAM_ARB, 5, 1.0f / (2.0f * SIN_PERIOD), 2.0f * SIN_PERIOD, SIN_PERIOD, SIN_PERIOD/2.0f);
+ gl.glProgramEnvParameter4f(GL2.GL_VERTEX_PROGRAM, 5, 1.0f / (2.0f * SIN_PERIOD), 2.0f * SIN_PERIOD, SIN_PERIOD, SIN_PERIOD/2.0f);
// sin wave frequency, amplitude
- gl.glProgramEnvParameter4fARB(GL.GL_VERTEX_PROGRAM_ARB, 6, 1.0f, 0.2f, 0.0f, 0.0f);
+ gl.glProgramEnvParameter4f(GL2.GL_VERTEX_PROGRAM, 6, 1.0f, 0.2f, 0.0f, 0.0f);
// phase animation
- gl.glProgramEnvParameter4fARB(GL.GL_VERTEX_PROGRAM_ARB, 7, 0.0f, 0.0f, 0.0f, 0.0f);
+ gl.glProgramEnvParameter4f(GL2.GL_VERTEX_PROGRAM, 7, 0.0f, 0.0f, 0.0f, 0.0f);
// fisheye sphere radius
- gl.glProgramEnvParameter4fARB(GL.GL_VERTEX_PROGRAM_ARB, 8, 1.0f, 0.0f, 0.0f, 0.0f);
+ gl.glProgramEnvParameter4f(GL2.GL_VERTEX_PROGRAM, 8, 1.0f, 0.0f, 0.0f, 0.0f);
setWindowTitle();
@@ -245,16 +260,16 @@ public class VertexProgWarp extends Demo {
time.update();
- GL gl = drawable.getGL();
+ GL2 gl = drawable.getGL().getGL2();
gl.glClear(GL.GL_COLOR_BUFFER_BIT | GL.GL_DEPTH_BUFFER_BIT);
if (toggleWire) {
wire = !wire;
if (wire)
- gl.glPolygonMode(GL.GL_FRONT_AND_BACK, GL.GL_LINE);
+ gl.glPolygonMode(GL.GL_FRONT_AND_BACK, GL2.GL_LINE);
else
- gl.glPolygonMode(GL.GL_FRONT_AND_BACK, GL.GL_FILL);
+ gl.glPolygonMode(GL.GL_FRONT_AND_BACK, GL2.GL_FILL);
toggleWire = false;
}
@@ -273,21 +288,21 @@ public class VertexProgWarp extends Demo {
ManipManager.getManipManager().updateCameraParameters(drawable, viewer.getCameraParameters());
ManipManager.getManipManager().render(drawable, gl);
- gl.glBindProgramARB(GL.GL_VERTEX_PROGRAM_ARB, programs[program]);
- gl.glProgramEnvParameter4fARB(GL.GL_VERTEX_PROGRAM_ARB, 7, anim, 0.0f, 0.0f, 0.0f);
+ gl.glBindProgram(GL2.GL_VERTEX_PROGRAM, programs[program]);
+ gl.glProgramEnvParameter4f(GL2.GL_VERTEX_PROGRAM, 7, anim, 0.0f, 0.0f, 0.0f);
if (program==6)
- gl.glProgramEnvParameter4fARB(GL.GL_VERTEX_PROGRAM_ARB, 6, (float) Math.sin(anim)*amp*50.0f, 0.0f, 0.0f, 0.0f);
+ gl.glProgramEnvParameter4f(GL2.GL_VERTEX_PROGRAM, 6, (float) Math.sin(anim)*amp*50.0f, 0.0f, 0.0f, 0.0f);
else
- gl.glProgramEnvParameter4fARB(GL.GL_VERTEX_PROGRAM_ARB, 6, freq, amp, d, d+1);
+ gl.glProgramEnvParameter4f(GL2.GL_VERTEX_PROGRAM, 6, freq, amp, d, d+1);
if (b['p'])
- gl.glEnable(GL.GL_VERTEX_PROGRAM_ARB);
+ gl.glEnable(GL2.GL_VERTEX_PROGRAM);
gl.glDisable(GL.GL_TEXTURE_2D);
gl.glCallList(obj+1);
- gl.glDisable(GL.GL_VERTEX_PROGRAM_ARB);
+ gl.glDisable(GL2.GL_VERTEX_PROGRAM);
gl.glPopMatrix();
}
@@ -430,7 +445,7 @@ public class VertexProgWarp extends Demo {
titleSetter.setTitle("SpaceWarp - " + programNames[program]);
}
- private void drawObject(GL gl, int which) {
+ private void drawObject(GL2 gl, int which) {
switch(which) {
case 0:
drawSphere(gl, 0.5f, 100, 100);
@@ -459,16 +474,19 @@ public class VertexProgWarp extends Demo {
}
}
- private void drawSphere(GL gl, float radius, int slices, int stacks) {
+ private void drawSphere(GL2 gl, float radius, int slices, int stacks) {
+
int J = stacks;
int I = slices;
+
for(int j = 0; j < J; j++) {
float v = j/(float) J;
float phi = (float) (v * 2 * Math.PI);
float v2 = (j+1)/(float) J;
float phi2 = (float) (v2 * 2 * Math.PI);
- gl.glBegin(GL.GL_QUAD_STRIP);
+ gl.glBegin(GL2.GL_QUAD_STRIP);
+
for(int i = 0; i < I; i++) {
float u = i/(I-1.0f);
float theta = (float) (u * Math.PI);
@@ -500,16 +518,20 @@ public class VertexProgWarp extends Demo {
}
}
- private void drawTorus(GL gl, float meridian_radius, float core_radius,
+ private void drawTorus(GL2 gl, float meridian_radius, float core_radius,
int meridian_slices, int core_slices) {
+
int J = meridian_slices;
int I = core_slices;
+
for(int j = 0; j < J-1; j++) {
+
float v = j/(J-1.0f);
float rho = (float) (v * 2.0f * Math.PI);
float v2 = (j+1)/(J-1.0f);
float rho2 = (float) (v2 * 2.0f * Math.PI);
- gl.glBegin(GL.GL_QUAD_STRIP);
+ gl.glBegin(GL2.GL_QUAD_STRIP);
+
for(int i = 0; i < I; i++) {
float u = i/(I-1.0f);
float theta = (float) (u * 2.0f * Math.PI);
@@ -541,7 +563,7 @@ public class VertexProgWarp extends Demo {
}
}
- private void drawCube(GL gl) {
+ private void drawCube(GL2 gl) {
int cr = 40;
float scaleFactor = 0.5f;
@@ -576,7 +598,7 @@ public class VertexProgWarp extends Demo {
drawGrid(gl, cr, cr, scaleFactor, -1.0f, 1.0f, -1.0f, 2.0f, 0.0f, 0.0f, 0.0f, 0.0f, 2.0f);
}
- private void drawGrid(GL gl, int rows, int cols,
+ private void drawGrid(GL2 gl, int rows, int cols,
float scaleFactor,
float sx, float sy, float sz,
float ux, float uy, float uz,
@@ -584,7 +606,7 @@ public class VertexProgWarp extends Demo {
int x, y;
for(y=0; y<rows; y++) {
- gl.glBegin(GL.GL_QUAD_STRIP);
+ gl.glBegin(GL2.GL_QUAD_STRIP);
for(x=0; x<=cols; x++) {
float u = x / (float) cols;
float v = y / (float) rows;
diff --git a/src/demos/xtrans/OffscreenComponentWrapper.java b/src/demos/xtrans/OffscreenComponentWrapper.java
index fa7ad03..47b7995 100755
--- a/src/demos/xtrans/OffscreenComponentWrapper.java
+++ b/src/demos/xtrans/OffscreenComponentWrapper.java
@@ -39,13 +39,16 @@
package demos.xtrans;
-import java.awt.*;
-import javax.swing.*;
+
+import java.awt.Component;
+import java.awt.Graphics;
+import java.awt.Rectangle;
+import javax.swing.JComponent;
// Internal JOGL API references
import com.sun.opengl.impl.Debug;
// FIXME: debugging only
-import com.sun.opengl.impl.Java2D;
+import com.sun.opengl.impl.awt.Java2D;
/** Provides an interposition point where we can install a new
* Graphics object in the rendering pipeline. Because lightweight
diff --git a/src/demos/xtrans/OffscreenDesktopManager.java b/src/demos/xtrans/OffscreenDesktopManager.java
index 1aabb67..72349df 100755
--- a/src/demos/xtrans/OffscreenDesktopManager.java
+++ b/src/demos/xtrans/OffscreenDesktopManager.java
@@ -39,18 +39,31 @@
package demos.xtrans;
-import java.awt.*;
-import java.awt.geom.*;
-import java.awt.image.*;
-import java.beans.*;
-import java.nio.*;
-import java.util.*;
-import javax.swing.*;
+
+import java.awt.Component;
+import java.awt.Container;
+import java.awt.Dimension;
+import java.awt.Graphics;
+import java.awt.GraphicsConfiguration;
+import java.awt.GraphicsEnvironment;
+import java.awt.Image;
+import java.awt.Rectangle;
+import java.awt.image.VolatileImage;
+import java.beans.PropertyVetoException;
+import java.util.Map;
+import java.util.WeakHashMap;
+import javax.swing.DesktopManager;
+import javax.swing.JComponent;
+import javax.swing.JDesktopPane;
+import javax.swing.JFrame;
+import javax.swing.JInternalFrame;
+import javax.swing.JLayeredPane;
+import javax.swing.JPanel;
// Internal JOGL API references
import com.sun.opengl.impl.Debug;
// FIXME: debugging only
-import com.sun.opengl.impl.Java2D;
+import com.sun.opengl.impl.awt.Java2D;
// FIXME: we need a way to lock a portion of the off-screen back
// buffer to be persistent for a while during component removals. It
diff --git a/src/demos/xtrans/XTBasicTransition.java b/src/demos/xtrans/XTBasicTransition.java
index 5621788..d9d37f1 100755
--- a/src/demos/xtrans/XTBasicTransition.java
+++ b/src/demos/xtrans/XTBasicTransition.java
@@ -39,8 +39,10 @@
package demos.xtrans;
-import javax.media.opengl.*;
-import gleem.linalg.*;
+import gleem.linalg.Vec3f;
+import javax.media.opengl.GL;
+import javax.media.opengl.GL2;
+
/** A basic transition supporting animated translation, rotation about
* a pivot point, scrolling and fading effects.
@@ -67,7 +69,7 @@ public class XTBasicTransition implements XTTransition {
this.percentage = percentage;
}
- public void draw(GL gl) {
+ public void draw(GL2 gl) {
float percent = percentage;
Quad3f vts = vertices.getCurrent(percent);
Quad2f tex = texcoords.getCurrent(percent);
diff --git a/src/demos/xtrans/XTDesktopManager.java b/src/demos/xtrans/XTDesktopManager.java
index 5701d13..a184ea6 100755
--- a/src/demos/xtrans/XTDesktopManager.java
+++ b/src/demos/xtrans/XTDesktopManager.java
@@ -39,16 +39,19 @@
package demos.xtrans;
-import java.awt.*;
-import java.awt.geom.*;
-import java.awt.image.*;
-import java.beans.*;
-import java.nio.*;
-import java.util.*;
-import javax.swing.*;
-import javax.media.opengl.*;
-import javax.media.opengl.glu.*;
-import com.sun.opengl.impl.*;
+import com.sun.opengl.impl.awt.Java2D;
+import java.awt.Component;
+import java.awt.Graphics;
+import java.awt.Image;
+import java.awt.Rectangle;
+import java.awt.geom.Rectangle2D;
+import javax.media.opengl.DebugGL2;
+import javax.media.opengl.GL;
+import javax.media.opengl.GL2;
+import javax.media.opengl.GLContext;
+import javax.media.opengl.GLDrawableFactory;
+import javax.swing.JDesktopPane;
+
/** A desktop manager implementation supporting accelerated
* transitions of the components on the desktop via OpenGL. This class
@@ -94,10 +97,12 @@ public class XTDesktopManager extends OffscreenDesktopManager {
the rendering results available to OpenGL in the form of a
texture object. */
public void updateOffscreenBuffer(OffscreenDesktopPane parent) {
+
boolean needsCopy = needsCopyBack();
boolean hadPrevBackBuffer = false;
super.updateOffscreenBuffer(parent);
Image img = getOffscreenBackBuffer();
+
final boolean mustResizeOGLTexture = ((oglTextureId == 0) ||
(img == null) ||
(prevBackBufferWidth != img.getWidth(null)) ||
@@ -111,13 +116,13 @@ public class XTDesktopManager extends OffscreenDesktopManager {
if (j2dContext == null ||
j2dContextSurfaceIdentifier != Java2D.getOGLSurfaceIdentifier(g)) {
j2dContext = GLDrawableFactory.getFactory().createExternalGLContext();
- j2dContext.setGL(new DebugGL(j2dContext.getGL()));
+ j2dContext.setGL(new DebugGL2(j2dContext.getGL().getGL2()));
j2dContextSurfaceIdentifier = Java2D.getOGLSurfaceIdentifier(g);
}
j2dContext.makeCurrent(); // No-op
try {
- GL gl = j2dContext.getGL();
+ GL2 gl = j2dContext.getGL().getGL2();
if (oglTextureId == 0) {
// Set up and initialize texture
@@ -155,26 +160,26 @@ public class XTDesktopManager extends OffscreenDesktopManager {
// NOTE: assumes read buffer is set up
// FIXME: could be more efficient by copying only bounding rectangle
- gl.glPixelStorei(GL.GL_UNPACK_SWAP_BYTES, GL.GL_FALSE);
- gl.glPixelStorei(GL.GL_PACK_SWAP_BYTES, GL.GL_FALSE);
- gl.glPixelStorei(GL.GL_UNPACK_LSB_FIRST, GL.GL_FALSE);
- gl.glPixelStorei(GL.GL_PACK_LSB_FIRST, GL.GL_FALSE);
- gl.glPixelStorei(GL.GL_UNPACK_ROW_LENGTH, 0);
- gl.glPixelStorei(GL.GL_PACK_ROW_LENGTH, 0);
- gl.glPixelStorei(GL.GL_UNPACK_SKIP_ROWS, 0);
- gl.glPixelStorei(GL.GL_PACK_SKIP_ROWS, 0);
- gl.glPixelStorei(GL.GL_UNPACK_SKIP_PIXELS, 0);
- gl.glPixelStorei(GL.GL_PACK_SKIP_PIXELS, 0);
- gl.glPixelStorei(GL.GL_UNPACK_ALIGNMENT, 1);
- gl.glPixelStorei(GL.GL_PACK_ALIGNMENT, 1);
- gl.glPixelTransferf(GL.GL_RED_SCALE, 1);
- gl.glPixelTransferf(GL.GL_GREEN_SCALE, 1);
- gl.glPixelTransferf(GL.GL_BLUE_SCALE, 1);
- gl.glPixelTransferf(GL.GL_ALPHA_SCALE, 1);
- gl.glPixelTransferf(GL.GL_RED_BIAS, 0);
- gl.glPixelTransferf(GL.GL_GREEN_BIAS, 0);
- gl.glPixelTransferf(GL.GL_BLUE_BIAS, 0);
- gl.glPixelTransferf(GL.GL_ALPHA_BIAS, 0);
+ gl.glPixelStorei(GL2.GL_UNPACK_SWAP_BYTES, GL.GL_FALSE);
+ gl.glPixelStorei(GL2.GL_PACK_SWAP_BYTES, GL.GL_FALSE);
+ gl.glPixelStorei(GL2.GL_UNPACK_LSB_FIRST, GL.GL_FALSE);
+ gl.glPixelStorei(GL2.GL_PACK_LSB_FIRST, GL.GL_FALSE);
+ gl.glPixelStorei(GL2.GL_UNPACK_ROW_LENGTH, 0);
+ gl.glPixelStorei(GL2.GL_PACK_ROW_LENGTH, 0);
+ gl.glPixelStorei(GL2.GL_UNPACK_SKIP_ROWS, 0);
+ gl.glPixelStorei(GL2.GL_PACK_SKIP_ROWS, 0);
+ gl.glPixelStorei(GL2.GL_UNPACK_SKIP_PIXELS, 0);
+ gl.glPixelStorei(GL2.GL_PACK_SKIP_PIXELS, 0);
+ gl.glPixelStorei(GL2.GL_UNPACK_ALIGNMENT, 1);
+ gl.glPixelStorei(GL2.GL_PACK_ALIGNMENT, 1);
+ gl.glPixelTransferf(GL2.GL_RED_SCALE, 1);
+ gl.glPixelTransferf(GL2.GL_GREEN_SCALE, 1);
+ gl.glPixelTransferf(GL2.GL_BLUE_SCALE, 1);
+ gl.glPixelTransferf(GL2.GL_ALPHA_SCALE, 1);
+ gl.glPixelTransferf(GL2.GL_RED_BIAS, 0);
+ gl.glPixelTransferf(GL2.GL_GREEN_BIAS, 0);
+ gl.glPixelTransferf(GL2.GL_BLUE_BIAS, 0);
+ gl.glPixelTransferf(GL2.GL_ALPHA_BIAS, 0);
// long start = System.currentTimeMillis();
gl.glCopyTexSubImage2D(textureTarget,
diff --git a/src/demos/xtrans/XTDesktopPane.java b/src/demos/xtrans/XTDesktopPane.java
index 0786618..5940172 100755
--- a/src/demos/xtrans/XTDesktopPane.java
+++ b/src/demos/xtrans/XTDesktopPane.java
@@ -39,13 +39,22 @@
package demos.xtrans;
-import java.awt.*;
-import java.awt.geom.*;
-import java.util.*;
-import javax.swing.*;
-import javax.media.opengl.*;
-import javax.media.opengl.glu.*;
-import com.sun.opengl.impl.*;
+import com.sun.opengl.impl.awt.Java2D;
+import java.awt.Component;
+import java.awt.Graphics;
+import java.awt.Point;
+import java.awt.Rectangle;
+import java.awt.geom.Rectangle2D;
+import java.util.ArrayList;
+import java.util.Iterator;
+import javax.media.opengl.DebugGL2;
+import javax.media.opengl.GL;
+import javax.media.opengl.GL2;
+import javax.media.opengl.GLContext;
+import javax.media.opengl.GLDrawableFactory;
+import javax.media.opengl.glu.GLU;
+
+
/** A JDesktopPane subclass supporting Accelerated Transitions (XT) of
* the components contained within.
@@ -54,6 +63,7 @@ import com.sun.opengl.impl.*;
*/
public class XTDesktopPane extends OffscreenDesktopPane {
+
private GLContext j2dContext;
private Object j2dContextSurfaceIdentifier;
@@ -177,13 +187,13 @@ public class XTDesktopPane extends OffscreenDesktopPane {
if (j2dContext == null ||
j2dContextSurfaceIdentifier != Java2D.getOGLSurfaceIdentifier(g)) {
j2dContext = GLDrawableFactory.getFactory().createExternalGLContext();
- j2dContext.setGL(new DebugGL(j2dContext.getGL()));
+ j2dContext.setGL(new DebugGL2(j2dContext.getGL().getGL2()));
j2dContextSurfaceIdentifier = Java2D.getOGLSurfaceIdentifier(g);
}
j2dContext.makeCurrent(); // No-op
try {
- GL gl = j2dContext.getGL();
+ GL2 gl = j2dContext.getGL().getGL2();
// Figure out where JDesktopPane is on the Swing back buffer
Rectangle oglRect = Java2D.getOGLViewport(g, getWidth(), getHeight());
@@ -264,13 +274,13 @@ public class XTDesktopPane extends OffscreenDesktopPane {
gl.glBindTexture(textureTarget, getXTDesktopManager().getOpenGLTextureObject());
gl.glEnable(textureTarget);
- gl.glTexParameteri(textureTarget, GL.GL_TEXTURE_WRAP_S, GL.GL_CLAMP);
- gl.glTexParameteri(textureTarget, GL.GL_TEXTURE_WRAP_T, GL.GL_CLAMP);
+ gl.glTexParameteri(textureTarget, GL.GL_TEXTURE_WRAP_S, GL2.GL_CLAMP);
+ gl.glTexParameteri(textureTarget, GL.GL_TEXTURE_WRAP_T, GL2.GL_CLAMP);
gl.glTexParameteri(textureTarget, GL.GL_TEXTURE_MAG_FILTER, GL.GL_LINEAR);
gl.glTexParameteri(textureTarget, GL.GL_TEXTURE_MIN_FILTER, GL.GL_LINEAR);
gl.glEnable(GL.GL_BLEND);
- gl.glTexEnvi(GL.GL_TEXTURE_ENV, GL.GL_TEXTURE_ENV_MODE, GL.GL_MODULATE);
+ gl.glTexEnvi(GL2.GL_TEXTURE_ENV, GL2.GL_TEXTURE_ENV_MODE, GL2.GL_MODULATE);
gl.glBlendFunc(GL.GL_SRC_ALPHA, GL.GL_ONE_MINUS_SRC_ALPHA);
// Iterate down children in z order bottom-to-top
@@ -352,7 +362,7 @@ public class XTDesktopPane extends OffscreenDesktopPane {
gl.glDisable(textureTarget);
gl.glDisable(GL.GL_BLEND);
- gl.glTexEnvi(GL.GL_TEXTURE_ENV, GL.GL_TEXTURE_ENV_MODE, GL.GL_MODULATE);
+ gl.glTexEnvi(GL2.GL_TEXTURE_ENV, GL2.GL_TEXTURE_ENV_MODE, GL2.GL_MODULATE);
gl.glMatrixMode(GL.GL_PROJECTION);
gl.glPopMatrix();
gl.glMatrixMode(GL.GL_TEXTURE);
diff --git a/src/demos/xtrans/XTTransition.java b/src/demos/xtrans/XTTransition.java
index b250567..1f683ac 100755
--- a/src/demos/xtrans/XTTransition.java
+++ b/src/demos/xtrans/XTTransition.java
@@ -53,5 +53,5 @@ public interface XTTransition {
public void update(float fraction);
/** Draws this transition using the passed OpenGL object. */
- public void draw(GL gl);
+ public void draw(GL2 gl);
}