Java OpenGL

From Wikipedia, the free encyclopedia
Jump to navigation Jump to search
JOGL
DeveloperJogAmp Community
Stable release
2.6.0 / August 31, 2025; 7 months ago (2025-08-31)
Preview release
n/a / tbd
Repository
  • {{URL|example.com|optional display text}}Lua error in Module:EditAtWikidata at line 29: attempt to index field 'wikibase' (a nil value).
Written inJava, C
Engine
    Lua error in Module:EditAtWikidata at line 29: attempt to index field 'wikibase' (a nil value).
    Operating systemCross-platform
    Type3D computer graphics software (library/API)
    LicenseBSD license

    Java OpenGL (JOGL) is a wrapper library that allows OpenGL to be used in the Java programming language.[1][2] It was originally developed by Kenneth Bradley Russell and Christopher John Kline, and was further developed by the Game Technology Group at Sun Microsystems. Since 2010, it has been an independent open-source project under a BSD license. It is the reference implementation for Java Bindings for OpenGL (JSR-231).

    JOGL allows access to most OpenGL features available to C language programs through the use of the Java Native Interface (JNI). It offers access to both the standard GL* functions along with the GLU* functions; however the OpenGL Utility Toolkit (GLUT) library is not available for window-system related calls, as Java has its own windowing systems: Abstract Window Toolkit (AWT), Swing, JavaFX, SWT, its own NEWT and some extensions.

    Design

    [edit | edit source]

    The base OpenGL C API, as well as its associated Windowing API,[3] are accessed in JOGL via Java Native Interface (JNI) calls. As such, the underlying system must support OpenGL for JOGL to work.

    JOGL differs from some other Java OpenGL wrapper libraries in that it merely exposes the procedural OpenGL API via methods on a few classes, rather than trying to map OpenGL functionality onto the object-oriented programming paradigm. Indeed, most of the JOGL code is autogenerated from the OpenGL C header files via a conversion tool named GlueGen, which was programmed specifically to facilitate the creation of JOGL.

    Status and standardization

    [edit | edit source]

    As of 2025, JOGL provides full access to the OpenGL 4.6 and OpenGL ES 3.2 specification as well as almost all vendor extensions (and OpenCL, OpenMAX and OpenAL).[4] The 2.5.0 version is the reference implementation for JSR-231 (Java Bindings for OpenGL).[5] The 1.1.1 release gave limited access to GLU NURBS, providing rendering of curved lines and surfaces via the traditional GLU APIs. The 2.6.0 release added support for OpenGL versions up to 4.6, and OpenGL ES versions up to 3.2.

    Wayland and Vulkan support is planned.[6]

    Java2D-OpenGL interoperability

    [edit | edit source]

    Since the Java SE 6 version of the Java language, Java2D (the API for drawing two dimensional graphics in Java) and JOGL have become interoperable, allowing it to :

    • Overlay Swing components (lightweight menus, tooltips, and other widgets) on top of OpenGL rendering.[7]
    • Draw 3D OpenGL graphics on top of Java2D rendering (see here for a button with an OpenGL icon).
    • Use 3D graphics anywhere where ordinarily a Swing widget would be used. (Inside a JTable, JTree, ...)
    • Draw Java2D graphics on top of 3D OpenGL rendering.

    Tutorials

    [edit | edit source]

    Code example

    [edit | edit source]
        @Override
        public void display(GLAutoDrawable drawable) {
    
            GL4 gl4 = drawable.getGL().getGL4();
    
            gl4.glClearBufferfv(GL2ES3.GL_COLOR, 0, clearColor);
            gl4.glClearBufferfv(GL2ES3.GL_DEPTH, 0, clearDepth);
    
            {
                FloatUtil.makeLookAt(view, 0, eye, 0, at, 0, up, 0, tmp);
                FloatUtil.makePerspective(projection, 0, reset, 45f, aspect, near, far);
    
                FloatUtil.multMatrix(projection, view); // projection *= view
    
                transformPointer.asFloatBuffer().put(projection);
            }
    
            gl4.glUseProgram(programName);
            gl4.glBindVertexArray(vertexArrayName.get(0));
            gl4.glBindBufferBase(GL2ES3.GL_UNIFORM_BUFFER /*target*/, 1 /*TRANSFORM0, index*/, bufferName.get(2) /*TRANSFORM, buffer*/);
    
            gl4.glBindTextureUnit(0 /*diffuse*/, textureName.get(0));
            gl4.glBindSampler(0 /*diffuse*/, samplerName.get(0));
    
            gl4.glDrawElements(GL.GL_TRIANGLES, elementCount, GL.GL_UNSIGNED_SHORT, 0);
        }
    

    See also

    [edit | edit source]

    Lua error in mw.title.lua at line 392: bad argument #2 to 'title.new' (unrecognized namespace name 'Portal').

    • Java Bindings for OpenGL, The Java Community Specification Request for which JOGL provides an implementation
    • Ardor3D, a high performance, professionally oriented scene graph using several bindings for OpenGL and OpenGL-ES including JOGL
    • JMonkey Engine, a high performance scene graph based graphics API using several bindings for OpenGL and OpenGL-ES including JOGL
    • Poxnora, an online multiplayer game using JOGL
    • RuneScape, a MMORPG using JOGL
    • Jake2, a Java port of Quake II using several bindings for OpenGL including JOGL for its low-level graphic API
    • Scilab, a numerical computing program using JOGL for 2D, 3D rendering
    • ClearVolume, a JOGL powered real-time live 3D visualization library designed for high-end volumetric light sheet microscopes.
    • LWJGL, an alternative open-source OpenGL wrapper library
    • Java OpenAL

    References

    [edit | edit source]
    1. ^ Lua error in Module:Citation/CS1/Configuration at line 2172: attempt to index field '?' (a nil value).
    2. ^ Lua error in Module:Citation/CS1/Configuration at line 2172: attempt to index field '?' (a nil value).
    3. ^ Lua error in Module:Citation/CS1/Configuration at line 2172: attempt to index field '?' (a nil value).
    4. ^ Lua error in Module:Citation/CS1/Configuration at line 2172: attempt to index field '?' (a nil value).
    5. ^ Lua error in Module:Citation/CS1/Configuration at line 2172: attempt to index field '?' (a nil value).
    6. ^ Lua error in Module:Citation/CS1/Configuration at line 2172: attempt to index field '?' (a nil value).
    7. ^ Lua error in Module:Citation/CS1/Configuration at line 2172: attempt to index field '?' (a nil value).
    [edit | edit source]