summaryrefslogtreecommitdiffstats
path: root/src/jogl/classes/javax/media/opengl/GLBase.java
diff options
context:
space:
mode:
authorSven Gothel <[email protected]>2012-02-13 07:00:01 +0100
committerSven Gothel <[email protected]>2012-02-13 07:00:01 +0100
commit4011e70eed8c88aee0fcd051a50ab3f15bb94f68 (patch)
treee7fb1c33d4c0e75fc52dc3ec2d927f76c51de216 /src/jogl/classes/javax/media/opengl/GLBase.java
parentddd375375025fb83aba90c80b9a089876dad5434 (diff)
OpenGL ES/EGL Overhaul
- GLProfile properly detects native EGL/ES1/ES2 on the 'desktop' device factory. This allows usage of Mesa's EGL/ES or Imageon's PVR emulation, etc. - GLProfile drops getDefaultDesktopDevice() and getDefaultEGLDevice() since both are aligned by getDefaultDevice(). - Fix GL_ARB_ES2_compatibility detection and utilize resulting isGLES2Compatible() where possible. This allows ES2 compatible desktop profiles to use core ES2 functionality (glShaderBinary() .. etc) even with a GL2ES2 desktop implementation. - EGLDrawable: If createSurface(..) fails (BAD_NATIVE_WINDOW) w/ surfaceHandle it uses windowHandle if available and differs. This allows the ANGLE impl. to work. - Properly order of EGL/ES library lookup: ES2: libGLESv2.so.2, libGLESv2.so, GLES20, GLESv2_CM EGL: libEGL.so.1, libEGL.so, EGL - *DynamicLookupHelper reference will be null if it's library is not complete (all tool libs, all glue libs and a ProcAddressFunc lookup function - if named). - Enhance GL version string (incl. ES2 compatible, hw/sw, ..) - GLBase: Fix docs and remove redundancies - Prepared (disabled) DesktopES2DynamicLibraryBundleInfo to be used for a real EGL/ES2 implementation within the desktop GL lib (AMD). Sadly it currenly crashed within eglGetDisplay(EGL_DEFAULT_DISPLAY), hence it's disabled.
Diffstat (limited to 'src/jogl/classes/javax/media/opengl/GLBase.java')
-rw-r--r--src/jogl/classes/javax/media/opengl/GLBase.java71
1 files changed, 26 insertions, 45 deletions
diff --git a/src/jogl/classes/javax/media/opengl/GLBase.java b/src/jogl/classes/javax/media/opengl/GLBase.java
index 899503ea6..bd24b15bc 100644
--- a/src/jogl/classes/javax/media/opengl/GLBase.java
+++ b/src/jogl/classes/javax/media/opengl/GLBase.java
@@ -81,86 +81,80 @@ package javax.media.opengl;
public interface GLBase {
/**
- * Indicates whether this GL object conforms to any of the common GL profiles.
- * @return whether this GL object conforms to any of the common GL profiles
+ * Indicates whether this GL object conforms to any of the OpenGL profiles.
*/
public boolean isGL();
/**
- * Indicates whether this GL object conforms to the GL4 compatibility profile.
- * The GL4 compatibility profile merges the GL2 profile and GL4 core profile.
- * @return whether this GL object conforms to the GL4 compatibility profile
+ * Indicates whether this GL object conforms to the OpenGL &ge; 4.0 compatibility profile.
+ * The GL4 compatibility profile includes the GL2, GL2ES1, GL2ES2, GL3, GL3bc and GL4 profile.
*/
public boolean isGL4bc();
/**
- * Indicates whether this GL object conforms to the GL4 core profile.
- * The GL4 core profile reflects OpenGL versions greater or equal 3.1
- * @return whether this GL object conforms to the GL4 core profile
+ * Indicates whether this GL object conforms to the OpenGL &ge; 4.0 core profile.
+ * The GL4 core profile includes the GL2ES2, and GL3 profile.
*/
public boolean isGL4();
/**
- * Indicates whether this GL object conforms to the GL3 compatibility profile.
- * The GL3 compatibility profile merges the GL2 profile and GL3 core profile.
- * @return whether this GL object conforms to the GL3 compatibility profile
+ * Indicates whether this GL object conforms to the OpenGL &ge; 3.1 compatibility profile.
+ * The GL3 compatibility profile includes the GL2, GL2ES1, GL2ES2 and GL3 profile.
*/
public boolean isGL3bc();
/**
- * Indicates whether this GL object conforms to the GL3 core profile.
- * The GL3 core profile reflects OpenGL versions greater or equal 3.1
- * @return whether this GL object conforms to the GL3 core profile
+ * Indicates whether this GL object conforms to the OpenGL &ge; 3.1 core profile.
+ * The GL3 core profile includes the GL2ES2 profile.
*/
public boolean isGL3();
/**
- * Indicates whether this GL object conforms to the GL2 profile.
- * The GL2 profile reflects OpenGL versions greater or equal 1.5
- * @return whether this GL object conforms to the GL2 profile
+ * Indicates whether this GL object conforms to the OpenGL &le; 3.0 profile.
+ * The GL2 profile includes the GL2ES1 and GL2ES2 profile.
*/
public boolean isGL2();
/**
- * Indicates whether this GL object conforms to the GLES1 profile.
- * @return whether this GL object conforms to the GLES1 profile
+ * Indicates whether this GL object conforms to the OpenGL ES1 &ge; 1.0 profile.
*/
public boolean isGLES1();
/**
- * Indicates whether this GL object conforms to the GLES2 profile.
- * @return whether this GL object conforms to the GLES2 profile
+ * Indicates whether this GL object conforms to the OpenGL ES2 &ge; 2.0 profile.
+ * <p>
+ * Remark: ES2 compatible desktop profiles are not included.
+ * To query whether core ES2 functionality is provided, use {@link #isGLES2Compatible()}.
+ * </p>
+ * @see #isGLES2Compatible()
*/
public boolean isGLES2();
/**
- * Indicates whether this GL object conforms to one of the OpenGL ES compatible profiles.
- * @return whether this GL object conforms to one of the OpenGL ES profiles
+ * Indicates whether this GL object conforms to one of the OpenGL ES profiles,
+ * see {@link #isGLES1()} and {@link #isGLES2()}.
*/
public boolean isGLES();
/**
- * Indicates whether this GL object conforms to the GL2ES1 compatible profile.
- * @return whether this GL object conforms to the GL2ES1 profile
+ * Indicates whether this GL object conforms to a GL2ES1 compatible profile.
*/
public boolean isGL2ES1();
/**
- * Indicates whether this GL object conforms to the GL2ES2 compatible profile.
- * @return whether this GL object conforms to the GL2ES2 profile
+ * Indicates whether this GL object conforms to a GL2ES2 compatible profile.
*/
public boolean isGL2ES2();
/**
- * Indicates whether this GL object is compatible with OpenGL ES2.
+ * Indicates whether this GL object is compatible with the core OpenGL ES2 functionality.
* @return true if this context is an ES2 context or implements
* the extension <code>GL_ARB_ES2_compatibility</code>, otherwise false
*/
public boolean isGLES2Compatible();
/**
- * Indicates whether this GL object conforms to the GL2GL3 compatible profile.
- * @return whether this GL object conforms to the GL2GL3 profile
+ * Indicates whether this GL object conforms to a GL2GL3 compatible profile.
*/
public boolean isGL2GL3();
@@ -169,90 +163,77 @@ public interface GLBase {
/**
* Casts this object to the GL interface.
- * @return this object cast to the GL interface
* @throws GLException if this GLObject is not a GL implementation
*/
public GL getGL() throws GLException;
/**
* Casts this object to the GL4bc interface.
- * @return this object cast to the GL4bc interface
* @throws GLException if this GLObject is not a GL4bc implementation
*/
public GL4bc getGL4bc() throws GLException;
/**
* Casts this object to the GL4 interface.
- * @return this object cast to the GL4 interface
* @throws GLException if this GLObject is not a GL4 implementation
*/
public GL4 getGL4() throws GLException;
/**
* Casts this object to the GL3bc interface.
- * @return this object cast to the GL3bc interface
* @throws GLException if this GLObject is not a GL3bc implementation
*/
public GL3bc getGL3bc() throws GLException;
/**
* Casts this object to the GL3 interface.
- * @return this object cast to the GL3 interface
* @throws GLException if this GLObject is not a GL3 implementation
*/
public GL3 getGL3() throws GLException;
/**
* Casts this object to the GL2 interface.
- * @return this object cast to the GL2 interface
* @throws GLException if this GLObject is not a GL2 implementation
*/
public GL2 getGL2() throws GLException;
/**
* Casts this object to the GLES1 interface.
- * @return this object cast to the GLES1 interface
* @throws GLException if this GLObject is not a GLES1 implementation
*/
public GLES1 getGLES1() throws GLException;
/**
* Casts this object to the GLES2 interface.
- * @return this object cast to the GLES2 interface
* @throws GLException if this GLObject is not a GLES2 implementation
*/
public GLES2 getGLES2() throws GLException;
/**
* Casts this object to the GL2ES1 interface.
- * @return this object cast to the GL2ES1 interface
* @throws GLException if this GLObject is not a GL2ES1 implementation
*/
public GL2ES1 getGL2ES1() throws GLException;
/**
* Casts this object to the GL2ES2 interface.
- * @return this object cast to the GL2ES2 interface
* @throws GLException if this GLObject is not a GL2ES2 implementation
*/
public GL2ES2 getGL2ES2() throws GLException;
/**
* Casts this object to the GL2GL3 interface.
- * @return this object cast to the GL2GL3 interface
* @throws GLException if this GLObject is not a GL2GL3 implementation
*/
public GL2GL3 getGL2GL3() throws GLException;
/**
- * Returns the GLProfile with which this GL object is associated.
- * @return the GLProfile with which this GL object is associated
+ * Returns the GLProfile associated with this GL object.
*/
public GLProfile getGLProfile();
/**
- * Returns the GLContext with which this GL object is associated.
- * @return the GLContext with which this GL object is associated
+ * Returns the GLContext associated which this GL object.
*/
public GLContext getContext();