OpenGL      (Partie 1)

JPG.png (2304 octets)

DÉFINITION

INTRODUCTION
Fonctionnalités
Architecture
simplifiée
Bibliothèques
L'Auxiliary library
L'Utility toolkit
Syntaxe
Variables d'état

INSTRUCTIONS
DE BASE

Messages d'erreur
Effacement
de la fenêtre

Couleur de tracé
Terminaison
du tracé

Les parties cachées
Sommets, lignes
et polygones

EXEMPLES GLUt

VISUALISATION
EN OPENGL

Le processus
de visualisation

Les transformations
Exemples

LES LISTES
D'AFFICHAGE

Définition
Commandes

MODES DE
LISSAGE

LES LUMIÈRES
Configuration
Modèle d'illumination
Exemple

LES MATÉRIAUX
Configuration
Exemple

LES BITMAPS
Introduction
Commandes
Exemple

LE PLACAGE
DE TEXTURE

Introduction
Commandes

LES COURBES
ET SURFACES
LISSÉES

Introduction
Commandes
Les NURBS

LA SÉLECTION
D'OBJETS

Introduction
Mode opératoire
Commandes

GLSL
(OpenGL Shading
Language)

 

RETOUR

 

Définition

GL et OpenGL sont des librairies graphiques de modélisation 3D destinées à la création de scènes 3D.

GL (Iris GL) : Librairie graphique standard de Silicon Graphics Inc. (orientée visualisation). Utilisée sur les stations de travail graphiques de SGI (sous le système d'exploitation Unix de SGI : IRIX) ainsi que sur les matériels équivalents d'autres constructeurs (sous licence).

OpenGL : Sous-ensemble de GL ne nécessitant pas une licence commerciale SGI

Conçu et spécifié à la fin des années 80 - début des années 90

Introduction

Interface logicielle avec les adaptateurs graphiques 3D
-> Indissociable d'une certaine "façon" d'envisager l'architecture des adaptateurs graphiques

Disponible pour un nombre important de plateformes et de langages (initialement C et Fortran)

Environ 120 instructions distinctes exécutables au moyen du langage de programmation utilisé

Spécification d'objets graphiques et production d’applications graphiques 3D

Conçu initialement pour fonctionner en environnement Unix

-> Exploitation de X-Window
-> Exploitation des réseaux

Standard de la programmation d'applications graphiques en CAO

Claire évolution vers l'industrie du jeu (support de techniques de rendu améliorant la qualité des images, exemples: textures évoluées, shaders)

Indépendant de la machine hôte

Existence de versions successives (ajout de nouvelles fonctionnalités, compatibilité ascendante?!)

  • 1.0, (01/92) : Version de base, mode immédiat
    • 1.1, (01/97) : Introduction des textures
    • 1.2
    • 1.3
    • 1.4
    • 1.5, (07/03) : Introduction des Vertex Buffer Objects (VBOs), mode retenu
  • 2.0, (09/04) : Introduction du langage GLSL pour la programmation de "shaders"
         -> implantation et exécution de programmes "utilisateurs" sur la carte graphique
    • 2.1
  • 3.0, (07/08) : Introduction d'un mécanisme de "dépréciation" pour des caractéristiques anciennes susceptibles de disparaître
    • 3.1
    • 3.2
    • 3.3
  • 4.0, (03/10) : Introduction de l'arithmétique 64 bits, convergence avec DirectX'11 et 12
    • 4.1
    • 4.2
    • 4.3
    • 4.4
    • 4.5
    • 4.6

Apparition de Vulkan

Existence des releases suivantes:

  • OpenGL : Version pour systèmes classiques: Stations de travail, ordinateurs portables, ... (programmation en C, Fortran, ...)
  • OpenGL ES (Embedded Systems) : Version pour systèmes embarqués : Téléphones mobiles, tablettes, GPS, ...
  • OpenGL SC (Safety Critical) : Version pour systèmes critiques : Aviation, industrie nucléaire, industrie de l'armement, ...
  • WebGL : Version dédiée à l'affichage 3D dans les navigateurs Internet (Programmation en Javascript) (Exemples)

Géré par le consortium OpenGL Khronos (3Dlabs, Apple, AMD, Dell, IBM, Intel, NVidia, Oracle, ..., liste ayant évolué au cours du temps)
http://www.opengl.org

Fonctionnalités principales

Exemple

#include <~~~~~~~~.h>
void main() {
  ...
  glViewport(0,0,512,512);
  glClearColor(0.0,0.0,0.0,0.0);
  glClear(GL_COLOR_BUFFER_BIT);
  glColor3f(1.0,1.0,1.0);
  glOrtho(-1.0,1.0,-1.0,1.0,-1.0,1.0);
  glBegin(GL_POLYGON);
    glVertex2f(-0.5,-0.5);
    glVertex2f(-0.5,0.5);
    glVertex2f(0.5,0.5);
    glVertex2f(0.5,-0.5);
  glEnd();
  glFlush();
  ...
}

Ce programme modélise (dessine) un "carré" blanc au centre d’une "fenêtre" de fond noir.

Architecture simplifiée

Architecture en pipeline avec des étages successifs réalisant les opérations nécéssaires au processus de visualisation d'une scène (création d'une image)

Circulation des données gérées au cours du rendu entre ces étages avec transformations de type au sein des étages:

  • En entrée : Des sommets en 3D, les paramètres d'affichage, ...
  • En sortie : Une image

Fonctionnement en parallèle des étages du pipeline
Fonctionnement en tâches élémentaires parallèles identiques (parallélisme sur les données) au sein des étages du pipeline

Fonctionnement en mode client-serveur

OpenGL utilise un mode de fonctionnement client-serveur.
Une fois initialisé, il se place en attente de demandes d'exécution de commandes émises par le programme qui l'utilise et n'interprête que ces commandes.
Une application utilisant OpenGL va donc devoir créer et gérer au sein de son (ou de ses!) flux d'instructions un flux unique d'instructions OpenGL.
Ce flux doit être cohérent.

Bibliothèques d'OpenGL

(1) OpenGL Library (GL)

Fonctions de base pour l'affichage 3D en OpenGL :

  • Gestion d'un repère de modélisation et réalisation de transformations géométriques sur ce repère
  • Modélisation de sommets, de segments de droite et de facettes
  • Intégration d'une caméra (virtuelle)
  • Utilisation de matériaux et lumières
  • Utilisation de textures
  • Gestion des paramètres de rendu
  • ...

Pas de fonction pour la construction d'une interface utilisateur (fenêtres, souris, clavier, gestionnaire d'événements, ...)

Préfixe des fonctions : gl

Librairie standard

En langage C, déclarations dans le fichier GL/gl.h

(2) OpenGL Utility Library (GLU)

Commandes écrites en GL :

  • Transformations géométriques spécifiques à certaines actions (gluPerspective, gluLookAt, ...)
  • Transformation de polygones quelconques en ensembles de polygones triangulaires
  • Rendu des surfaces paramétriques et quadriques
  • ...

Préfixe des fonctions : glu

Librairie standard

En langage C, déclarations dans le fichier GL/glu.h

Bibliothèques associées à OpenGL

(1) Auxiliary Library (pas systématiquement disponible)

Bibliothèque écrite pour rendre simple la programmation de petites applications dans le cadre d'interfaces graphiques interactives simples:

  • Gestion d'une fenêtre d'affichage
  • Gestion de la souris
  • Gestion du clavier
  • ...

Programmation événementielle

Préfixe des fonctions : aux

Librairie non standard

Librairie non spécifique à un système d'exploitation

L'Auxiliary Library: Aux

(2) OpenGL Utility Toolkit (GLUT) (pas systématiquement disponible)

Équivalent à Aux du point de vue des fonctionnalités principales et des principes d'utilisation

Interface utilisateur programmable plus élaborée (multifenêtrage, menus popup)
-> plus grande puissance fonctionnelle

Préfixe des fonctions : glut

Librairie non standard mais très couramment utilisée quand il s'agit de faire vite et simple sans souci d'intégration poussée avec le système d'exploitation hôte

Librairie non spécifique à un système d'exploitation

En langage C, déclarations dans le fichier GL/glut.h

Fonctionnalités supplémentaires par rapport à Aux :

Autres exemples

L'Utility Toolkit: GLUT

Syntaxe de la librairie GL (fichier GL/gl.h)

D'une manière générale, emploi des règles syntaxiques du langage C
-> Pas de programmation orientée objet

Spécificités :

  • Les noms de fonction de la librairie GL commencent par le préfixe gl.

  • Les noms de constante (#define ou enum) sont donnés en majuscule et commencent par le préfixe GL_.

  • OpenGL spécifie ses propres types mappés sur les types du langage C (voir ci-dessous).

  • Certaines instructions prennent la forme d'une famille de fonctions dont les noms se terminent par un suffixe (pas de surcharge). Celui-ci indique le nombre et le type des arguments de chaque fonction.

Exemple: glVertex2f, glVertex3f, glVertex2d

-

Type

Type C 32 bits

Type OpenGL

b

entier 8 bits

signed char

GLbyte

s

entier 16 bits

short

GLshort

i

entier 32 bits

long, int

GLint, GLsizei

f

réel 32 bits

float

GLfloat, GLclampf

d

réel 64 bits

double

GLdouble, GLclampd

ub

entier non signé
8 bits

unsigned char

GLubyte, GLboolean

us

entier non signé
16 bits

unsigned short

GLushort

ui

entier non signé
32 bits

unsigned int

GLuint, GLenum,
GLbitfield

Exemple

glVertex2i(1,3);

<=>

glVertex2d(1.0,3.0);

Une lettre terminale v supplémentaire (v pour vector) indique que la fonction prend comme paramètre un pointeur sur un tableau.

glColor3i(1,0,1);

<=>

int c[3]={1,0,1};
glColor3iv(c);

Variables d'état

OpenGL est une machine à états.
-> Des instructions existent pour placer le système dans certains "états" : couleur de tracé, matrice(s) de transformation représentative(s) du(des) repère(s) courant(s), activation de l'élimination des parties cachées, caractéristiques des lumières, caractéristiques du matériel, caractéristiques de la texture, ...
Ceux-ci seront utilisés à cette valeur pour toute opération de dessin et peuvent être changés entre chaque opération de dessin.

Chaque fois que le dessin d'un objet est réalisé (sommet, segment de droite, facette), l'ensemble de ces "variables d'états" définit la manière avec laquelle l'objet est dessiné.

Le dessin d'un objet est définitif. Les modifications ultérieures des variables d'état n'ont aucune influence sur tout ce qui a déjà été dessiné.

L'ensemble des variables d'états constitue l'"environnement" OpenGL.

Toute variable d'état possède une valeur par défaut affectée à l'amorçage du programme utilisant OpenGL, voire de chaque viewport si plusieurs viewports sont utilisés (plusieurs fenêtres, dessin off-screen).

Fonctions de manipulation directe des variables d'état

Activation d'une variable d'état booléenne

pname : Variable d'état à activer (liste des constantes à trouver dans GL/gl.h)

Exemples:
glEnable(GL_LIGHTING) -> activation de la gestion des lumières et des matériaux
glEnable(GL_DEPTH_TEST) -> activation de l'élimination des parties cachées

Désactivation d'une variable d'état booléenne

pname : Variable d'état à désactiver (liste des constantes à trouver dans GL/gl.h)

Consultation de variables d'état de l'environnement OpenGL

pname : Variable d'état consultée (liste des constantes à trouver dans GL/gl.h)

param : Résultat (pointeur sur une variable si une seule valeur, tableau de variables si plusieurs valeurs)

Consultation de variables d'état booléennes (liste des constantes à trouver dans GL/gl.h)

pname : Variable d'état consultée

Sauvegarde de variables d'état par empilement dans la pile dédiée de l'environnement OpenGL

mask : Variables d'état à sauvegarder (descriptif complet non réalisé ici car trop long, à trouver dans GL/gl.h)

Restoration de variables d'état par dépilement depuis la pile dédiée de l'environnement OpenGL

Exemple

glEnable(GL_DEPTH_TEST);
GLboolean v = glIsEnabled(GL_DEPTH_TEST);

Active l'affichage avec élimination des parties cachées puis récupère la valeur d'activation de l'affichage avec élimination des parties cachées.

Les variables d'état non booléennes sont généralement manipulées au moyen de fonctions dédiées (glMaterial*, glLight*, glNormale*, ... , voir plus loin).

Instructions de base d'OpenGL base d'OpenGL

Version d'OpenGL

Retour d'une chaine de caractères de description de la librairie OpenGL utilisée

name : Information recherchée
  GL_VENDOR : Fabriquant de la librairie
  GL_RENDERER : Nom de la librairie
  GL_VERSION : Version de la librairie
  GL_EXTENSIONS : Liste des extensions disponibles (items séparés par des espaces)

Détection d'erreur

Retour de la valeur actuelle de la variable d'état erreur de l'environnement OpenGL

7 valeurs retournées possibles :
  GL_NO_ERROR
  GL_INVALID_ENUM
  GL_INVALID_VALUE
  GL_INVALID_OPERATION
  GL_STACK_OVERFLOW
  GL_STACK_UNDERFLOW
  GL_OUT_OF_MEMORY
Replacement de la variable d'état erreur à GL_NO_ERROR après interrogation

La fenêtre de dessin (viewport)

L'environnement OpenGL inclut plusieurs tampons mémoire effaçables individuellement ou par lot :

  • Le tampon couleur (frame buffer ou color buffer)
    -> Stockage de la couleur des pixels de l'image calculée
    Le tampon couleur doit habituellement être "vidé" à la couleur de fond au début du calcul d'une nouvelle image, il est généralement utilisé et transmis automatiquement comme image à afficher dans la fenêtre de visualisation. Sa taille est définie à la taille du viewport.
  • Le tampon profondeur (depth buffer)
    -> Stockage, pour chaque pixel de l'image calculée, d'une information de profondeur utilisée lors de l'élimination des parties cachées
    Si l'élimination des parties cachées est activée, le tampon profondeur doit habituellement être vidé avant le calcul de toute nouvelle image. Sa taille est définie à la taille du viewport.
  • Le tampon accumulation
    -> Accumulation d'images les unes sur les autres
  • Le tampon stencil
  • void glViewport(GLint x,GLint y,GLsizei tx,GLsizei ty);

Choix de la position et de la taille du viewport d'affichage (résolution des tampons mémoire)

x,y : Position
tx,ty : Taille

Effacement d'un (ou de plusieurs) buffer(s) écran

mask : Buffer(s) à éffacer

mask

GL_COLOR_BUFFER_BIT
Effacement des pixels du tampon couleur

GL_DEPTH_BUFFER_BIT
Effacement de l'information de profondeur
associée à chaque pixel
(information utilisée
pour l'élimination des parties cachées)

GL_ACCUM_BUFFER_BIT
Effacement du tampon accumulation utilisé
pour composer des images

GL_STENCIL_BUFFER_BIT
Non renseigné

Les valeurs de masque sont composables par "ou" (| en C) pour effectuer plusieurs opérations d'effacement en une seule instruction glClear et rendre possible l'optimisation de ces opérations.

  • void glClearColor(GLclampf r,GLclampf v,GLclampf b, GLclampf alpha) ;

Choix de la couleur d'éffacement du tampon couleur

r, v, b, alpha : Composantes élémentaires de la couleur de remplissage du tampon couleur lors d'un effacement par glClear

Choix de la profondeur d'initialisation du tampon profondeur

depth : Valeur de remplissage du tampon profondeur lors d'un effacement par glClear

Choix de la couleur de tracé

  • void glColor3{b s i f d ub us ui} (TYPE r,TYPE v,TYPE b);

  • void glColor4{b s i f d ub us ui} (TYPE r,TYPE v,TYPE b,TYPE alpha);

r, v, b, alpha : Composantes élémentaires de la couleur de tracé

  • void glColor3{b s i f d ub us ui}v (const TYPE *v);

  • void glColor4{b s i f d ub us ui}v (const TYPE *v);

v : Tableau contenant les composantes élémentaires de la couleur de tracé

La couleur choisie est active pour tous les objets créés après spécification, jusqu'à nouvelle spécification (sauf si une texture est utilisée).

Cette couleur n'est utilisée que si la gestion des lumières et des matériaux est désactivée. En cas d'activation de cette fonctionnalité, ce sont les calculs d'éclairage, compte tenu des lumieres, des matériaux et éventuellement des textures spécifiés, qui permettent le calcul de la couleur des pixels.

Terminaison du tracé d'une image

Instruction utilisée pour forcer l'exécution entière des commandes GL qui la précèdent dans le flux d'exécution OpenGL (vidage d'un pipeline d'affichage sur une station graphique, exécution des ordres de tracé sur un réseau, ...).
Généralement utilisée pour indiquer qu'une image est entièrement tracée et peut donc être affichée.

glFinish se met en attente d'une notification d'exécution de la part du dispositif graphique tandis que glFlush n'est pas bloquant.

Principe de programmation et élimination des parties cachées

Généralement, l'affichage d'une scène est intégrée dans une boucle "infinie" d'affichages successifs de cette scène. L'opération de modélisation d'un objet graphique s'accompagne du dessin dans l'image de cet objet graphique. A chaque nouvel affichage la scène doit donc être entièrement modélisée. L'image est donc entièrement recréée.
Si on modélise toujours la même scène, ce sont les mêmes images qui sont obtenues. Si ce n'est pas le cas, les images obtenues sont différentes.
S'il n'y a pas de point d'arrêt entre chaque image (chaque exécution du contenu de la boucle infinie), une animation est créée à l'écran. Pour des raisons d'économie de puissance CPU/GPU, si on ne souhaite pas animer, on place un point d'arrêt dans la boucle d'affichage (par un moyen ou un autre).

while(1) {
  definir_camera();
  glClear(GL_COLOR_BUFFER_BIT);
  modeliser_objet_3D_A();
  modeliser_objet_3D_B();
  modeliser_objet_3D_C();
  ...
  modeliser_objet_3D_Z();
  afficher_Image();
  attendreEtGererEvenement();
}

-> L'élimination des parties cachées n'est pas forcément correctement réalisée car un algorithme du peintre est utilisé pour créer chacune des images. Les objets sont affichés les uns sur les autres dans l'ordre d'exécution du programme et donc l'ordre d'affichage a une influence sur le résultat obtenu. Si l'ordre est bon, l'élimination des parties cachées est réalisée.

Utilisation de la fonction glEnable pour activer l'élimination des parties cachées (généralement par Z-Buffer en OpenGL) via modification de la variable d'état GL_DEPTH_TEST.
   -> L'effacement des tampons couleur et profondeur doit être réalisé entre chaque image au lieu du seul tampon couleur.
   -> L'ordre de dessin des objets n'a plus d'importance.

glEnable(GL_DEPTH_TEST);
while(1) {
  definir_camera();
  glClear(GL_COLOR_BUFFER_BIT|
          GL_DEPTH_BUFFER_BIT);
  modeliser_objet_3D_A();
  modeliser_objet_3D_B();
  modeliser_objet_3D_C();
  ...
  modeliser_objet_3D_Z();
  afficher_Image();
  attendreEtGererEvenement();
}

Sans élimination des parties cachées

Avec élimination des parties cachées

Programme GLUt

Exécutable GLUt

 

Sommets, lignes et polygones

  • Sommet : Ensemble de trois coordonnées numériques représentant une position dans l'espace

Remarque : OpenGL travaille en coordonnées homogènes.

  • Ligne : Segment de droite défini entre deux sommets

  • Polygone : Surface plane délimitée par une boucle fermée de sommets

Par définition, un polygone OpenGL ne se recoupe pas, n'a pas de trou et est de bord convexe.
Si on veut représenter un polygone ne vérifiant pas ces conditions, on devra le subdiviser (triangulation, triangularisation) en un ensemble de polygones convenables (généralement triangulaires). GLU propose des fonctions pour gérer les polygones spéciaux.
OpenGL ne vérifie pas les hypothèses de définition des polygones et les dessine même s'ils ne les respectent pas. Le résultat à l'affichage n'est alors pas déterministe.

Déclaration de la position d'un sommet

coords : Coordonnées de la position
Si seulement 2 valeurs sont spécifiées, ces valeurs représentent x et y et z est défini à 0.0.
Si 4 valeurs sont spécifiées, on travaille directement en coordonnées homogènes.

Les coordonnées spécifiées sont considérées dans le repère de modélisation en cours au moment de l'exécution du glVertex*.

Cette fonction est utilisée uniquement pour la déclaration de sommets au sein d'une primitive graphique.

Déclaration d'une primitive graphique

Une primitive graphique est constituée d'un ensemble de sommets.

Elle est créée par la réalisation des instructions glVertex* successives permettant la définition des positions de ses sommets.

La primitive est délimitée au début et à la fin par

mode : Type de primitive à dessiner à choisir parmi GL_POINTS, GL_LINES, GL_LINE_STRIP, GL_LINE_LOOP, GL_POLYGON, GL_QUADS, GL_QUAD_STRIP, GL_TRIANGLES, GL_TRIANGLE_STRIP ou GL_TRIANGLE_FAN

et

Type de primitive graphique

GL_POINTS

GL_LINES

GL_LINE_STRIP

GL_LINE_LOOP

GL_POLYGON

GL_QUADS

GL_QUAD_STRIP

GL_TRIANGLES

GL_TRIANGLE_STRIP

GL_TRIANGLE_FAN

IMPORTANT : A l'exception du cas particulier des bitmaps, la librairie GL ne comporte aucune autre fonction de dessin que celle permettant de dessiner les 10 primitives existantes.
-> Pas de modélisation à base d'objets canoniques en n'utilisant directement que les fonctions de la librairie GL.

Exemple : Création d'un polygone

glBegin(GL_POLYGON);
glVertex2f(0.0F,0.0F) ;
glVertex2f(2.0F,1.0F) ;
glVertex2f(1.0F,3.0F) ;
glVertex2f(5.0F,0.5F) ;
glVertex2f(-.5F,2.0F) ;
glVertex2f(1.5F,2.5F) ;
glEnd() ;

Outre ses sommets, la définition d'une primitive peut requérir d'autres informations. Celles-ci sont aussi renseignées via des appels à des fonctions particulières réalisés entre glBegin et glEnd.

Fonctions utilisables entre glBegin et glEnd

Fonction

But

glVertex*()

Coordonnées d'un sommet

glColor*()

Couleur de tracé

glIndex*()

Indexe de couleur de tracé

glNormal*()

Vecteur normal

glEvalCoord*()

Génération de coordonnées

glCallList()
glCallLists()

Exécution de listes d'affichage

glTexCoord*()

Coordonnées d'une texture

glEdgeFlag*()

Contrôle du tracé d'un coté

glMaterial*()

Propriétés du matériel

Parmi ces fonctions, l'une des plus importantes permet la configuration de la valeur de la normale courante (vecteur orthogonal à la surface, utilisé pour les calculs d'éclairage) qui sera attribuée à tout vertex créé :

x, y, z ou v : Coordonnées attribuées au vecteur "normal" (valeur par défaut initiale : (0.0,0.0,1.0).

Exemple

glBegin(GL_POLYGON);
glColor3f(1.0F,0.0F,0.0F) ;
glVertex2f(0.0F,0.0F) ;
glNormal3f(-1.0F,0.0F,0.0F) ;
glVertex2f(2.0F,1.0F) ;
glColor3f(0.0F,1.0F,0.0F) ;
glVertex2f(1.0F,3.0F) ;
glEnd() ;

Définit un polygone à trois sommets.
Donne la couleur rouge aux premier et deuxième sommets, et la couleur verte au troisième.
Donne la normale (-1.0,0.0,0.0) aux deuxième et troisième sommets. Le premier adopte comme normale la valeur courante (inconnue dans l'exemple) définie avant le glBegin.

Les 10 primitives graphiques

Déclaration d'un ensemble de facettes

Utilisation fréquente de surfaces polygonales (ensembles de facettes adjacentes) pour modéliser des objets complexes.

Recommandations

  • Conserver constante l'orientation 3D des polygones.
  • Eviter les facettes non triangulaires.
  • Trouver un bon équilibre entre le nombre de polygones et la vitesse et la qualité d'affichage.
  • Multiplier le nombre de polygones sur la silhouette des objets (pas simple).
  • Éviter des intersections en T.

Exemple

#define X .525731112119133606
#define Z .850650808352039932
static GLfloat vdata[12][3] = {
  {-X,0,Z},{X,0,Z},{-X,0,-Z},
  {X,0,-Z},{0,Z,X},{0,Z,-X},
  {0,-Z,X},{0,-Z,-X},{Z,X,0},
  {-Z,X,0},{Z,-X,0},{-Z,-X,0}} ;
static GLint t[20][3] = {
  {0,4,1},{0,9,4},{9,5,4},{4,5,8},
  {4,8,1},{8,10,1},{8,3,10},{5,3,8},
  {5,2,3},{2,7,3},{7,10,3},{7,6,10},
  {7,11,6},{9,2,5},{0,1,6},{6,1,10},
  {9,0,11},{9,11,2},{11,0,6},
  {7,2,11}};
for ( i = 0 ; i < 20 ; i++ ) {
  glBegin(GL_TRIANGLES) ;
    glNormal3fv(&vdata[t[i][0]][0]);
    glVertex3fv(&vdata[t[i][0]][0]);
    glNormal3fv(&vdata[t[i][1]][0]);
    glVertex3fv(&vdata[t[i][1]][0]);
    glNormal3fv(&vdata[t[i][2]][0]);
    glVertex3fv(&vdata[t[i][2]][0]);
  glEnd() ; }

Fonctions basiques pour la configuration de l'affichage des primitives graphiques

Configuration de la taille de tracé des sommets (par défaut 1.0 pixel)

size : Taille de tracé

Configuration de la largeur de tracé des segments de droite (par défaut 1.0 pixel)

width : Largeur de tracé

Configuration du motif de tracé des lignes (par défaut continu)
Le motif est une série de 16 bits (poids faible à poids fort) où les 1 représentent des pixels allumés et des 0 des pixels non modifiés. Le facteur (de 1 à 255) permet l'étirement du motif par multiplication (un 1 devient facteur 1 consécutifs).
L'utilisation des motifs pour les segments est subordonnée à autorisation via un glEnable(GL_LINE_STIPPLE).

facteur : Facteur de zoom du motif
motif : Motif de tracé

Configuration de la technique de dessin des faces avant et arrières des polygones (par défaut avec remplissage)

face : Face configurée (GL_FRONT, GL_BACK ou GL_FRONT_AND_BACK)
mode : Mode d'affichage (GL_POINT, GL_LINE ou GL_FILL pour un dessin des sommets, en fil de fer ou avec remplissage)

Configuration de la technique de détermination de la face frontale des polygones
La valeur par défaut est GL_CCW (anti-horaire). Elle peut être inversée par GL_CW.

mode : GL_CCW ou GL_CW

Configuration de quels polygones doivent être éliminés avant leur dessin au cours du processus d'affichage en fonction de leur orientation vers l'observateur (par défaut tous les polygones sont affichés)
Permet, par exemple, de ne pas dessiner les polygones orientés vers le fond de la scène qui seraient donc obligatoirement masqués par d'autres objets si on ne dessine que des volumes.
L'utilisation du culling est subordonnée à autorisation via un glEnable(GL_CULL_FACE).

mode : GL_FRONT, GL_BACK ou GL_FRONT_AND_BACK

Définition du motif de remplissage des polygones (par défaut plein)
L'utilisation des motifs pour les polygones est subordonnée à autorisation via un glEnable(GL_POLYGONE_STIPPLE).

mask : Pointeur sur une bitmap de 32x32 pixels interprétée comme un masque de bits (128 octets). Si un 1 est présent, le pixel est dessiné, sinon, il ne l'est pas.

Suite