3 #include "cgmath/cgmath.h"
11 static void draw_level(void);
16 int win_width, win_height;
22 float view_matrix[16], proj_matrix[16];
26 static long prev_step, prev_turn;
30 if(init_opengl() == -1) {
34 glEnable(GL_DEPTH_TEST);
35 glEnable(GL_CULL_FACE);
37 if(!(sdr_foo = create_program_load("sdr/foo.v.glsl", "sdr/foo.p.glsl"))) {
40 glBindAttribLocation(sdr_foo, MESH_ATTR_VERTEX, "apos");
41 glBindAttribLocation(sdr_foo, MESH_ATTR_NORMAL, "anorm");
42 glBindAttribLocation(sdr_foo, MESH_ATTR_TANGENT, "atang");
43 glBindAttribLocation(sdr_foo, MESH_ATTR_TEXCOORD, "atex");
44 link_program(sdr_foo);
46 if(load_level(&lvl, "data/test.lvl") == -1) {
58 void game_shutdown(void)
61 free_program(sdr_foo);
64 #define STEP_INTERVAL 250
65 #define TURN_INTERVAL 500
69 int fwd = 0, right = 0, turn = 0;
71 if(time_msec - prev_turn >= TURN_INTERVAL) {
72 if(input_state[INP_LTURN]) turn--;
73 if(input_state[INP_RTURN]) turn++;
76 turn_player(&player, turn);
77 prev_turn = time_msec;
81 if(time_msec - prev_step >= STEP_INTERVAL) {
82 if(input_state[INP_FWD]) fwd++;
83 if(input_state[INP_BACK]) fwd--;
84 if(input_state[INP_LEFT]) right--;
85 if(input_state[INP_RIGHT]) right++;
88 move_player(&player, right, fwd);
89 prev_step = time_msec;
93 upd_player_xform(&player);
96 void game_display(void)
99 static long prev_msec;
101 dt = (prev_msec - time_msec) / 1000.0f;
102 prev_msec = time_msec;
106 glClearColor(0.1, 0.1, 0.1, 1);
107 glClear(GL_COLOR_BUFFER_BIT | GL_DEPTH_BUFFER_BIT);
109 cgm_midentity(proj_matrix);
110 cgm_mperspective(proj_matrix, cgm_deg_to_rad(80), win_aspect, 0.5, 500.0);
111 glMatrixMode(GL_PROJECTION);
112 glLoadMatrixf(proj_matrix);
114 glMatrixMode(GL_MODELVIEW);
116 glTranslatef(0, 0, -cam_dist);
117 glMultMatrixf(player.view_xform);
122 assert(glGetError() == GL_NO_ERROR);
125 static void draw_level(void)
131 glUseProgram(sdr_foo);
134 for(i=0; i<lvl.height; i++) {
135 for(j=0; j<lvl.width; j++) {
136 cgm_mtranslation(xform, j * lvl.cell_size, 0, -i * lvl.cell_size);
139 glMultMatrixf(xform);
142 cgm_mrotation_y(xform, cell->tilerot * M_PI / 2.0f);
145 glMultMatrixf(xform);
146 draw_meshgroup(&cell->tile->mgrp);
150 for(k=0; k<cell->num_mgrp; k++) {
151 draw_meshgroup(cell->mgrp + k);
162 void game_reshape(int x, int y)
164 glViewport(0, 0, x, y);
167 win_aspect = (float)x / (float)y;
170 void game_keyboard(int key, int press)
172 if(press && key == 27) {
177 /* TODO key remapping */
180 input_state[INP_FWD] = press;
182 move_player(&player, 0, 1);
183 prev_step = time_msec;
188 input_state[INP_LEFT] = press;
190 move_player(&player, -1, 0);
191 prev_step = time_msec;
196 input_state[INP_BACK] = press;
198 move_player(&player, 0, -1);
199 prev_step = time_msec;
204 input_state[INP_RIGHT] = press;
206 move_player(&player, 1, 0);
207 prev_step = time_msec;
212 input_state[INP_LTURN] = press;
214 turn_player(&player, -1);
215 prev_turn = time_msec;
220 input_state[INP_RTURN] = press;
222 turn_player(&player, 1);
223 prev_turn = time_msec;
229 void game_mbutton(int bn, int press, int x, int y)
236 void game_mmotion(int x, int y)
238 int dx = x - mouse_x;
239 int dy = y - mouse_y;
243 if(!(dx | dy)) return;
246 player.theta += cgm_deg_to_rad(dx * 0.5f);
247 player.phi -= cgm_deg_to_rad(dy * 0.5f);
248 if(player.phi < -M_PI/2) player.phi = -M_PI/2;
249 if(player.phi > M_PI/2) player.phi = M_PI/2;
252 cam_dist += dy * 0.1;
253 if(cam_dist < 0) cam_dist = 0;