JOGL - Éclairage
Ce chapitre vous explique comment appliquer un effet d'éclairage à un objet à l'aide de JOGL.
Pour régler l'éclairage, activez d'abord l'éclairage à l'aide du glEnable()méthode. Appliquez ensuite un éclairage pour les objets, en utilisant leglLightfv(int light, int pname, float[] params, int params_offset) méthode de GLLightingFuncinterface. Cette méthode prend quatre paramètres.
Le tableau suivant décrit les paramètres de gllightfv() méthode.
N ° Sr. | Nom et description du paramètre |
---|---|
1 | Light Spécifie une lumière. Le nombre de lumières dépend de l'implémentation, mais au moins huit lumières sont prises en charge. Il accepte dix valeurs, ces paramètres sont traités dans un tableau séparé nommé Paramètres de la source lumineuse ci-dessous. |
2 | Pname Spécifie un paramètre de source lumineuse à valeur unique. Pour la source de lumière, il existe dix paramètres comme indiqué ci-dessous. |
3 | Params Spécifie un pointeur vers la ou les valeurs définies sur le paramètre pname de la source lumineuse . |
4 | Light source parameter Vous pouvez utiliser n'importe lequel des paramètres de source lumineuse indiqués ci-dessous. |
Paramètres de la source lumineuse
N ° Sr. | Paramètre et description |
---|---|
1 | GL_AMBIENT Il contient les paramètres qui spécifient l'intensité ambiante de la lumière. |
2 | GL_DIFFUSE Il contient les paramètres qui spécifient l'intensité diffuse de la lumière. |
3 | GL_SPECULAR Il contient les paramètres qui spécifient l'intensité spéculaire de la lumière. |
4 | GL_POSITION Il contient quatre valeurs entières ou à virgule flottante qui spécifient la position de la lumière en coordonnées d'objet homogènes. |
5 | GL_SPOT_DIRECTION Il contient des paramètres qui spécifient la direction de la lumière en coordonnées d'objet homogènes. |
6 | GL_SPOT_EXPONENT Ses paramètres spécifient la distribution d'intensité de la lumière. |
sept | GL_SPOT_CUTOFF Le seul paramètre de celui-ci spécifie l'angle maximal de diffusion de la lumière. |
8 | GL_CONSTANT_ATTENUATION or GL_LINEAR_ATTENUATION or GL_QUADRATIC_ATTENUATION Vous pouvez utiliser l'un de ces facteurs d'atténuation, qui est représenté par une valeur unique. |
L'éclairage est activé ou désactivé à l'aide de glEnable() et glDisable () méthodes avec l'argument GL_LIGHTING.
Le modèle suivant est donné pour l'éclairage -
gl.glEnable(GL2.GL_LIGHTING);
gl.glEnable(GL2.GL_LIGHT0);
gl.glEnable(GL2.GL_NORMALIZE);
float[] ambientLight = { 0.1f, 0.f, 0.f,0f }; // weak RED ambient
gl.glLightfv(GL2.GL_LIGHT0, GL2.GL_AMBIENT, ambientLight, 0);
float[] diffuseLight = { 1f,2f,1f,0f }; // multicolor diffuse
gl.glLightfv(GL2.GL_LIGHT0, GL2.GL_DIFFUSE, diffuseLight, 0);
Application de lumière à un polygone en rotation
Suivez les étapes indiquées pour appliquer de la lumière à un polygone en rotation.
Faites pivoter le polygone à l'aide de la méthode glRotate ()
gl.glClear(GL2.GL_COLOR_BUFFER_BIT | GL2.GL_DEPTH_BUFFER_BIT);
// Clear The Screen And The Depth Buffer
gl.glLoadIdentity();
// Reset The View
gl.glRotatef(rpoly, 0.0f, 1.0f, 0.0f);
Passons en revue le programme pour appliquer de la lumière à un polygone en rotation -
import javax.media.opengl.GL2;
import javax.media.opengl.GLAutoDrawable;
import javax.media.opengl.GLCapabilities;
import javax.media.opengl.GLEventListener;
import javax.media.opengl.GLProfile;
import javax.media.opengl.awt.GLCanvas;
import javax.swing.JFrame;
import com.jogamp.opengl.util.FPSAnimator;
public class PolygonLighting implements GLEventListener {
private float rpoly;
@Override
public void display( GLAutoDrawable drawable ) {
final GL2 gl = drawable.getGL().getGL2();
gl.glColor3f(1f,0f,0f); //applying red
// Clear The Screen And The Depth Buffer
gl.glClear( GL2.GL_COLOR_BUFFER_BIT |
GL2.GL_DEPTH_BUFFER_BIT );
gl.glLoadIdentity(); // Reset The View
gl.glRotatef( rpoly, 0.0f, 1.0f, 0.0f );
gl.glBegin( GL2.GL_POLYGON );
gl.glVertex3f( 0f,0.5f,0f );
gl.glVertex3f( -0.5f,0.2f,0f );
gl.glVertex3f( -0.5f,-0.2f,0f );
gl.glVertex3f( 0f,-0.5f,0f );
gl.glVertex3f( 0f,0.5f,0f );
gl.glVertex3f( 0.5f,0.2f,0f );
gl.glVertex3f( 0.5f,-0.2f,0f );
gl.glVertex3f( 0f,-0.5f,0f );
gl.glEnd();
gl.glFlush();
rpoly += 0.2f; //assigning the angle
gl.glEnable( GL2.GL_LIGHTING );
gl.glEnable( GL2.GL_LIGHT0 );
gl.glEnable( GL2.GL_NORMALIZE );
// weak RED ambient
float[] ambientLight = { 0.1f, 0.f, 0.f,0f };
gl.glLightfv(GL2.GL_LIGHT0, GL2.GL_AMBIENT, ambient-Light, 0);
// multicolor diffuse
float[] diffuseLight = { 1f,2f,1f,0f };
gl.glLightfv( GL2.GL_LIGHT0, GL2.GL_DIFFUSE, diffuse-Light, 0 );
}
@Override
public void dispose( GLAutoDrawable arg0 ) {
//method body
}
@Override
public void init( GLAutoDrawable arg0 ) {
// method body
}
@Override
public void reshape( GLAutoDrawable arg0, int arg1, int arg2, int arg3, int arg4 ) {
// method body
}
public static void main( String[] args ) {
//getting the capabilities object of GL2 profile
final GLProfile profile = GLProfile.get( GLProfile.GL2 );
GLCapabilities capabilities = new GLCapabilities( profile);
// The canvas
final GLCanvas glcanvas = new GLCanvas( capabilities );
PolygonLighting polygonlighting = new PolygonLighting();
glcanvas.addGLEventListener( polygonlighting );
glcanvas.setSize( 400, 400 );
//creating frame
final JFrame frame = new JFrame (" Polygon lighting ");
//adding canvas to it
frame.getContentPane().add( glcanvas );
frame.setSize( frame.getContentPane().getPreferredSize());
frame.setVisible( true );
//Instantiating and Initiating Animator
final FPSAnimator animator = new FPSAnimator(glcanvas, 300,true );
animator.start();
} //end of main
} //end of class
Si vous compilez et exécutez le programme ci-dessus, il génère la sortie suivante. Ici, vous pouvez observer divers instantanés d'un polygone en rotation avec éclairage.