ViewVC Help
View File | Revision Log | Show Annotations | Download File
/cvs/libgender/test.C
Revision: 1.72
Committed: Fri Oct 29 17:21:54 2004 UTC (19 years, 7 months ago) by root
Content type: text/plain
Branch: MAIN
Changes since 1.71: +2 -2 lines
Log Message:
*** empty log message ***

File Contents

# User Rev Content
1 root 1.1 #include <stdlib.h>
2     #include <stdio.h>
3     #include <string.h>
4     #include <math.h>
5    
6 root 1.62 #include "opengl.h"
7    
8 root 1.1 #include "SDL.h"
9     #include "SDL_opengl.h"
10    
11     static SDL_Surface *global_image = NULL;
12     static GLuint global_texture = 0;
13    
14 root 1.29 #include "util.h"
15 root 1.2 #include "entity.h"
16 root 1.29 #include "txtprt_import.h"
17    
18 root 1.70 #include "shader.h"
19    
20 root 1.1 /**********************************************************************/
21    
22 root 1.6 view camera;
23 root 1.18 vec3 camera_velocity;
24 root 1.51 float camera_angle, camera_angle2, camera_velocity_angle, camera_velocity_angle2;
25 root 1.50 float camera_velocity_factor = 80;
26 root 1.6
27 root 1.1 void
28     HotKey_ToggleFullScreen (void)
29     {
30     SDL_Surface *screen;
31    
32     screen = SDL_GetVideoSurface ();
33     if (SDL_WM_ToggleFullScreen (screen))
34 root 1.5 printf ("Toggled fullscreen mode - now %s\n",
35     (screen->flags & SDL_FULLSCREEN) ? "fullscreen" : "windowed");
36 root 1.1 else
37 root 1.5 printf ("Unable to toggle fullscreen mode\n");
38 root 1.1 }
39    
40     void
41     HotKey_ToggleGrab (void)
42     {
43     SDL_GrabMode mode;
44    
45     printf ("Ctrl-G: toggling input grab!\n");
46     mode = SDL_WM_GrabInput (SDL_GRAB_QUERY);
47     if (mode == SDL_GRAB_ON)
48 root 1.5 printf ("Grab was on\n");
49 root 1.1 else
50 root 1.5 printf ("Grab was off\n");
51 root 1.1
52     mode = SDL_WM_GrabInput (mode ? SDL_GRAB_OFF : SDL_GRAB_ON);
53     if (mode == SDL_GRAB_ON)
54 root 1.5 printf ("Grab is now on\n");
55 root 1.1 else
56 root 1.5 printf ("Grab is now off\n");
57 root 1.1 }
58    
59     void
60     HotKey_Iconify (void)
61     {
62     printf ("Ctrl-Z: iconifying window!\n");
63     SDL_WM_IconifyWindow ();
64     }
65    
66     int
67     HandleEvent (SDL_Event * event)
68     {
69     int done;
70    
71     done = 0;
72     switch (event->type)
73     {
74     case SDL_ACTIVEEVENT:
75     /* See what happened */
76     printf ("app %s ", event->active.gain ? "gained" : "lost");
77     if (event->active.state & SDL_APPACTIVE)
78 root 1.62 printf ("active ");
79 root 1.1 else if (event->active.state & SDL_APPMOUSEFOCUS)
80 root 1.62 printf ("mouse ");
81 root 1.1 else if (event->active.state & SDL_APPINPUTFOCUS)
82 root 1.62 printf ("input ");
83 root 1.1
84     printf ("focus\n");
85     break;
86    
87     case SDL_KEYDOWN:
88 root 1.51 if (event->key.keysym.sym == SDLK_UP) camera_velocity.z--;
89     if (event->key.keysym.sym == SDLK_DOWN) camera_velocity.z++;
90     if (event->key.keysym.sym == SDLK_RIGHT) camera_velocity_angle++;
91     if (event->key.keysym.sym == SDLK_LEFT) camera_velocity_angle--;
92     if (event->key.keysym.sym == SDLK_PAGEUP) camera_velocity_angle2++;
93     if (event->key.keysym.sym == SDLK_PAGEDOWN) camera_velocity_angle2--;
94     if (event->key.keysym.sym == SDLK_e) camera_velocity.y--;
95     if (event->key.keysym.sym == SDLK_q) camera_velocity.y++;
96     if (event->key.keysym.sym == SDLK_v) camera_velocity_factor *= 1.5;
97     if (event->key.keysym.sym == SDLK_b) camera_velocity_factor /= 1.5;
98 root 1.6
99 root 1.1 if (event->key.keysym.sym == SDLK_ESCAPE)
100 root 1.6 done = 1;
101 root 1.1
102     if ((event->key.keysym.sym == SDLK_g) &&
103     (event->key.keysym.mod & KMOD_CTRL))
104 root 1.6 HotKey_ToggleGrab ();
105 root 1.1
106     if ((event->key.keysym.sym == SDLK_z) &&
107     (event->key.keysym.mod & KMOD_CTRL))
108 root 1.6 HotKey_Iconify ();
109 root 1.1
110     if ((event->key.keysym.sym == SDLK_RETURN) &&
111     (event->key.keysym.mod & KMOD_ALT))
112 root 1.6 HotKey_ToggleFullScreen ();
113 root 1.1
114     break;
115    
116 root 1.18 case SDL_KEYUP:
117 root 1.19 if (event->key.keysym.sym == SDLK_UP) camera_velocity.z++;
118     if (event->key.keysym.sym == SDLK_DOWN) camera_velocity.z--;
119 root 1.50 if (event->key.keysym.sym == SDLK_LEFT) camera_velocity_angle++;
120     if (event->key.keysym.sym == SDLK_RIGHT) camera_velocity_angle--;
121 root 1.51 if (event->key.keysym.sym == SDLK_PAGEUP) camera_velocity_angle2--;
122     if (event->key.keysym.sym == SDLK_PAGEDOWN) camera_velocity_angle2++;
123 root 1.50 if (event->key.keysym.sym == SDLK_e) camera_velocity.y++;
124     if (event->key.keysym.sym == SDLK_q) camera_velocity.y--;
125 root 1.18 break;
126    
127 root 1.1 case SDL_QUIT:
128     done = 1;
129     break;
130     }
131    
132     return (done);
133     }
134    
135 root 1.47 void draw_floor (int size, int dx, int dy, int dz)
136     {
137     int x, z, ry;
138    
139 root 1.60 for (x = 0; x < 10; x++)
140 root 1.47 {
141 root 1.60 for (z = 0; z < 10; z++)
142 root 1.47 {
143 root 1.62 vector<vertex_t2f_n3f_v3f> pts;
144     pts.push_back (vertex_t2f_n3f_v3f (point ( 0, 0, 0), vec3 (0, 1, 0), tex2 (0, 0)));
145     pts.push_back (vertex_t2f_n3f_v3f (point ( 0, 0, size), vec3 (0, 1, 0), tex2 (0, 1)));
146     pts.push_back (vertex_t2f_n3f_v3f (point (size, 0, size), vec3 (0, 1, 0), tex2 (1, 1)));
147     pts.push_back (vertex_t2f_n3f_v3f (point (size, 0, 0), vec3 (0, 1, 0), tex2 (1, 0)));
148 root 1.47
149     geometry_quads *q = new geometry_quads;
150 root 1.57 q->m = new simple_material;
151 root 1.47 q->set (pts);
152     entity *e = new entity (q);
153     e->move (vec3 (dx + x * size, dy, dz + z * size));
154     e->show ();
155     }
156     }
157     }
158    
159 root 1.52 void draw_test_nurb ()
160     {
161 root 1.49 geometry_nurbs *q = new geometry_nurbs;
162     q->set ();
163     entity *e = new entity (q);
164     e->move (vec3 (10, 3, -4));
165     e->show ();
166     }
167    
168 root 1.66 void fisch (vec3 center, GLfloat radius, int depth)
169     {
170     entity *planet = new entity (new geometry_sphere (radius));
171     planet->move (center);
172     planet->show ();
173    
174     if (--depth)
175     {
176     GLfloat r2 = radius * .1F;
177     GLfloat r3 = radius + r2;
178    
179     fisch (center + vec3 (r3, 0, 0), r2, depth);
180     fisch (center + vec3 (0, 0, r3), r2, depth);
181     fisch (center + vec3 (-r3, 0, 0), r2, depth);
182     }
183     }
184    
185 root 1.54 extern void draw_level ();
186 root 1.1 int
187     RunGLTest (int argc, char *argv[],
188     int logo, int slowly, int bpp, float gamma, int noframe, int fsaa)
189     {
190     int i;
191     int rgb_size[3];
192     int w = 640;
193     int h = 480;
194     int done = 0;
195     int frames;
196 root 1.2 Uint32 video_flags;
197 root 1.1 int value;
198 root 1.45 GLenum gl_error;
199 root 1.1
200     if (SDL_Init (SDL_INIT_VIDEO) < 0)
201     {
202     fprintf (stderr, "Couldn't initialize SDL: %s\n", SDL_GetError ());
203     exit (1);
204     }
205    
206     /* See if we should detect the display depth */
207     if (bpp == 0)
208     {
209     if (SDL_GetVideoInfo ()->vfmt->BitsPerPixel <= 8)
210 root 1.3 bpp = 8;
211 root 1.1 else
212 root 1.3 bpp = 16; /* More doesn't seem to work */
213 root 1.1 }
214    
215 root 1.2 video_flags = SDL_OPENGL;
216    
217 root 1.1 for (i = 1; argv[i]; ++i)
218 root 1.3 if (strcmp (argv[1], "-fullscreen") == 0)
219     video_flags |= SDL_FULLSCREEN;
220 root 1.1
221     if (noframe)
222 root 1.3 video_flags |= SDL_NOFRAME;
223 root 1.1
224     /* Initialize the display */
225     switch (bpp)
226     {
227     case 8:
228     rgb_size[0] = 3;
229     rgb_size[1] = 3;
230     rgb_size[2] = 2;
231     break;
232 root 1.3
233 root 1.1 case 15:
234     case 16:
235     rgb_size[0] = 5;
236     rgb_size[1] = 5;
237     rgb_size[2] = 5;
238     break;
239 root 1.3
240 root 1.1 default:
241     rgb_size[0] = 8;
242     rgb_size[1] = 8;
243     rgb_size[2] = 8;
244     break;
245     }
246 root 1.18
247 root 1.1 SDL_GL_SetAttribute (SDL_GL_RED_SIZE, rgb_size[0]);
248     SDL_GL_SetAttribute (SDL_GL_GREEN_SIZE, rgb_size[1]);
249     SDL_GL_SetAttribute (SDL_GL_BLUE_SIZE, rgb_size[2]);
250 root 1.69 SDL_GL_SetAttribute (SDL_GL_DEPTH_SIZE, 24);
251 root 1.1 SDL_GL_SetAttribute (SDL_GL_DOUBLEBUFFER, 1);
252 root 1.3
253 root 1.1 if (fsaa)
254     {
255     SDL_GL_SetAttribute (SDL_GL_MULTISAMPLEBUFFERS, 1);
256     SDL_GL_SetAttribute (SDL_GL_MULTISAMPLESAMPLES, fsaa);
257     }
258 root 1.3
259 root 1.1 if (SDL_SetVideoMode (w, h, bpp, video_flags) == NULL)
260     {
261     fprintf (stderr, "Couldn't set GL mode: %s\n", SDL_GetError ());
262     SDL_Quit ();
263     exit (1);
264     }
265    
266 root 1.69 //printf ("Screen BPP: %d\n", SDL_GetVideoSurface ()->format->BitsPerPixel);
267     //printf ("\n");
268     //printf ("Vendor : %s\n", glGetString (GL_VENDOR));
269     //printf ("Renderer : %s\n", glGetString (GL_RENDERER));
270     //printf ("Version : %s\n", glGetString (GL_VERSION));
271     //printf ("Extensions : %s\n", glGetString (GL_EXTENSIONS));
272 root 1.1 printf ("\n");
273    
274     SDL_GL_GetAttribute (SDL_GL_RED_SIZE, &value);
275     printf ("SDL_GL_RED_SIZE: requested %d, got %d\n", rgb_size[0], value);
276     SDL_GL_GetAttribute (SDL_GL_GREEN_SIZE, &value);
277     printf ("SDL_GL_GREEN_SIZE: requested %d, got %d\n", rgb_size[1], value);
278     SDL_GL_GetAttribute (SDL_GL_BLUE_SIZE, &value);
279     printf ("SDL_GL_BLUE_SIZE: requested %d, got %d\n", rgb_size[2], value);
280     SDL_GL_GetAttribute (SDL_GL_DEPTH_SIZE, &value);
281     printf ("SDL_GL_DEPTH_SIZE: requested %d, got %d\n", bpp, value);
282     SDL_GL_GetAttribute (SDL_GL_DOUBLEBUFFER, &value);
283     printf ("SDL_GL_DOUBLEBUFFER: requested 1, got %d\n", value);
284 root 1.3
285 root 1.1 if (fsaa)
286     {
287     SDL_GL_GetAttribute (SDL_GL_MULTISAMPLEBUFFERS, &value);
288     printf ("SDL_GL_MULTISAMPLEBUFFERS: requested 1, got %d\n", value);
289     SDL_GL_GetAttribute (SDL_GL_MULTISAMPLESAMPLES, &value);
290     printf ("SDL_GL_MULTISAMPLESAMPLES: requested %d, got %d\n", fsaa,
291     value);
292     }
293    
294     /* Set the window manager title bar */
295 root 1.12 SDL_WM_SetCaption ("libgender rendering test", "gendertest");
296 root 1.1
297     /* Set the gamma for the window */
298     if (gamma != 0.0)
299 root 1.3 SDL_SetGamma (gamma, gamma, gamma);
300 root 1.1
301 root 1.60 entity *planet = new entity (new geometry_sphere (10));
302     planet->move (vec3 (0, 0, -20));
303     planet->show ();
304    
305 root 1.69 shader::debdebdebdebug ();//D
306    
307 root 1.60 #if 1
308 root 1.56 for (int i = 0; i < 20; i++)
309 root 1.17 {
310 root 1.40 // load a entity
311 root 1.17 txtprt_parser p;
312 root 1.47 geometry *g;
313 root 1.17 try
314 root 1.40 {
315 root 1.47 g = p.read ("test.blasc");
316 root 1.40 }
317     catch (txtprt_i_exception & e)
318     {
319     cout << "ERR: " << e.msg << endl;
320     }
321    
322 root 1.47 entity *e = new entity (g);
323     e->move (vec3 (i*5, -3, -i*10));
324     e->show ();
325 root 1.17 }
326 root 1.47
327 root 1.60 {
328 root 1.67 fisch (vec3 (0, 0, -2e9), 1e9, 8);
329 root 1.66 //entity *planet = new entity (new geometry_sphere (1e9));
330     //planet->move (vec3 (0, 0, -1.5e9));
331     //planet->show ();
332 root 1.60 }
333    
334     {
335     entity *planet = new entity (new geometry_sphere (4e15));
336     planet->move (vec3 (0, 0, 1e17));
337     planet->show ();
338     }
339    
340 root 1.56 draw_floor (10, -500, -10, -1000);
341 root 1.54 draw_level ();
342 root 1.60 //draw_test_nurb ();
343     #endif
344 root 1.47
345 root 1.55 //camera.orig.x = 108; camera.orig.y = 0; camera.orig.z = -368;
346     camera.orig.x = 0; camera.orig.y = 0; camera.orig.z = 0;
347 root 1.6 camera.p = point (0, 0, 10);
348     camera.d = vec3 (0, 0, -1);
349     camera.u = vec3 (0, 1, 0);
350     camera.w = w; camera.h = h;
351 root 1.67 camera.fov = 40.;
352 root 1.1
353 root 1.41 glEnable (GL_CULL_FACE);
354 root 1.65 glDisable (GL_ALPHA_TEST);
355     glDisable (GL_BLEND);
356 root 1.29
357 root 1.71 test_material test_mat;
358 root 1.59
359 root 1.1 /* Loop until done. */
360     frames = 0;
361 root 1.16
362 root 1.1 while (!done)
363     {
364     char *sdl_error;
365     SDL_Event event;
366    
367 root 1.51 camera_angle += 180 * camera_velocity_angle * timer.diff;
368     camera_angle2 += 180 * camera_velocity_angle2 * timer.diff;
369    
370     vec3 geradeaus = matrix::rotation (-camera_angle, vec3 (0, 1, 0)) * vec3 (0, 0, -1);
371     vec3 right = matrix::rotation (90., vec3 (0, 1, 0)) * geradeaus;
372    
373     camera.d = matrix::rotation (camera_angle2, right) * geradeaus;
374     camera.u = cross (camera.d, right);
375    
376 root 1.50 camera.p = camera.p - camera.d * (camera_velocity_factor * timer.diff) * camera_velocity.z;
377     camera.p = camera.p - camera.u * (camera_velocity_factor * timer.diff) * camera_velocity.y;
378 root 1.18
379 root 1.72 test_mat.enable (camera);
380 root 1.1
381 root 1.34 camera.begin ();
382 root 1.63 camera.render (view::DEPTH);
383     camera.render (view::POSTDEPTH);
384     camera.render (view::LIGHTED);
385 root 1.34 camera.end ();
386 root 1.1
387     SDL_GL_SwapBuffers ();
388 root 1.15 timer.frame ();
389 root 1.1
390 root 1.72 test_mat.disable (camera);
391 root 1.62
392     #if 0
393 root 1.1 /* Check for error conditions. */
394     gl_error = glGetError ();
395    
396 root 1.45 if (gl_error != GL_NO_ERROR) fprintf (stderr, "testgl: OpenGL error: %d\n", gl_error);
397 root 1.1
398     sdl_error = SDL_GetError ();
399    
400     if (sdl_error[0] != '\0')
401     {
402     fprintf (stderr, "testgl: SDL error '%s'\n", sdl_error);
403     SDL_ClearError ();
404     }
405    
406     /* Allow the user to see what's happening */
407 root 1.51 //SDL_Delay (40);
408 root 1.62 #endif
409 root 1.1
410     /* Check if there's a pending event. */
411     while (SDL_PollEvent (&event))
412 root 1.18 done = HandleEvent (&event);
413 root 1.20
414 root 1.18
415 root 1.1 ++frames;
416     }
417    
418     if (global_image)
419     {
420     SDL_FreeSurface (global_image);
421     global_image = NULL;
422     }
423     if (global_texture)
424     {
425     glDeleteTextures (1, &global_texture);
426     global_texture = 0;
427     }
428    
429     /* Destroy our GL context, etc. */
430     SDL_Quit ();
431     return (0);
432     }
433     int
434     main (int argc, char *argv[])
435     {
436     int i, logo;
437     int numtests;
438     int bpp = 0;
439     int slowly;
440     float gamma = 0.0;
441     int noframe = 0;
442     int fsaa = 0;
443 root 1.68
444 root 1.1 logo = 0;
445     slowly = 0;
446     numtests = 1;
447     for (i = 1; argv[i]; ++i)
448     {
449     if (strcmp (argv[i], "-twice") == 0)
450     {
451     ++numtests;
452     }
453     if (strcmp (argv[i], "-slow") == 0)
454     {
455     slowly = 1;
456     }
457     if (strcmp (argv[i], "-bpp") == 0)
458     {
459     bpp = atoi (argv[++i]);
460     }
461     if (strcmp (argv[i], "-gamma") == 0)
462     {
463     gamma = (float) atof (argv[++i]);
464     }
465     if (strcmp (argv[i], "-noframe") == 0)
466     {
467     noframe = 1;
468     }
469     if (strcmp (argv[i], "-fsaa") == 0)
470     {
471     ++fsaa;
472     }
473     if (strncmp (argv[i], "-h", 2) == 0)
474     {
475     printf
476     ("Usage: %s [-twice] [-logo] [-slow] [-bpp n] [-gamma n] [-noframe] [-fsaa]\n",
477     argv[0]);
478     exit (0);
479     }
480     }
481 root 1.17
482 root 1.1 for (i = 0; i < numtests; ++i)
483 root 1.17 RunGLTest (argc, argv, logo, slowly, bpp, gamma, noframe, fsaa);
484    
485 root 1.1 return 0;
486     }