X-Git-Url: http://git.mutantstargoat.com/user/nuclear/?a=blobdiff_plain;f=progs%2Fdemos%2FFractals_random%2Ffractals_random.c;h=324f00b26e9ba2e4bd35f787753de5b5846acaf0;hb=f1774ac58ab2a7c7967d243a7909e01dda2cb21d;hp=e401c706a067b7e8f39a6d1d6aeefa7973ca4fc7;hpb=0fc97b9a2b832dfea1beadb3bb3539b2fa72c637;p=freeglut diff --git a/progs/demos/Fractals_random/fractals_random.c b/progs/demos/Fractals_random/fractals_random.c index e401c70..324f00b 100644 --- a/progs/demos/Fractals_random/fractals_random.c +++ b/progs/demos/Fractals_random/fractals_random.c @@ -50,6 +50,9 @@ float scale_factor = 1.0 ; /* The current point */ float current_x = 0.0, current_y = 0.0 ; +/* Signals when a glClear is needed */ +static GLboolean needClear = GL_TRUE; + static void draw_level ( int num, double m00, double m01, double m10, double m11, double n0, double n1 ) { /* Draw a fractal transformed by "M", "N" as passed in */ @@ -70,6 +73,11 @@ static void draw_level ( int num, double m00, double m01, double m10, double m11 static void Display(void) { + if (needClear) { + glClear(GL_COLOR_BUFFER_BIT); + needClear = GL_FALSE; + } + /* the curve */ glPushMatrix(); glScalef(2.5, 2.5, 2.5); @@ -81,7 +89,7 @@ Display(void) glPopMatrix(); - // glutSwapBuffers(); /* Should NOT be here... This is a Single-Buffered Program! */ + glFlush(); glutPostRedisplay(); /* Needed so that this function will be called again */ } @@ -93,12 +101,16 @@ Reshape(int width, int height) glMatrixMode(GL_PROJECTION); glLoadIdentity(); ar = (float) width / (float) height; - glFrustum(-ar, ar, -1.0, 1.0, 2.0, 100.0); + if( ar > 1 ) + glFrustum(-ar, ar, -1.0, 1.0, 2.0, 100.0); + else + glFrustum(-1.0, 1.0, -1/ar, 1/ar, 2.0, 100.0); glMatrixMode(GL_MODELVIEW); glLoadIdentity(); xwin = -1.0 ; ywin = 0.0 ; glTranslatef(xwin, ywin, -5.0); + needClear = GL_TRUE; } static void @@ -119,7 +131,7 @@ Key(unsigned char key, int x, int y) break ; } - glClear(GL_COLOR_BUFFER_BIT | GL_DEPTH_BUFFER_BIT); + needClear = GL_TRUE; glutPostRedisplay(); } @@ -169,7 +181,7 @@ Special(int key, int x, int y) break ; } - glClear(GL_COLOR_BUFFER_BIT | GL_DEPTH_BUFFER_BIT); + needClear = GL_TRUE; glutPostRedisplay(); } @@ -188,6 +200,11 @@ void readConfigFile ( char *fnme ) /* Read the window title */ fgets ( inputline, 256, fptr ) ; + /* We assume here that this line will not exceed 79 characters plus a + newline (window_title is 80 characters long). That'll cause a buffer + overflow. For a simple program like this, though, we're letting it + slide! + */ sscanf ( inputline, "%[a-zA-Z0-9!@#$%^&*()+=/\\_-\" ]", window_title ) ; /* Read a comment line */ @@ -236,23 +253,21 @@ main(int argc, char *argv[]) { int fractal_window ; - if ( argc > 1 ) - readConfigFile ( argv[1] ) ; - else - readConfigFile ( "fractals.dat" ) ; + glutInitDisplayMode( GLUT_RGB | GLUT_SINGLE ); - glutInit(&argc, argv); glutInitWindowSize(500, 250); glutInitWindowPosition ( 140, 140 ) ; + glutInit(&argc, argv); - glutInitDisplayMode(GLUT_RGB | GLUT_SINGLE | GLUT_DEPTH); + if ( argc > 1 ) + readConfigFile ( argv[1] ) ; + else + readConfigFile ( "fractals.dat" ) ; fractal_window = glutCreateWindow( window_title ); glClearColor(1.0, 1.0, 1.0, 1.0); - glClear(GL_COLOR_BUFFER_BIT | GL_DEPTH_BUFFER_BIT); - glutReshapeFunc(Reshape); glutKeyboardFunc(Key); glutSpecialFunc(Special);