gKit2 light
tuto_transformations_lookat.cpp
Go to the documentation of this file.
1 
3 
4 
5 #include "wavefront.h"
6 #include "texture.h"
7 
8 #include "orbiter.h"
9 #include "draw.h"
10 #include "app_camera.h" // classe Application a deriver
11 
12 
13 // utilitaire. creation d'une grille / repere.
14 // n= 0 ne dessine que les axes du repere.
15 Mesh make_grid( const int n= 10 )
16 {
17  Mesh grid= Mesh(GL_LINES);
18 
19  // grille
20  grid.color(White());
21  for(int x= 0; x < n; x++)
22  {
23  float px= float(x) - float(n)/2 + .5f;
24  grid.vertex(px, 0, - float(n)/2 + .5f);
25  grid.vertex(px, 0, float(n)/2 - .5f);
26  }
27 
28  for(int z= 0; z < n; z++)
29  {
30  float pz= float(z) - float(n)/2 + .5f;
31  grid.vertex(- float(n)/2 + .5f, 0, pz);
32  grid.vertex(float(n)/2 - .5f, 0, pz);
33  }
34 
35  // axes XYZ
36  grid.color(Red());
37  grid.vertex(0, .1, 0);
38  grid.vertex(1, .1, 0);
39 
40  grid.color(Green());
41  grid.vertex(0, .1, 0);
42  grid.vertex(0, 1, 0);
43 
44  grid.color(Blue());
45  grid.vertex(0, .1, 0);
46  grid.vertex(0, .1, 1);
47 
48  glLineWidth(2);
49 
50  return grid;
51 }
52 
53 Mesh make_camera( )
54 {
55  Mesh camera= Mesh(GL_LINES);
56 
57  camera.color(Yellow());
58  camera.vertex(0,0,0);
59  camera.vertex(-0.5, -0.5, -1);
60  camera.vertex(0,0,0);
61  camera.vertex(-0.5, 0.5, -1);
62  camera.vertex(0,0,0);
63  camera.vertex(0.5, 0.5, -1);
64  camera.vertex(0,0,0);
65  camera.vertex(0.5, -0.5, -1);
66 
67  camera.vertex(-0.5, -0.5, -1);
68  camera.vertex(-0.5, 0.5, -1);
69 
70  camera.vertex(-0.5, 0.5, -1);
71  camera.vertex(0.5, 0.5, -1);
72 
73  camera.vertex(0.5, 0.5, -1);
74  camera.vertex(0.5, -0.5, -1);
75 
76  camera.vertex(0.5, -0.5, -1);
77  camera.vertex(-0.5, -0.5, -1);
78 
79  // axes XYZ
80  camera.color(Red());
81  camera.vertex(Point(0, 0, 0));
82  camera.vertex(Point(1, 0, 0));
83 
84  camera.color(Green());
85  camera.vertex(Point(0, 0, 0));
86  camera.vertex(Point(0, 1, 0));
87 
88  camera.color(Blue());
89  camera.vertex(Point(0, 0, 0));
90  camera.vertex(Point(0, 0, 1));
91 
92  glLineWidth(2);
93 
94  return camera;
95 }
96 
97 class TP : public AppCamera
98 {
99 public:
100  // constructeur : donner les dimensions de l'image, et eventuellement la version d'openGL.
101  TP( ) : AppCamera(1024, 640) {}
102 
103  // creation des objets de l'application
104  int init( )
105  {
106  // decrire un repere / grille
107  m_repere= make_grid(20);
108  m_local= make_grid(2);
109  m_proxy= make_camera();
110 
111  // charge l'element
112  m_objet= read_mesh("data/cube.obj");
113 
114  // position initiale de l'objet
115  m_position= Identity();
116 
117  // si l'objet est "gros", il faut regler la camera pour l'observer entierement :
118  // recuperer les points extremes de l'objet (son englobant)
119  Point pmin, pmax;
120  m_repere.bounds(pmin, pmax);
121  // parametrer la camera de l'application, renvoyee par la fonction camera()
122  camera().lookat(pmin, pmax);
123 
124  // etat openGL par defaut
125  glClearColor(0.2f, 0.2f, 0.2f, 1.f); // couleur par defaut de la fenetre
126 
127  glClearDepth(1.f); // profondeur par defaut
128  glDepthFunc(GL_LESS); // ztest, conserver l'intersection la plus proche de la camera
129  glEnable(GL_DEPTH_TEST); // activer le ztest
130 
131  return 0; // ras, pas d'erreur
132  }
133 
134  // destruction des objets de l'application
135  int quit( )
136  {
137  m_objet.release();
138  m_repere.release();
139  m_local.release();
140  m_proxy.release();
141  return 0;
142  }
143 
144  // dessiner une nouvelle image
145  int render( )
146  {
147  glClear(GL_COLOR_BUFFER_BIT | GL_DEPTH_BUFFER_BIT);
148 
149  // modifie la position de l'objet en fonction des fleches de direction
150  if(key_state(SDLK_UP))
151  m_position= m_position * Translation(0, 0, 0.25); // en avant
152  if(key_state(SDLK_DOWN))
153  m_position= m_position * Translation(0, 0, -0.25); // en arriere
154 
155  if(key_state(SDLK_LEFT))
156  m_position= m_position * RotationY(4); // tourne vers la droite
157  if(key_state(SDLK_RIGHT))
158  m_position= m_position * RotationY(-4); // tourne vers la gauche
159 
160  // transformations de la camera de l'application
161  Transform view= camera().view();
162  Transform projection= camera().projection();
163 
164  // view= Inverse(m_position * m);
165  // view= Inverse(m) * Inverse(m_position);
166  // et Inverse(m) est le resultat de Lookat()...
167  view= Lookat(Point(0,1,-4), Point(0,0,1), Vector(0,1,0)) * Inverse(m_position);
168  projection= Perspective(60, float(window_width()) / float(window_height()), float(0.1), float(40));
169  Transform m= Inverse(view);
170 
171  draw(m_objet, /* model */ m_position, view, projection);
172 
173  // dessine le 2ieme objet par rapport au premier objet...
174  // compose leurs 2 transformations, les coordonnees du 2ieme objet sont connues dans le repere local du premier objet
175  draw(m_proxy, /* model */ m, view, projection);
176 
177  // dessine aussi le repere local, pour le meme point de vue
178  draw(m_local, m_position, view, projection);
179 
180  // dessine le repere global, pour le meme point de vue
181  draw(m_repere, Identity(), view, projection);
182 
183  // screenshot
184  if(key_state('s'))
185  {
186  clear_key_state('s');
187  static int id= 1;
188  screenshot("lookat", id++);
189  }
190 
191  // continuer...
192  return 1;
193  }
194 
195 protected:
196  Mesh m_objet;
197  Mesh m_repere;
198  Mesh m_local;
199  Mesh m_proxy;
200  Transform m_position;
201 };
202 
203 
204 int main( int argc, char **argv )
205 {
206  printf("appuyez sur 'espace' pour fixer la position de la camera\n");
207  printf("appuyez sur 'c' pour dessiner avec la camera\n");
208  printf("appuyez sur 'c' et 'espace' pour dessiner avec la camera attachee derriere le cube\n");
209  printf("deplacez le cube avec les fleches de directions\n");
210 
211  // il ne reste plus qu'a creer un objet application et la lancer
212  TP tp;
213  tp.run();
214 
215  return 0;
216 }
classe application.
Definition: app_camera.h:19
const Orbiter & camera() const
renvoie l'orbiter gere par l'application.
Definition: app_camera.h:37
int run()
execution de l'application.
Definition: app.cpp:36
representation d'un objet / maillage.
Definition: mesh.h:112
unsigned int vertex(const vec3 &p)
insere un sommet de position p, et ses attributs (s'ils sont definis par color(), texcoord(),...
Definition: mesh.cpp:111
void bounds(Point &pmin, Point &pmax) const
renvoie min et max les coordonnees des extremites des positions des sommets de l'objet (boite engloba...
Definition: mesh.cpp:503
void release()
detruit les objets openGL.
Definition: mesh.cpp:64
Mesh & color(const vec4 &c)
definit la couleur du prochain sommet.
Definition: mesh.cpp:80
void lookat(const Point &center, const float size)
observe le point center a une distance size.
Definition: orbiter.cpp:7
Transform projection(const int width, const int height, const float fov)
fixe la projection reglee pour une image d'aspect width / height, et une demi ouverture de fov degres...
Definition: orbiter.cpp:47
Transform view() const
renvoie la transformation vue.
Definition: orbiter.cpp:40
Definition: alpha.cpp:59
int render()
a deriver pour afficher les objets. renvoie 1 pour continuer, 0 pour fermer l'application.
int quit()
a deriver pour detruire les objets openGL. renvoie -1 pour indiquer une erreur, 0 sinon.
int init()
a deriver pour creer les objets openGL. renvoie -1 pour indiquer une erreur, 0 sinon.
int window_height()
renvoie la hauteur de la fenetre de l'application.
Definition: window.cpp:29
void clear_key_state(const SDL_Keycode key)
desactive une touche du clavier.
Definition: window.cpp:48
void printf(Text &text, const int px, const int py, const char *format,...)
affiche un texte a la position x, y. meme utilisation que printf().
Definition: text.cpp:140
int key_state(const SDL_Keycode key)
renvoie l'etat d'une touche du clavier. cf la doc SDL2 pour les codes.
Definition: window.cpp:42
int window_width()
renvoie la largeur de la fenetre de l'application.
Definition: window.cpp:25
Color Red()
utilitaire. renvoie une couleur rouge.
Definition: color.cpp:57
Color Yellow()
utilitaire. renvoie une couleur jaune.
Definition: color.cpp:72
Color Blue()
utilitaire. renvoie une couleur bleue.
Definition: color.cpp:67
Color Green()
utilitaire. renvoie une couleur verte.
Definition: color.cpp:62
Color White()
utilitaire. renvoie une couleur blanche.
Definition: color.cpp:52
Transform Inverse(const Transform &m)
renvoie l'inverse de la matrice.
Definition: mat.cpp:197
Transform Identity()
construit la transformation identite.
Definition: mat.cpp:187
Transform RotationY(const float a)
renvoie la matrice representation une rotation de a degree autour de l'axe Y.
Definition: mat.cpp:242
Transform Perspective(const float fov, const float aspect, const float znear, const float zfar)
renvoie la matrice representant une transformation projection perspective.
Definition: mat.cpp:329
Transform Translation(const Vector &v)
renvoie la matrice representant une translation par un vecteur.
Definition: mat.cpp:216
Transform Lookat(const Point &from, const Point &to, const Vector &up)
renvoie la matrice representant le placement et l'orientation d'une camera pour observer le point to.
Definition: mat.cpp:369
Mesh read_mesh(const char *filename)
charge un fichier wavefront .obj et renvoie un mesh compose de triangles non indexes....
Definition: wavefront.cpp:14
int screenshot(const char *filename)
enregistre le contenu de la fenetre dans un fichier. doit etre de type .png / .bmp
Definition: texture.cpp:188
representation d'un point 3d.
Definition: vec.h:21
representation d'une transformation, une matrice 4x4, organisee par ligne / row major.
Definition: mat.h:21
representation d'un vecteur 3d.
Definition: vec.h:59