/* Auteur: Nicolas JANEY */ /* nicolas.janey@univ-fcomte.fr */ /* Avril 2004 */ /* Illustration du trace de */ /* cercle par l'algorithme */ /* de Bresenham (Midpoint) */ #include #include #include #include #include #include #include "ModuleCouleurs.h" #include "ModuleMenus.h" #include "ModuleReshape.h" static int aff = 0 ; static int yy = 0 ; static int cc = 0 ; static int c = 1 ; void circle(int *p1,float r) { glColor4fv(couleurBleu()) ; glBegin(GL_LINE_LOOP) ; for ( int i = 0 ; i < 360 ; i++ ) { float angle = i * 3.14159F / 180 ; float x = (float) (p1[0] + r*cos(angle)) ; float y = (float) (p1[1] + r*sin(angle)) ; glVertex2f(x,y) ; } glEnd() ; } void pixel(int x,int y,float *c) { glColor4fv(c) ; glBegin(GL_QUADS) ; glVertex2f(x-0.5F,y-0.5F) ; glVertex2f(x-0.5F,y+0.5F) ; glVertex2f(x+0.5F,y+0.5F) ; glVertex2f(x+0.5F,y-0.5F) ; glEnd() ; } void trame(int xi,int xf,int y,float *c) { for ( int i = xi ; i <= xf ; i++ ) pixel(i,y,c); } void pixelsSymetriques(int x,int y,float *c) { pixel(x,y,c) ; pixel(-x,y,c) ; pixel(x,-y,c) ; pixel(-x,-y,c) ; pixel(y,x,c) ; pixel(-y,x,c) ; pixel(y,-x,c) ; pixel(-y,-x,c) ; } void cercle(float *c,int r) { int x,y,d ; x = 0 ; y = r ; d = 1 - r ; pixelsSymetriques(x,y,c) ; while ( y > x ) { if ( d < 0 ) d += 2 * x + 3 ; else { d += 2 * (x - y) + 5 ; y-- ; } x++ ; pixelsSymetriques(x,y,c) ; } } void disque(float *c,int r) { int x,y,d ; x = 0 ; y = r ; d = 1 - r ; trame(-x,x,y,c) ; trame(-x,x,-y,c) ; trame(-y,y,x,c) ; trame(-y,y,-x,c) ; while ( y > x ) { if ( d < 0 ) d += 2 * x + 3 ; else { trame(-x,x,y,c) ; trame(-x,x,-y,c) ; d += 2 * (x - y) + 5 ; y-- ; } x++ ; trame(-y,y,x,c) ; trame(-y,y,-x,c) ; } } void cercleIncomplet(float *c,int r,int max,int aff) { int x,y,d ; x = 0 ; y = r ; d = 1 - r ; pixelsSymetriques(x,y,c) ; int cp = 0 ; while ( ( y > x ) && ( cp < max ) ) { cp++ ; if ( d < 0 ) d += 2 * x + 3 ; else { d += 2 * (x - y) + 5 ; y-- ; } x++ ; pixelsSymetriques(x,y,c) ; } } void disqueIncomplet(float *c,int r,int max,int aff) { int x,y,d ; x = 0 ; y = r ; d = 1 - r ; trame(-r,r,0,c) ; int cp = 0 ; while ( ( y > x ) && ( cp < max ) ) { cp++ ; if ( d < 0 ) d += 2 * x + 3 ; else { trame(-x,x,y,c) ; trame(-x,x,-y,c) ; d += 2 * (x - y) + 5 ; y-- ; } x++ ; trame(-y,y,x,c) ; trame(-y,y,-x,c) ; } } void display() { int p[] = { 0,0 } ; glClear(GL_COLOR_BUFFER_BIT|GL_DEPTH_BUFFER_BIT); glPushMatrix(); switch (aff) { case 0 : case 2 : case 4 : case 6 : if ( ( cc == 1 ) || ( cc == 2 ) ) disque(couleurVert(),10+(aff/2)*5) ; if ( ( cc == 0 ) || ( cc == 2 ) ) cercle(couleurRouge(),10+(aff/2)*5) ; if ( c ) circle(p,10+(aff/2)*5) ; break ; case 1 : case 3 : case 5 : case 7 : if ( ( cc == 1 ) || ( cc == 2 ) ) disqueIncomplet(couleurVert(),10+(aff/2)*5,yy,0) ; if ( ( cc == 0 ) || ( cc == 2 ) ) cercleIncomplet(couleurRouge(),10+(aff/2)*5,yy,0) ; if ( c ) circle(p,10+(aff/2)*5) ; break ; } glPopMatrix(); glFlush(); glutSwapBuffers() ; } void myinit() { glShadeModel(GL_SMOOTH); glClearColor(0.8F,0.8F,0.8F,1.0F); } void key(unsigned char key,int x,int y) { switch ( key ) { case 'c' : case 'C' : c = !c; glutPostRedisplay(); break; case ' ' : cc = (cc+1)%3; glutPostRedisplay(); break; case 43 : yy++ ; if ( yy == 60 ) yy = 0 ; glutPostRedisplay(); break; case 45 : yy-- ; if ( yy == -1 ) yy = 0 ; glutPostRedisplay(); break; case 0x0D : yy = 0 ; aff = (aff+1)%8 ; glutPostRedisplay(); break; case 0x1B : exit(0) ; break; } } int main(int argc,char **argv) { glutInit(&argc,argv); glutInitDisplayMode(GLUT_RGBA|GLUT_DEPTH|GLUT_DOUBLE); glutInitWindowSize(300,300); glutInitWindowPosition(50,50); glutCreateWindow("Cercles par l'algorithme du midpoint"); myinit(); creationMenuBasique(); setParametresOrthoBasique(-30.0,30.0,-30.0,30.0,-40.0,40.0); glutReshapeFunc(reshapeOrthoBasique); glutKeyboardFunc(key); glutDisplayFunc(display); glutMainLoop(); return(0); }