La présentation est en train de télécharger. S'il vous plaît, attendez

La présentation est en train de télécharger. S'il vous plaît, attendez

GRAPHISME PAR ORDINATEUR

Présentations similaires


Présentation au sujet: "GRAPHISME PAR ORDINATEUR"— Transcription de la présentation:

1 GRAPHISME PAR ORDINATEUR
SIF-1032

2 Contenu du cours 4 Transformations géométriques des objets
Transformations 2D Transformations entre systèmes de coordonnées Transformations 3D de base Sommaire des transformations en OpenGL Utilisation des transformations dans un programme Introduction au processus de visualisation avec OpenGL Sommaire des transformations en OpenGL 3.x LECTURES: Chapitre 5

3 Contenu du cours 4 Transformations géométriques des objets

4 Transformations géométriques 2D de base
Translation La translation d’un point 2D s’effectue par l’addition des distances de décalage tx et ty aux coordonnées d’origine du point (x,y) permettant son déplacement à la position (x’,y’)

5 Transformations géométriques 2D de base
Translation Sous forme matricielle

6 Transformations géométriques 2D de base
Rotation Une rotation est appliquée sur un objet en le déplaçant selon une trajectoire circulaire Nous devons spécifier un angle de rotation () et la position (xr, yr) du pivot SI (xr=0, yr=0)

7 Transformations géométriques 2D de base
Rotation

8 Transformations géométriques 2D de base
Rotation Sous forme matricielle avec

9 Transformations géométriques 2D de base
Rotation Par rapport à un pivot TRANSLATION Rotation suivi d’une translation

10 Transformations géométriques 2D de base
Rotation Par rapport à un pivot 1) Translation T(-xr,-yr) 2) Rotation d’un angle  3) Translation T(xr,yr)

11 Transformations géométriques 2D de base
Changement d’échelle (scaling) Changement des dimensions d’un objet

12 Transformations géométriques 2D de base
Changement d’échelle (scaling) Sous forme matricielle

13 Transformations géométriques 2D de base
Changement d’échelle (scaling) Par rapport à un point de référence Scaling suivi d’une translation

14 Transformations géométriques 2D de base
Shearing Déformation d ’un objet par rapport à un axe donné Direction x Direction y

15 Transformations géométriques 2D de base
Shearing Sous forme matricielle (Direction x)

16 Transformations multiples (composite)
Représentation matricielle et coordonnées homogènes Dans plusieurs applications en graphisme des séquences de transformations graphiques doivent être générées Les représentations matricielles servent de base pour modéliser de façon efficace ces séquences de transformations Les transformations de base peuvent s’écrire Où M1 est une matrice 2X2 et M2 une matrice 2X1

17 Transformations multiples (composite)
Divers cas Translation: M1: matrice identité M2: terme translationnel Rotation: M1: matrice de rotation M2: terme translationnel (pivot) Scaling: M1: matrice des changements d’échelle M2: terme translationnel (point de référence)

18 Transformations multiples (composite)
Une séquence de transformations S-R-T s’effectue: scaling des coordonnées des objets rotation des coordonnées transformées (après scaling) translation des coordonnées (après rotation) La combinaison de ces transformations permet d’améliorer l’efficacité en éliminant le terme additif M2

19 Transformations multiples (composite)
Pour combiner les termes multiplicatifs et translationnels il faut utiliser une forme matricielle M1de 3X3 Dans ce contexte nous pouvons représenter toutes les transformations sous forme de multiplication matricielle Il faut par contre modifier la représenta-tion matricielle des coordonnées des points constituant nos objets

20 Transformations multiples (composite)
Les coordonnées cartésiennes (x, y) sont alors représentées sous forme homogène (xh, yh, h) ou x=xh/h et y=yh/h Alors une représentation en coordonnées homogènes généralisée peut aussi être déduite sous la forme (h x, h y, h) Nous choisissons par simplicité h=1, chaque position est alors représentée en coordonnées homogènes par (x, y, 1)

21 Transformations multiples (composite)
Translation Rotation

22 Transformations multiples (composite)
Scaling

23 Transformations multiples (composite)
Shearing Direction x: SH(shx=0,shy) Direction y: SH(shx,shy=0)

24 Transformations multiples (composite)
Sachant que la multiplication matricielle est associative, les transformations successives sont alors représentées par une matrice 3X3 découlant de la concaténation des matrices individuelles 2 translations successives (tx1,ty1), (tx2,ty2)

25 Transformations multiples (composite)
Cette transformation s’écrit

26 Transformations multiples (composite)
2 rotations

27 Transformations multiples (composite)
2 scaling

28 Transformations multiples (composite)
Rotation par rapport à un pivot

29 Transformations multiples (composite)
Matrice des transformations

30 Transformations multiples (composite)
Scaling avec un point de référence

31 Transformations multiples (composite)
Matrice des transformations

32 Transformations multiples (composite)
Forme générale Complexité 4 X et + VS 9 X 6 +

33 Transformations multiples (composite)
Par exemple, si un objet doit subir un changement d’échelle et une rotation par rapport au point (xc, yc) et par la suite une translation, la matrice composite devient

34 Transformations multiples (composite)
Transformations entre systèmes de coordonnées Un objet quelconque peut être défini dans un système de coordonnées cartésien du monde (ex: scène du monde) mais les coordonnées du monde doivent être transformées au préalable pour permettre le positionnement de cet objet par rapport au système de coordonnées de l’écran avant son affichage

35 Transformations multiples (composite)
Transformations entre systèmes de coordonnées Pour transformer la description d’un objet d’un système de coordonnées x y à x’y’ nous devons effectuer une transformation qui doit permettre la superposition des axes du système x’y’ sur ceux du système x y Translation T(-x0, -y0) R(-)

36 Transformations multiples (composite)
Transformations entre systèmes de coordonnées

37 Transformations multiples (composite)
Transformations entre systèmes de coordonnées

38 Visualisation 2D (Rappel)
Une surface dans le système de coordonnées du monde sélectionnée pour l’affichage est appelée une fenêtre. Une surface sur un écran sur laquelle est projetée la fenêtre est un port de visualisation (viewport)

39 Les transformations de visualisations
Visualisation 2D Les transformations de visualisations

40 Visualisation 2D Le passage des WC au VC

41 Visualisation 2D WC -> VC

42 Visualisation 2D VC -> NVC

43 VC -> NVC Visualisation 2D
Pour maintenir les mêmes positions relatives dans les deux représentations nous devons savoir v: viewport w: window

44 Visualisation 2D VC -> NVC Maintien des positions relatives

45 Visualisation 2D VC -> NVC Nous pouvons alors déduire (xv,yv) par

46 VC -> NVC Visualisation 2D
Séquences de transformations correspondantes Scaling avec comme point de référence (xwmin,ywmin) (fenêtre) Translation à la position du viewport (xvmin,yvmin)

47 Transformations géométriques 3D de base
Translation La translation d’un point 3D s’effectue par l’addition des distances de décalage tx, ty et tz aux coordonnées d’origine du point (x,y,z) permettant son déplacement à la position (x’,y’,z’)

48 Transformations géométriques 3D de base
Translation Sous forme matricielle (coordonnées homogènes)

49 Transformations géométriques 3D de base
Translation La translation d’un objet 3D revient à déplacer les points de l’objet. Pour un objet 3D représenté par un ensemble de surfaces polygonales, la translation est appliquée sur les sommets. Ensuite, l’objet est retracé

50 Transformations géométriques 3D de base
Translation d’un objet 3D

51 Transformations géométriques 3D de base
Rotation Pour faire subir une rotation à un objet 3D nous devons désigner au préalable un axe et un angle de rotation Une rotation 3D peut s’effectuer par rapport à n’importe quel axe dans l’espace Les rotations les plus simples sont celles par rapport à des axes parallèles aux axes du système de coordonnées Par convention, un angle de rotation () positif produit une rotation anti-horaire par rapport à un axe de coordonnées

52 Transformations géométriques 3D de base
Rotation

53 Transformations géométriques 3D de base
Rotation 3D par rapport à l’axe z

54 Transformations géométriques 3D de base
Rotation 3D par rapport à l’axe z

55 Transformations géométriques 3D de base
Rotation 3D par rapport à l’axe x (x->y->z->x)

56 Transformations géométriques 3D de base
Rotation 3D par rapport à l’axe x

57 Transformations géométriques 3D de base
Rotation 3D par rapport à l’axe y (y->z->x->y)

58 Transformations géométriques 3D de base
Rotation 3D par rapport à l’axe y

59 Transformations géométriques 3D de base
Rotation 3D générale Une rotation par rapport à un axe quelconque est représentée par une combinaison de translations et de rotations par rapport aux axes de coordonnées Cas 1: Axe de rotation parallèle à un axe de coordonnées Translation de l’objet pour amener l’axe de rotation sur l’axe de coordonnées Rotation de l’objet par rapport à cet axe de coordonnées Translation de l’objet pour ramener l’axe de rotation à sa place originale

60 Transformations géométriques 3D de base
Rotation 3D générale Cas 1: Axe de rotation parallèle à un axe de coordonnées

61 Transformations géométriques 3D de base
Rotation 3D générale Cas 1: Axe de rotation parallèle à un axe de coordonnées

62 Transformations géométriques 3D de base
Rotation 3D générale Cas 2: Axe de rotation non parallèle à un axe de coordonnées Translation de l’objet pour faire passer l’axe de rotation par l’origine Rotation de l’objet pour faire coïncider l’axe de rotation avec un des axes de coordonnées (axe z) Rotation de l’objet par rapport à cet axe de coordonnées Rotation inverse de l’objet pour ramener son axe de rotation à son orientation originale Translation inverse de l’objet pour ramener l’axe de rotation à sa place originale

63 Transformations géométriques 3D de base
Rotation 3D générale Cas 2: Axe de rotation non parallèle à un axe de coordonnées

64 Transformations géométriques 3D de base
Rotation 3D générale Cas 2: Axe de rotation non parallèle à un axe de coordonnées Un axe de rotation peut être défini par 2 points ou par un point et les cosinus directeurs entre l’axe de rotation et les axes de coordonnées

65 Transformations géométriques 3D de base
Rotation 3D générale Cas 2: Axe de rotation non parallèle à un axe de coordonnées Un vecteur axial est donné par

66 Transformations géométriques 3D de base
Rotation 3D générale Cas 2: Axe de rotation non parallèle à un axe de coordonnées Un vecteur unitaire dans la direction de l’axe de rotation est donné par

67 Transformations géométriques 3D de base
Rotation 3D générale Cas 2: Axe de rotation non parallèle à un axe de coordonnées Étape 1: Translation de l’axe de rotation

68 Transformations géométriques 3D de base
Rotation 3D générale Cas 2: Axe de rotation non parallèle à un axe de coordonnées Étape 2: Rotation de l’axe de rotation sur l’axe z Rotation par rapport à l’axe x pour amener u dans le plan xz Rotation par rapport à l’axe y pour amener u sur l’axe z

69 Transformations géométriques 3D de base
Rotation 3D générale Cas 2: Axe de rotation non parallèle à un axe de coordonnées Étape 2: Rotation de l’axe de rotation sur l’axe z Rotation par rapport à l’axe x pour amener u dans le plan xz

70 Transformations géométriques 3D de base
Rotation 3D générale Cas 2: Axe de rotation non parallèle à un axe de coordonnées Étape 2: Rotation de l’axe de rotation sur l’axe z Rotation par rapport à l’axe x pour amener u dans le plan xz L’angle  est l’angle entre la projection de u dans le plan yz et l’axe z La projection de u dans le plan yz est u’ = (0,b,c), cos  et sin  sont donnés par

71 Transformations géométriques 3D de base
Rotation 3D générale Cas 2: Axe de rotation non parallèle à un axe de coordonnées Étape 2: Rotation de l’axe de rotation sur l’axe z Rotation par rapport à l’axe y pour amener u sur l’axe z

72 Transformations géométriques 3D de base
Rotation 3D générale Cas 2: Axe de rotation non parallèle à un axe de coordonnées Étape 3: Rotation de l’objet par rapport l’axe z

73 Transformations géométriques 3D de base
Rotation 3D générale Cas 2: Axe de rotation non parallèle à un axe de coordonnées Pour accomplir les étapes 4 et 5 il faut effectuer les transformations inverses Rx-1, Ry-1et T-1 La matrice de transformation composée est alors

74 Transformations géométriques 3D de base
Changement d’échelle 3D

75 Transformations géométriques 3D de base
Changement d’échelle 3D

76 Transformations géométriques 3D de base
Changement d’échelle 3D relatif à un point de référence

77 Transformations géométriques 3D de base
Exemple

78 Sommaire des transformations en OpenGL
Pipeline de transformations de OpenGL

79 Sommaire des transformations en OpenGL
Nous avons déjà introduit sous forme d’exemples les transformations matricielles et le modèle d'une caméra synthétique. Nous expliquons maintenant comment la machine OpenGL réalise ces opérations. La machine OpenGL utilise 2 matrices qui sont sélectionnées avec les opérations suivantes: glMatrixMode(GL_PROJECTION); glMatrixMode(GL_MODELVIEW);

80 Sommaire des transformations en OpenGL
Supposons que p est un sommet et que p' est le sommet qui est affiché dans le viewport à l’écran, Supposons que P est la matrice de projection et M la matrice ModelView. OpenGL calcule le produit matriciel suivant: p' = M P p Ce calcul est réalisé lors de la transmission du point p à la machine OpenGL. Chacune de ces matrices peuvent être modifiées selon nos besoins. Ainsi, il faut donc toujours contrôler l'état de chacune de ces matrices.

81 Sommaire des transformations en OpenGL
Normalement, on place la projection dans P et les autres transformations dans M. Pour initialiser une matrice (M ou P) avec une matrice identité, on utilise la commande "glLoadIdentity();". Aussi, OpenGL effectue ses calculs matriciels en effectuant une opération de multiplication matricielle permettant une mise à jour de la matrice de transformation courante CT pour chaque transformation : CT = CT M

82 Sommaire des transformations en OpenGL
Par exemple, pour accomplir une rotation en X de angleX, suivie d’une rotation en Y de angleY, il faut écrire la séquence de commande OpenGL: glLoadIdentity(); // CT = I glRotatef(angleY, 0.0f, 1.0f, 0.0f); CT *= Ry glRotatef(angleX, 1.0f, 0.0f, 0.0f); CT *= Rx

83 Sommaire des transformations en OpenGL
Piles de matrices Une pile de matrices est associée à chaque matrice P et M et des instructions pour manipuler ces piles comme n'importe quelle pile: glPushMatrix(); // sauvegarder glPopMatrix(); //ramener la dernière sauvegardée En plus des opérations de rotation et de translation déjà vues, d’autres opérations permettent la manipulation de matrice: glLoadMatrix() // on fournit les coefficients de la matrice glMultMatrix() // multiplier par une matrice de coefficients glScale() // multiplier x par scaleX, y par scaleY, z par scaleZ

84 Sommaire des transformations en OpenGL
Initialisation des matrices de l'observateur en OpenGL glViewport(0, 0, w,h); // Reset projection matrix stack glMatrixMode(GL_PROJECTION); glLoadIdentity(); // Reset Model view matrix stack glMatrixMode(GL_MODELVIEW); gluPerspective(ouverture,w/h,front,back);

85 Sommaire des transformations en OpenGL
Initialisation des matrices de l'observateur en OpenGL Définition de la taille de la fenêtre OpenGL. Initialisation de la matrice de projection (P) et la matrice ModelView (M). Définition de la position de l'observateur à l'origine, regardant vers l'axe Z négatif. Aussi, la droite est l'axe X positif, et le haut est l'axe Y positif. De plus, on définit un volume de visualisation qui sert à couper des éléments hors du volume de visualisation (clipping). "front" est la distance d'un plan de coupe qui désigne le début en Z de cet espace, "back" marque la fin en Z de cet espace. "ouverture" est l'angle d'ouverture de la pyramide décrivant ce volume de visualisation (frustum).

86 Sommaire des transformations en OpenGL
Visualisation: Permet de spécifier la position de l ’observateur Modélisation: Permet le déplacement des objets dans la scène MODELVIEW: Représente la dualité entre les transformations de visualisation et de modélisation Projection: Permet le découpage et le dimensionne-ment du volume de visualisation Viewport: Permet la mise à l ’échelle finale dans le fenêtre d ’affichage

87 Sommaire des transformations en OpenGL
Transformation MODELVIEW Les transformations de modélisation et de visualisation son dual l ’une avec l ’autre Il n ’existe pas de différence entre déplacer un objet vers l ’arrière et déplacer le système de coordonnées de visualisation dans le sens inverse (vers l ’avant) Il n ’existe pas de différence à faire une rotation  sur un objet et appliquer une rotation -  sur le système de coordonnées de visualisation Le terme MODELVIEW indique que nous pouvons voir cette transformation comme étant soient de modélisation ou de visualisation

88 Sommaire des transformations en OpenGL
Matrice MODELVIEW Matrice de 4X4, représente la transformation requise pour transformer les coordonnées du monde en coordonnées de visualisation Exemple de translation (cube) glutWireCube(10.0f); // dessine un cube de 10 unités // centré par rapport au système de // coordonnées de visualisation glTranslatef(0.0,10.0f,0.0f) glutWireCube(10.0f);

89 Sommaire des transformations en OpenGL
Matrice MODELVIEW Exemple de rotation (cube) glutWireCube(10.0f); glrotatef(90.0f,1.0f,1.0f,1.0f)

90 Sommaire des transformations en OpenGL
Matrice MODELVIEW Exemple deux translations (cube) glutWireCube(10.0f); glTranslatef(0.0,10.0f,0.0f) glTranslatef(10.0,0.0,0.0f)

91 Sommaire des transformations en OpenGL
Matrice MODELVIEW Exemple deux translations par rapport au système de coordonnées de visualisation (cube) glutWireCube(10.0f); glMatrixMode(GL_MODELVIEW); glLoadIdentity(); glTranslatef(0.0,10.0f,0.0f) glTranslatef(10.0,0.0,0.0f)

92 Sommaire des transformations en OpenGL
Voir l ’exemple ATOM pour l ’utilisation des transformations de base

93 Sommaire des transformations en OpenGL
Voir l ’exemple ATOM pour l ’utilisation des transformations de base

94 Sommaire des transformations en OpenGL
Voir aussi l ’exemple SOLAR (Super Bible, chapitre 5) pour l ’utilisation des transformations de base

95 Sommaire des transformations en OpenGL
L’exemple SOLAR (fonction RenderScene())

96 Sommaire des transformations en OpenGL
L’exemple SOLAR (fonction RenderScene())

97 Sommaire des transformations en OpenGL
L’exemple SOLAR (fonction RenderScene()) La matrice ModelView contient l'identité. On sauvegarde son état (glPushMatrix) On place la lumière à l'origine, et déplace la scène de -300 en Z, Le soleil est alors dessiné et sera donc à la position (0,0,-300). La lumière éclaire dans toutes les directions. Notez que le soleil est en fait dessiné à zéro puis est déplacé de -300 en Z. Donc par rapport au soleil la lumière est à (0,0,0).

98 Sommaire des transformations en OpenGL
Ensuite, on transmet la position (0,0,0) de la lumière, mais après la dernière translation, donc la lumière se retrouve au milieu du soleil. Ensuite, la terre est dessinée, par rapport au soleil: après une translation et une rotation. La lune est dessinée par rapport à la terre: après une translation et une rotation. Pour la terre et la lune, la lumière se trouve au milieu du soleil, mais pour le soleil, la lumière se trouve devant en Z à une distance de 300.

99 Sommaire des transformations en OpenGL

100 Sommaire des transformations en OpenGL
Il faut conclure que la méthode d'OpenGL de modéliser les transformations sous forme de matrices composites permet d'afficher facilement une structure hiérarchique d'objets: Le soleil par rapport à la scène, la terre par rapport au soleil, la lune par rapport à la terre.

101 Sommaire des transformations en OpenGL 3.x
Voir le tutoriel: Voir le code source: Les transformations Model, View et Projection (MVP) permettent de séparer le processus de transformations du modèle vers le viewport à l’écran

102 Sommaire des transformations en OpenGL 3.x
Matrice de transformation Model: Les sommets sont définis par rapport au centre de l’objet, donc le référentiel (0, 0, 0) est au centre de l’objet

103 Sommaire des transformations en OpenGL 3.x
Pour déplacer ce modèle, comme par le contrôle du joueur avec les touches du clavier ou de la souris, nous pouvons appliquer une tranformation 3D sur le modèle ex: translation*rotation*scale, à tous les sommets du modèle en GLSL Un modèle qui ne bouge pas après son chargement restera centré à (0, 0, 0) Le déplacement d’un modèle dans la scène 3D correspond au positionnement de ce modèle dans l’espace du monde 3D

104 Sommaire des transformations en OpenGL 3.x
Positionnement du modèle dans l’espace du monde 3D

105 Sommaire des transformations en OpenGL 3.x
Positionnement du modèle dans l’espace du monde 3D

106 Sommaire des transformations en OpenGL 3.x
Positionnement de la caméra (transformation de visualisation, View)

107 Sommaire des transformations en OpenGL 3.x
Positionnement de la caméra (transformation de visualisation): fonction LookAt()

108 Sommaire des transformations en OpenGL 3.x
Transformation de Projection (ex: perspective)

109 Sommaire des transformations en OpenGL 3.x
Transformation de projection (ex: perspective)

110 Sommaire des transformations en OpenGL 3.x
Transformation de projection (ex: perspective, application des transformations)

111 Sommaire des transformations en OpenGL 3.x
Transformation de projection (ex: perspective, application des transformations) Cube normalisé Viewport

112 Sommaire des transformations en OpenGL 3.x
Transformation de projection (ex: perspective, code)

113 Sommaire des transformations en OpenGL 3.x
Transformation de projection (ex: perspective, code)

114 Sommaire des transformations en OpenGL 3.x
Transformation de projection (ex: perspective, code)

115 Sommaire des transformations en OpenGL 3.x
Transformation de projection (ex: perspective, code) Vertex shader

116 Sommaire des transformations en OpenGL 3.x
Transformation de projection (ex: perspective, code) Fragment shader

117 Sommaire des transformations en OpenGL 3.x
Transformation de projection (ex: perspective, code)


Télécharger ppt "GRAPHISME PAR ORDINATEUR"

Présentations similaires


Annonces Google