17 Mesh make_grid(
const int n= 10 )
24 for(
int x= 0; x < n; x++)
26 float px= float(x) - float(n)/2 + .5f;
27 grid.
vertex(px, 0, -
float(n)/2 + .5f);
28 grid.
vertex(px, 0,
float(n)/2 - .5f);
31 for(
int z= 0; z < n; z++)
33 float pz= float(z) - float(n)/2 + .5f;
34 grid.
vertex(-
float(n)/2 + .5f, 0, pz);
35 grid.
vertex(
float(n)/2 - .5f, 0, pz);
55 Mesh make_ground(
const int n= 10 )
60 int a= grid.
vertex(-n/2, -1, n/2);
61 int b= grid.
vertex( n/2, -1, n/2);
62 int c= grid.
vertex( n/2, -1, -n/2);
63 int d= grid.
vertex(-n/2, -1, -n/2);
77 camera.vertex(
Point(0, 0, 0));
78 camera.vertex(
Point(1, 0, 0));
80 camera.color(
Green());
81 camera.vertex(
Point(0, 0, 0));
82 camera.vertex(
Point(0, 1, 0));
85 camera.vertex(
Point(0, 0, 0));
86 camera.vertex(
Point(0, 0, 1));
98 camera.vertex(-1, -1, -1);
99 camera.vertex(-1, 1, -1);
100 camera.vertex(-1, 1, -1);
101 camera.vertex(1, 1, -1);
102 camera.vertex(1, 1, -1);
103 camera.vertex(1, -1, -1);
104 camera.vertex(1, -1, -1);
105 camera.vertex(-1, -1, -1);
108 camera.vertex(-1, -1, 1);
109 camera.vertex(-1, 1, 1);
110 camera.vertex(-1, 1, 1);
111 camera.vertex(1, 1, 1);
112 camera.vertex(1, 1, 1);
113 camera.vertex(1, -1, 1);
114 camera.vertex(1, -1, 1);
115 camera.vertex(-1, -1, 1);
118 camera.vertex(-1, -1, -1);
119 camera.vertex(-1, -1, 1);
120 camera.vertex(-1, 1, -1);
121 camera.vertex(-1, 1, 1);
122 camera.vertex(1, 1, -1);
123 camera.vertex(1, 1, 1);
124 camera.vertex(1, -1, -1);
125 camera.vertex(1, -1, 1);
140 m_repere= make_grid(20);
141 m_local= make_grid(2);
142 m_ground= make_ground(20);
145 m_frustum= make_frustum();
162 m_ground.
bounds(pmin, pmax);
167 m_framebuffer.
create(1024, 1024);
172 glClearColor(0.2f, 0.2f, 0.2f, 1.f);
175 glDepthFunc(GL_LESS);
176 glEnable(GL_DEPTH_TEST);
199 glClear(GL_COLOR_BUFFER_BIT | GL_DEPTH_BUFFER_BIT);
224 Transform decal_projection=
Ortho(-2, 2, -2, 2,
float(0.1),
float(10));
234 projection= decal_projection;
238 draw(m_objet, m_position, view, projection);
240 draw(m_local, m_position, view, projection);
243 draw(m_proxy, m_position * m, view, projection);
250 draw(m_frustum, decal_m, view, projection);
256 draw(m_ground,
Identity(), view, projection);
261 m_framebuffer.
bind(m_decal_program,
true,
true,
false,
false,
false,
false);
263 glUseProgram(m_decal_program);
271 m_objet.
draw(m_decal_program,
true,
false,
false,
false,
false);
278 glUseProgram(m_shadow_program);
291 Transform decal= decal_viewport * decal_projection * decal_view;
296 m_framebuffer.use_color_texture(m_shadow_program,
"decal", 0);
299 m_ground.
draw(m_shadow_program,
true,
false,
true,
false,
false);
308 m_framebuffer.blit_color(0, 0, 256, 256);
335 GLuint m_decal_program;
336 GLuint m_shadow_program;
340 int main(
int argc,
char **argv )
const Orbiter & camera() const
renvoie l'orbiter gere par l'application.
int run()
execution de l'application.
representation d'un objet / maillage.
unsigned int vertex(const vec3 &p)
insere un sommet de position p, et ses attributs (s'ils sont definis par color(), texcoord(),...
void bounds(Point &pmin, Point &pmax) const
renvoie min et max les coordonnees des extremites des positions des sommets de l'objet (boite engloba...
void draw(const GLuint program, const bool use_position, const bool use_texcoord, const bool use_normal, const bool use_color, const bool use_material_index)
dessine l'objet avec un shader program.
Mesh & triangle(const unsigned int a, const unsigned int b, const unsigned int c)
Mesh & normal(const vec3 &n)
definit la normale du prochain sommet.
void release()
detruit les objets openGL.
Mesh & color(const vec4 &c)
definit la couleur du prochain sommet.
void lookat(const Point ¢er, const float size)
observe le point center a une distance size.
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...
Transform view() const
renvoie la transformation vue.
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.
void clear_key_state(const SDL_Keycode key)
desactive une touche du clavier.
int key_state(const SDL_Keycode key)
renvoie l'etat d'une touche du clavier. cf la doc SDL2 pour les codes.
int window_width()
renvoie la largeur de la fenetre de l'application.
Color Red()
utilitaire. renvoie une couleur rouge.
Color Yellow()
utilitaire. renvoie une couleur jaune.
Color Blue()
utilitaire. renvoie une couleur bleue.
Color Green()
utilitaire. renvoie une couleur verte.
Color White()
utilitaire. renvoie une couleur blanche.
Transform Inverse(const Transform &m)
renvoie l'inverse de la matrice.
Transform Viewport(const float width, const float height)
renvoie la matrice representant une transformation viewport.
Transform Identity()
construit la transformation identite.
Transform RotationX(const float a)
renvoie la matrice representation une rotation de angle degree autour de l'axe X.
Transform RotationY(const float a)
renvoie la matrice representation une rotation de a degree autour de l'axe Y.
Transform Ortho(const float left, const float right, const float bottom, const float top, const float znear, const float zfar)
renvoie la matrice representant une transformation orthographique, passage d'un cube []x[]x[] vers [-...
Transform Translation(const Vector &v)
renvoie la matrice representant une translation par un vecteur.
Mesh read_mesh(const char *filename)
charge un fichier wavefront .obj et renvoie un mesh compose de triangles non indexes....
int screenshot(const char *filename)
enregistre le contenu de la fenetre dans un fichier. doit etre de type .png / .bmp
GLuint read_program(const char *filename, const char *definitions)
void program_uniform(const GLuint program, const char *uniform, const std::vector< unsigned > &v)
affecte un tableau de valeurs a un uniform du shader program.
int program_print_errors(const GLuint program)
affiche les erreurs de compilation.
int release_program(const GLuint program)
detruit les shaders et le program.
void release()
destruction.
void unbind(const int width, const int height)
desactive le framebuffer, selection du framebuffer par defaut associe a la fenetre.
GLuint create(const int width, const int height)
creation du framebuffer
void clear_color(const Color &value)
couleur par defaut.
void clear_depth(const float value)
profondeur par defaut.
void unbind_textures()
nettoyage, desactive les textures utilisees par les autres shaders, cf use_color_texture(),...
void bind(const GLuint program, const bool store_color, const bool store_depth, const bool store_position, const bool store_texcoord, const bool store_normal, const bool store_material)
selection du framebuffer, stocker les sorties du fragment shader. les textures sont initialisees avec...
representation d'un point 3d.