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