Jogl API Overview: Difference between revisions
No edit summary |
No edit summary |
||
Line 29: | Line 29: | ||
You can init vertex, fragment, geometry, tesselation control and tesselation evaluation shaders (compute will be implemented soon) using [http://jogamp.org/git/?p=jogl.git;a=blob;f=src/jogl/classes/com/jogamp/opengl/util/glsl/ShaderCode.java;h=e1db3f7a3467c57ebddbafcda52eddc154c4866b;hb=HEAD ShaderCode.create] ([https://github.com/sgothel/jogl/blob/master/src/jogl/classes/com/jogamp/opengl/util/glsl/ShaderCode.java#L683-L689 GH] [http://jogamp.org/deployment/jogamp-next/javadoc/jogl/javadoc/com/jogamp/opengl/util/glsl/ShaderCode.html AD]). | You can init vertex, fragment, geometry, tesselation control and tesselation evaluation shaders (compute will be implemented soon) using [http://jogamp.org/git/?p=jogl.git;a=blob;f=src/jogl/classes/com/jogamp/opengl/util/glsl/ShaderCode.java;h=e1db3f7a3467c57ebddbafcda52eddc154c4866b;hb=HEAD ShaderCode.create] ([https://github.com/sgothel/jogl/blob/master/src/jogl/classes/com/jogamp/opengl/util/glsl/ShaderCode.java#L683-L689 GH] [http://jogamp.org/deployment/jogamp-next/javadoc/jogl/javadoc/com/jogamp/opengl/util/glsl/ShaderCode.html AD]). | ||
For the vertex shader, note that <code>"simple"</code> is the name and "vert" is the custom suffix. You need to specify that if your shaders suffices differ from [https://github.com/sgothel/jogl/blob/master/src/jogl/classes/com/jogamp/opengl/util/glsl/ShaderCode.java#L77-L117 these]. | For the vertex shader, note that <code>"simple"</code> is the name and "vert" is the custom suffix. You need to specify that if your shaders suffices differ from [https://github.com/sgothel/jogl/blob/master/src/jogl/classes/com/jogamp/opengl/util/glsl/ShaderCode.java#L77-L117 these]. | ||
The two <code>null</code> refer to the path for the binary shaders and the name. If the shaders are located in the same package of the <code>class.initProgram(gl4)</code> you can pass <code>null</code> also on the src path. |
Revision as of 11:25, 26 July 2015
Before starting, you should know that the JOGL API is not a young API, this means that there are some things that are (very) old, so you should always evaluate what you are looking at.
We will reference all the links to the main jogamp server, but you can click also on the GitHub version (GH) for a better layout, font and support for highlighting or on the API docs (AD).
Preface
The JOGL API offers a lots of deep and detailed utilities for almost all the possible needs regarding OpenGL but most of them aren't used simply because people ignore about their existence. This small overview aims to alleviate this problem.
You can find the most interesting part under com.jogamp.opengl (GH).
Shaders
com.jogamp.opengl.util.glsl (GH).
You can create your own GLSL program in JOGL by simply calling:
private int initProgram(GL4 gl4) {
ShaderCode vertexShader = ShaderCode.create(gl4, GL4.GL_VERTEX_SHADER, this.getClass(), "src/data", null, "simple", "vert", null, true);
ShaderCode fragmentShader = ShaderCode.create(gl4, GL4.GL_FRAGMENT_SHADER, this.getClass(), "src/data", null, "simple", "frag", null, true);
ShaderProgram program = new ShaderProgram();
program.add(vertexShader);
program.add(fragmentShader);
program.link(gl4, System.out);
return program.program();
}
You can init vertex, fragment, geometry, tesselation control and tesselation evaluation shaders (compute will be implemented soon) using ShaderCode.create (GH AD).
For the vertex shader, note that "simple"
is the name and "vert" is the custom suffix. You need to specify that if your shaders suffices differ from these.
The two null
refer to the path for the binary shaders and the name. If the shaders are located in the same package of the class.initProgram(gl4)
you can pass null
also on the src path.