2 * glDrawPixels demo/test/benchmark
4 * Brian Paul September 25, 1997 This file is in the public domain.
6 * Conversion to UGL/Mesa by Stephane Raimbault july, 2001
10 * $Log: ugldrawpix.c,v $
11 * Revision 1.1 2001/08/20 16:07:11 brianp
12 * WindML driver (Stephane Raimbault)
14 * Revision 1.5 2000/12/24 22:53:54 pesco
15 * * demos/Makefile.am (INCLUDES): Added -I$(top_srcdir)/util.
16 * * demos/Makefile.X11, demos/Makefile.BeOS-R4, demos/Makefile.cygnus:
17 * Essentially the same.
18 * Program files updated to include "readtex.c", not "../util/readtex.c".
19 * * demos/reflect.c: Likewise for "showbuffer.c".
22 * * Makefile.am (EXTRA_DIST): Added top-level regular files.
24 * * include/GL/Makefile.am (INC_X11): Added glxext.h.
27 * * src/GGI/include/ggi/mesa/Makefile.am (EXTRA_HEADERS): Include
28 * Mesa GGI headers in dist even if HAVE_GGI is not given.
30 * * configure.in: Look for GLUT and demo source dirs in $srcdir.
32 * * src/swrast/Makefile.am (libMesaSwrast_la_SOURCES): Set to *.[ch].
33 * More source list updates in various Makefile.am's.
35 * * Makefile.am (dist-hook): Remove CVS directory from distribution.
36 * (DIST_SUBDIRS): List all possible subdirs here.
37 * (SUBDIRS): Only list subdirs selected for build again.
38 * The above two applied to all subdir Makefile.am's also.
40 * Revision 1.4 2000/09/08 21:45:21 brianp
41 * added dither key option
43 * Revision 1.3 1999/10/28 18:23:29 brianp
44 * minor changes to Usage() function
46 * Revision 1.2 1999/10/21 22:13:58 brianp
47 * added f key to toggle front/back drawing
49 * Revision 1.1.1.1 1999/08/19 00:55:40 jtg
52 * Revision 3.3 1999/03/28 18:18:33 brianp
55 * Revision 3.2 1998/11/05 04:34:04 brianp
56 * moved image files to ../images/ directory
58 * Revision 3.1 1998/02/22 16:43:17 brianp
59 * added a few casts to silence compiler warnings
61 * Revision 3.0 1998/02/14 18:42:29 brianp
73 #include <ugl/uglucode.h>
74 #include <ugl/uglevent.h>
75 #include <ugl/uglinput.h>
77 #include <GL/uglmesa.h>
80 #include "../util/readtex.h"
82 #define IMAGE_FILE "Mesa/images/girl.rgb"
84 UGL_LOCAL UGL_EVENT_SERVICE_ID eventServiceId
;
85 UGL_LOCAL UGL_EVENT_Q_ID qId
;
86 UGL_LOCAL
volatile UGL_BOOL stopWex
;
87 UGL_LOCAL UGL_MESA_CONTEXT umc
;
89 UGL_LOCAL
int ImgWidth
, ImgHeight
;
90 UGL_LOCAL GLenum ImgFormat
;
91 UGL_LOCAL GLubyte
*Image
;
93 UGL_LOCAL
int Xpos
, Ypos
;
94 UGL_LOCAL
int SkipPixels
, SkipRows
;
95 UGL_LOCAL
int DrawWidth
, DrawHeight
;
96 UGL_LOCAL
float Xzoom
, Yzoom
;
97 UGL_LOCAL GLboolean Scissor
;
98 UGL_LOCAL GLboolean DrawFront
;
99 UGL_LOCAL GLboolean Dither
;
101 UGL_LOCAL
void cleanUp (void);
103 UGL_LOCAL
void reset(void)
106 DrawWidth
= ImgWidth
;
107 DrawHeight
= ImgHeight
;
108 SkipPixels
= SkipRows
= 0;
113 UGL_LOCAL
void initGL(GLboolean ciMode
, GLsizei width
, GLsizei height
)
115 printf("GL_VERSION = %s\n", (char *) glGetString(GL_VERSION
));
116 printf("GL_RENDERER = %s\n", (char *) glGetString(GL_RENDERER
));
117 printf("GL_VENDOR = %s\n", (char *) glGetString(GL_VENDOR
));
119 Image
= LoadRGBImage(IMAGE_FILE
, &ImgWidth
, &ImgHeight
, &ImgFormat
);
122 printf("Couldn't read %s\n", IMAGE_FILE
);
127 glScissor(width
/4, height
/4, width
/2, height
/2);
131 /* Convert RGB image to grayscale */
132 GLubyte
*indexImage
= malloc( ImgWidth
* ImgHeight
);
134 for (i
=0; i
<ImgWidth
*ImgHeight
; i
++)
136 int gray
= Image
[i
*3] + Image
[i
*3+1] + Image
[i
*3+2];
137 indexImage
[i
] = gray
/ 3;
141 ImgFormat
= GL_COLOR_INDEX
;
146 uglMesaSetColor(i
, g
, g
, g
);
150 printf("Loaded %d by %d image\n", ImgWidth
, ImgHeight
);
152 glPixelStorei(GL_UNPACK_ALIGNMENT
, 1);
153 glPixelStorei(GL_UNPACK_ROW_LENGTH
, ImgWidth
);
157 glViewport( 0, 0, width
, height
);
158 glMatrixMode( GL_PROJECTION
);
160 glOrtho( 0.0, width
, 0.0, height
, -1.0, 1.0 );
161 glMatrixMode( GL_MODELVIEW
);
165 UGL_LOCAL
void drawGL(void)
167 glClear(GL_COLOR_BUFFER_BIT
);
169 /* This allows negative raster positions: */
171 glBitmap(0, 0, 0, 0, Xpos
, Ypos
, NULL
);
173 glPixelStorei(GL_UNPACK_SKIP_PIXELS
, SkipPixels
);
174 glPixelStorei(GL_UNPACK_SKIP_ROWS
, SkipRows
);
176 glPixelZoom( Xzoom
, Yzoom
);
179 glEnable(GL_SCISSOR_TEST
);
181 glDrawPixels(DrawWidth
, DrawHeight
, ImgFormat
, GL_UNSIGNED_BYTE
, Image
);
183 glDisable(GL_SCISSOR_TEST
);
185 uglMesaSwapBuffers();
189 UGL_LOCAL
void benchmark( void )
191 int startTick
, endTick
, ticksBySec
;
193 double seconds
, pixelsPerSecond
;
195 printf("Benchmarking (4 sec)...\n");
198 glPixelStorei(GL_UNPACK_SKIP_PIXELS
, SkipPixels
);
199 glPixelStorei(GL_UNPACK_SKIP_ROWS
, SkipRows
);
200 glPixelZoom( Xzoom
, Yzoom
);
202 glEnable(GL_SCISSOR_TEST
);
205 glDrawBuffer(GL_FRONT
);
207 glDrawBuffer(GL_BACK
);
209 /* Run timing test */
212 ticksBySec
= sysClkRateGet ();
213 startTick
= tickGet();
216 glDrawPixels(DrawWidth
, DrawHeight
, ImgFormat
, GL_UNSIGNED_BYTE
, Image
);
218 endTick
= tickGet ();
219 } while ((endTick
- startTick
)/ticksBySec
< 4); /* 4 seconds */
222 glDisable(GL_SCISSOR_TEST
);
225 seconds
= (endTick
- startTick
)/ticksBySec
;
226 pixelsPerSecond
= draws
* DrawWidth
* DrawHeight
/ seconds
;
227 printf("Result: %d draws in %f seconds = %f pixels/sec\n",
228 draws
, seconds
, pixelsPerSecond
);
231 UGL_LOCAL
void echoUse(void)
234 printf(" SPACE Reset Parameters\n");
235 printf(" Up/Down Move image up/down\n");
236 printf(" Left/Right Move image left/right\n");
237 printf(" x Decrease X-axis PixelZoom\n");
238 printf(" X Increase X-axis PixelZoom\n");
239 printf(" y Decrease Y-axis PixelZoom\n");
240 printf(" Y Increase Y-axis PixelZoom\n");
241 printf(" w Decrease glDrawPixels width*\n");
242 printf(" W Increase glDrawPixels width*\n");
243 printf(" h Decrease glDrawPixels height*\n");
244 printf(" H Increase glDrawPixels height*\n");
245 printf(" p Decrease GL_UNPACK_SKIP_PIXELS*\n");
246 printf(" P Increase GL_UNPACK_SKIP_PIXELS*\n");
247 printf(" r Decrease GL_UNPACK_SKIP_ROWS*\n");
248 printf(" R Increase GL_UNPACK_SKIP_ROWS*\n");
249 printf(" s Toggle GL_SCISSOR_TEST\n");
250 printf(" f Toggle front/back buffer drawing\n");
251 printf(" d Toggle dithering\n");
252 printf(" b Benchmark test\n");
253 printf(" ESC Exit\n");
254 printf("* Warning: no limits are imposed on these parameters so it's\n");
255 printf(" possible to cause a segfault if you go too far.\n");
259 UGL_LOCAL
void readKey(UGL_WCHAR key
)
271 glDisable(GL_DITHER
);
320 DrawFront
= !DrawFront
;
322 glDrawBuffer(GL_FRONT
);
324 glDrawBuffer(GL_BACK
);
325 printf("glDrawBuffer(%s)\n", DrawFront
? "GL_FRONT" : "GL_BACK");
327 case UGL_UNI_UP_ARROW
:
330 case UGL_UNI_DOWN_ARROW
:
333 case UGL_UNI_LEFT_ARROW
:
336 case UGL_UNI_RIGHT_ARROW
:
345 UGL_LOCAL
void loopEvent(void)
348 UGL_INPUT_EVENT
* pInputEvent
;
352 if (uglEventGet (qId
, &event
, sizeof (event
), UGL_NO_WAIT
)
353 != UGL_STATUS_Q_EMPTY
)
355 pInputEvent
= (UGL_INPUT_EVENT
*)&event
;
357 if (pInputEvent
->header
.type
== UGL_EVENT_TYPE_KEYBOARD
&&
358 pInputEvent
->modifiers
& UGL_KEYBOARD_KEYDOWN
)
359 readKey(pInputEvent
->type
.keyboard
.key
);
368 UGL_LOCAL
void cleanUp (void)
370 uglEventQDestroy (eventServiceId
, qId
);
372 uglMesaDestroyContext();
376 void windMLDrawPix (void);
378 void ugldrawpix (void)
380 taskSpawn ("tDrawPix", 210, VX_FP_TASK
, 100000, (FUNCPTR
)windMLDrawPix
,
381 0,1,2,3,4,5,6,7,8,9);
384 void windMLDrawPix (void)
386 UGL_INPUT_DEVICE_ID keyboardDevId
;
388 GLsizei width
, height
;
392 DrawFront
= GL_FALSE
;
397 uglDriverFind (UGL_KEYBOARD_TYPE
, 0,
398 (UGL_UINT32
*)&keyboardDevId
);
400 uglDriverFind (UGL_EVENT_SERVICE_TYPE
, 0, (UGL_UINT32
*)&eventServiceId
);
402 qId
= uglEventQCreate (eventServiceId
, 100);
404 /* Double buffering */
405 umc
= uglMesaCreateNewContext (UGL_MESA_DOUBLE
, NULL
);
412 uglMesaMakeCurrentContext(umc
, 0, 0, UGL_MESA_FULLSCREEN_WIDTH
,
413 UGL_MESA_FULLSCREEN_HEIGHT
);
415 uglMesaGetIntegerv(UGL_MESA_COLOR_INDEXED
, &ciMode
);
416 uglMesaGetIntegerv(UGL_MESA_WIDTH
, &width
);
417 uglMesaGetIntegerv(UGL_MESA_HEIGHT
, &height
);
419 initGL(ciMode
, width
, height
);