blob: d2f57486744ecb5b98b80da050b0cd270983542f [file] [log] [blame]
jtgafb833d1999-08-19 00:55:39 +00001
2/*
3 * glDrawPixels demo/test/benchmark
4 *
5 * Brian Paul September 25, 1997 This file is in the public domain.
6 */
7
jtgafb833d1999-08-19 00:55:39 +00008#include <stdio.h>
9#include <stdlib.h>
10#include <math.h>
Brian Paul2d84ed82005-01-09 17:39:06 +000011#include <string.h>
jtgafb833d1999-08-19 00:55:39 +000012#include <GL/glut.h>
13
Brian Paul2d84ed82005-01-09 17:39:06 +000014#include "readtex.h"
jtgafb833d1999-08-19 00:55:39 +000015
16#define IMAGE_FILE "../images/girl.rgb"
17
18static int ImgWidth, ImgHeight;
19static GLenum ImgFormat;
20static GLubyte *Image = NULL;
21
22static int Xpos, Ypos;
23static int SkipPixels, SkipRows;
24static int DrawWidth, DrawHeight;
25static int Scissor = 0;
Brian Paul6a731f32002-01-26 17:49:30 +000026static int Fog = 0;
27static GLfloat Zpos = -1.0;
jtgafb833d1999-08-19 00:55:39 +000028static float Xzoom, Yzoom;
Brian Pauld13c0a91999-10-21 22:13:58 +000029static GLboolean DrawFront = GL_FALSE;
Brian Paul9d3e5db2000-09-08 21:45:21 +000030static GLboolean Dither = GL_TRUE;
jtgafb833d1999-08-19 00:55:39 +000031
32
33static void Reset( void )
34{
35 Xpos = Ypos = 20;
36 DrawWidth = ImgWidth;
37 DrawHeight = ImgHeight;
38 SkipPixels = SkipRows = 0;
39 Scissor = 0;
Brian Paul6a731f32002-01-26 17:49:30 +000040 Fog = 0;
41 Zpos = -1.0;
jtgafb833d1999-08-19 00:55:39 +000042 Xzoom = Yzoom = 1.0;
43}
44
45
46static void Display( void )
47{
48 glClear( GL_COLOR_BUFFER_BIT );
49
50#if 0
51 glRasterPos2i(Xpos, Ypos);
52#else
53 /* This allows negative raster positions: */
Brian Paul6a731f32002-01-26 17:49:30 +000054 glRasterPos3f(0, 0, Zpos);
jtgafb833d1999-08-19 00:55:39 +000055 glBitmap(0, 0, 0, 0, Xpos, Ypos, NULL);
56#endif
57
58 glPixelStorei(GL_UNPACK_SKIP_PIXELS, SkipPixels);
59 glPixelStorei(GL_UNPACK_SKIP_ROWS, SkipRows);
60
61 glPixelZoom( Xzoom, Yzoom );
62
63 if (Scissor)
64 glEnable(GL_SCISSOR_TEST);
65
Brian Paul6a731f32002-01-26 17:49:30 +000066 if (Fog)
67 glEnable(GL_FOG);
68
jtgafb833d1999-08-19 00:55:39 +000069 glDrawPixels(DrawWidth, DrawHeight, ImgFormat, GL_UNSIGNED_BYTE, Image);
70
71 glDisable(GL_SCISSOR_TEST);
Brian Paul6a731f32002-01-26 17:49:30 +000072 glDisable(GL_FOG);
jtgafb833d1999-08-19 00:55:39 +000073
Brian Paul1ad6e082005-09-29 18:46:27 +000074 if (DrawFront)
75 glFinish();
76 else
Brian Pauld13c0a91999-10-21 22:13:58 +000077 glutSwapBuffers();
jtgafb833d1999-08-19 00:55:39 +000078}
79
80
81static void Benchmark( void )
82{
83 int startTime, endTime;
84 int draws = 500;
85 double seconds, pixelsPerSecond;
86
87 printf("Benchmarking...\n");
88 /* GL set-up */
89 glPixelStorei(GL_UNPACK_SKIP_PIXELS, SkipPixels);
90 glPixelStorei(GL_UNPACK_SKIP_ROWS, SkipRows);
91 glPixelZoom( Xzoom, Yzoom );
92 if (Scissor)
93 glEnable(GL_SCISSOR_TEST);
Brian Paul6a731f32002-01-26 17:49:30 +000094 if (Fog)
95 glEnable(GL_FOG);
jtgafb833d1999-08-19 00:55:39 +000096
Brian Pauld13c0a91999-10-21 22:13:58 +000097 if (DrawFront)
98 glDrawBuffer(GL_FRONT);
99 else
100 glDrawBuffer(GL_BACK);
101
jtgafb833d1999-08-19 00:55:39 +0000102 /* Run timing test */
103 draws = 0;
104 startTime = glutGet(GLUT_ELAPSED_TIME);
105 do {
106 glDrawPixels(DrawWidth, DrawHeight, ImgFormat, GL_UNSIGNED_BYTE, Image);
107 draws++;
108 endTime = glutGet(GLUT_ELAPSED_TIME);
109 } while (endTime - startTime < 4000); /* 4 seconds */
110
111 /* GL clean-up */
112 glDisable(GL_SCISSOR_TEST);
Brian Paul6a731f32002-01-26 17:49:30 +0000113 glDisable(GL_FOG);
jtgafb833d1999-08-19 00:55:39 +0000114
115 /* Results */
116 seconds = (double) (endTime - startTime) / 1000.0;
117 pixelsPerSecond = draws * DrawWidth * DrawHeight / seconds;
118 printf("Result: %d draws in %f seconds = %f pixels/sec\n",
119 draws, seconds, pixelsPerSecond);
120}
121
122
123static void Reshape( int width, int height )
124{
125 glViewport( 0, 0, width, height );
126 glMatrixMode( GL_PROJECTION );
127 glLoadIdentity();
Brian Paul6a731f32002-01-26 17:49:30 +0000128 glOrtho( 0.0, width, 0.0, height, 0.0, 2.0 );
jtgafb833d1999-08-19 00:55:39 +0000129 glMatrixMode( GL_MODELVIEW );
130 glLoadIdentity();
131
132 glScissor(width/4, height/4, width/2, height/2);
133}
134
135
136static void Key( unsigned char key, int x, int y )
137{
138 (void) x;
139 (void) y;
140 switch (key) {
141 case ' ':
142 Reset();
143 break;
Brian Paul9d3e5db2000-09-08 21:45:21 +0000144 case 'd':
145 Dither = !Dither;
146 if (Dither)
147 glEnable(GL_DITHER);
148 else
149 glDisable(GL_DITHER);
150 break;
jtgafb833d1999-08-19 00:55:39 +0000151 case 'w':
152 if (DrawWidth > 0)
153 DrawWidth--;
154 break;
155 case 'W':
156 DrawWidth++;
157 break;
158 case 'h':
159 if (DrawHeight > 0)
160 DrawHeight--;
161 break;
162 case 'H':
163 DrawHeight++;
164 break;
165 case 'p':
166 if (SkipPixels > 0)
167 SkipPixels--;
168 break;
169 case 'P':
170 SkipPixels++;
171 break;
172 case 'r':
173 if (SkipRows > 0)
174 SkipRows--;
175 break;
176 case 'R':
177 SkipRows++;
178 break;
179 case 's':
180 Scissor = !Scissor;
181 break;
182 case 'x':
183 Xzoom -= 0.1;
184 break;
185 case 'X':
186 Xzoom += 0.1;
187 break;
188 case 'y':
189 Yzoom -= 0.1;
190 break;
191 case 'Y':
192 Yzoom += 0.1;
193 break;
Brian Paul6a731f32002-01-26 17:49:30 +0000194 case 'z':
195 Zpos -= 0.1;
196 printf("RasterPos Z = %g\n", Zpos);
197 break;
198 case 'Z':
199 Zpos += 0.1;
200 printf("RasterPos Z = %g\n", Zpos);
201 break;
jtgafb833d1999-08-19 00:55:39 +0000202 case 'b':
203 Benchmark();
204 break;
Brian Paul6a731f32002-01-26 17:49:30 +0000205 case 'F':
206 Fog = !Fog;
207 printf("Fog %d\n", Fog);
208 break;
Brian Pauld13c0a91999-10-21 22:13:58 +0000209 case 'f':
210 DrawFront = !DrawFront;
211 if (DrawFront)
212 glDrawBuffer(GL_FRONT);
213 else
214 glDrawBuffer(GL_BACK);
215 printf("glDrawBuffer(%s)\n", DrawFront ? "GL_FRONT" : "GL_BACK");
216 break;
jtgafb833d1999-08-19 00:55:39 +0000217 case 27:
218 exit(0);
219 break;
220 }
221 glutPostRedisplay();
222}
223
224
225static void SpecialKey( int key, int x, int y )
226{
227 (void) x;
228 (void) y;
229 switch (key) {
230 case GLUT_KEY_UP:
231 Ypos += 1;
232 break;
233 case GLUT_KEY_DOWN:
234 Ypos -= 1;
235 break;
236 case GLUT_KEY_LEFT:
237 Xpos -= 1;
238 break;
239 case GLUT_KEY_RIGHT:
240 Xpos += 1;
241 break;
242 }
243 glutPostRedisplay();
244}
245
246
Brian Paulb271ce82004-11-10 23:16:22 +0000247static void Init( GLboolean ciMode, const char *filename )
jtgafb833d1999-08-19 00:55:39 +0000248{
Brian Paul6a731f32002-01-26 17:49:30 +0000249 static const GLfloat fogColor[4] = {0, 1, 0, 0};
250
jtgafb833d1999-08-19 00:55:39 +0000251 printf("GL_VERSION = %s\n", (char *) glGetString(GL_VERSION));
252 printf("GL_RENDERER = %s\n", (char *) glGetString(GL_RENDERER));
253
Brian Paulb271ce82004-11-10 23:16:22 +0000254 Image = LoadRGBImage( filename, &ImgWidth, &ImgHeight, &ImgFormat );
jtgafb833d1999-08-19 00:55:39 +0000255 if (!Image) {
Brian Paulb271ce82004-11-10 23:16:22 +0000256 printf("Couldn't read %s\n", filename);
jtgafb833d1999-08-19 00:55:39 +0000257 exit(0);
258 }
259
260 if (ciMode) {
261 /* Convert RGB image to grayscale */
Brian Paulf02a5f62002-07-12 15:54:01 +0000262 GLubyte *indexImage = (GLubyte *) malloc( ImgWidth * ImgHeight );
jtgafb833d1999-08-19 00:55:39 +0000263 GLint i;
264 for (i=0; i<ImgWidth*ImgHeight; i++) {
265 int gray = Image[i*3] + Image[i*3+1] + Image[i*3+2];
266 indexImage[i] = gray / 3;
267 }
268 free(Image);
269 Image = indexImage;
270 ImgFormat = GL_COLOR_INDEX;
271
272 for (i=0;i<255;i++) {
273 float g = i / 255.0;
274 glutSetColor(i, g, g, g);
275 }
276 }
277
278 printf("Loaded %d by %d image\n", ImgWidth, ImgHeight );
279
280 glPixelStorei(GL_UNPACK_ALIGNMENT, 1);
281 glPixelStorei(GL_UNPACK_ROW_LENGTH, ImgWidth);
282
Brian Paul6a731f32002-01-26 17:49:30 +0000283 glFogi(GL_FOG_MODE, GL_LINEAR);
284 glFogf(GL_FOG_START, 0);
285 glFogf(GL_FOG_END, 2);
286 glFogfv(GL_FOG_COLOR, fogColor);
287
jtgafb833d1999-08-19 00:55:39 +0000288 Reset();
289}
290
291
292static void Usage(void)
293{
294 printf("Keys:\n");
Brian Paul8de4a381999-10-28 18:23:29 +0000295 printf(" SPACE Reset Parameters\n");
jtgafb833d1999-08-19 00:55:39 +0000296 printf(" Up/Down Move image up/down\n");
297 printf(" Left/Right Move image left/right\n");
Brian Paul8de4a381999-10-28 18:23:29 +0000298 printf(" x Decrease X-axis PixelZoom\n");
299 printf(" X Increase X-axis PixelZoom\n");
300 printf(" y Decrease Y-axis PixelZoom\n");
301 printf(" Y Increase Y-axis PixelZoom\n");
302 printf(" w Decrease glDrawPixels width*\n");
303 printf(" W Increase glDrawPixels width*\n");
304 printf(" h Decrease glDrawPixels height*\n");
305 printf(" H Increase glDrawPixels height*\n");
306 printf(" p Decrease GL_UNPACK_SKIP_PIXELS*\n");
307 printf(" P Increase GL_UNPACK_SKIP_PIXELS*\n");
308 printf(" r Decrease GL_UNPACK_SKIP_ROWS*\n");
309 printf(" R Increase GL_UNPACK_SKIP_ROWS*\n");
jtgafb833d1999-08-19 00:55:39 +0000310 printf(" s Toggle GL_SCISSOR_TEST\n");
Brian Paul6a731f32002-01-26 17:49:30 +0000311 printf(" F Toggle GL_FOG\n");
312 printf(" z Decrease RasterPos Z\n");
313 printf(" Z Increase RasterPos Z\n");
314
Brian Pauld13c0a91999-10-21 22:13:58 +0000315 printf(" f Toggle front/back buffer drawing\n");
jtgafb833d1999-08-19 00:55:39 +0000316 printf(" b Benchmark test\n");
317 printf(" ESC Exit\n");
Brian Paul8de4a381999-10-28 18:23:29 +0000318 printf("* Warning: no limits are imposed on these parameters so it's\n");
319 printf(" possible to cause a segfault if you go too far.\n");
jtgafb833d1999-08-19 00:55:39 +0000320}
321
322
323int main( int argc, char *argv[] )
324{
325 GLboolean ciMode = GL_FALSE;
Brian Paulb271ce82004-11-10 23:16:22 +0000326 const char *filename = IMAGE_FILE;
327 int i = 1;
jtgafb833d1999-08-19 00:55:39 +0000328
Brian Paulb271ce82004-11-10 23:16:22 +0000329 if (argc > i && strcmp(argv[i], "-ci")==0) {
jtgafb833d1999-08-19 00:55:39 +0000330 ciMode = GL_TRUE;
Brian Paulb271ce82004-11-10 23:16:22 +0000331 i++;
332 }
333 if (argc > i) {
334 filename = argv[i];
jtgafb833d1999-08-19 00:55:39 +0000335 }
336
337 glutInit( &argc, argv );
338 glutInitWindowPosition( 0, 0 );
339 glutInitWindowSize( 500, 400 );
340
341 if (ciMode)
342 glutInitDisplayMode( GLUT_INDEX | GLUT_DOUBLE );
343 else
Brian Paul9d3e5db2000-09-08 21:45:21 +0000344 glutInitDisplayMode( GLUT_RGB | GLUT_DOUBLE);
jtgafb833d1999-08-19 00:55:39 +0000345
346 glutCreateWindow(argv[0]);
347
Brian Paulb271ce82004-11-10 23:16:22 +0000348 Init(ciMode, filename);
jtgafb833d1999-08-19 00:55:39 +0000349 Usage();
350
351 glutReshapeFunc( Reshape );
352 glutKeyboardFunc( Key );
353 glutSpecialFunc( SpecialKey );
354 glutDisplayFunc( Display );
355
356 glutMainLoop();
357 return 0;
358}