X-Git-Url: https://git.ucc.asn.au/?a=blobdiff_plain;f=scene.c;h=1e89dc776444f8bcec2dde13014a5a9b5a061e53;hb=41cbed9054b38b60a0832bbfa24501e20d93aa6d;hp=6993bd4fb13708f2f84332eb691b71d13c88b5fc;hpb=a2f1c50d8985e2f043840ffea632fba446535a34;p=atyndall%2Fcits2231.git diff --git a/scene.c b/scene.c index 6993bd4..1e89dc7 100644 --- a/scene.c +++ b/scene.c @@ -556,24 +556,21 @@ motion(int x, int y) void idle() { angle = (int)(angle + 10) % 360; - //angle2 = (int)(angle2 + 10) % 360; - printf("Angle 1: %f, Angle 2: %f\n", angle, angle2); - sleep(25); - glutPostRedisplay(); + //angle2 = (int)(angle2 + 10) % 360; + printf("Angle 1: %f, Angle 2: %f\n", angle, angle2); + sleep(1); + glutPostRedisplay(); } -int drawFloorRecurse = 2; +int drawFloorRecurse = 5; void drawSquare(int recurseLevel, float x1, float y1, float x2, float y2) { - printf("%d, %d, %d, %d\n", x1, y2, x2, y2); - if ( drawFloorRecurse != recurseLevel ) { float xm = (x1 + x2) / 2.0; float ym = (y1 + y2) / 2.0; int rnew = recurseLevel + 1; - printf("Recursing to level %d\n", rnew); // Split into four sub-quads drawSquare(rnew, x1, y1, xm, ym); @@ -582,7 +579,6 @@ void drawSquare(int recurseLevel, float x1, float y1, float x2, float y2) { drawSquare(rnew, xm, y1, x2, ym); } else { - printf("Drawing (%.10f, %.10f) -> (%.10f, %.10f)\n", x1, y2, x2, y2); glBegin(GL_QUADS); glVertex3f(x1, 0.0, y1); glVertex3f(x1, 0.0, y2); @@ -597,30 +593,13 @@ void drawSquare(int recurseLevel, float x1, float y1, float x2, float y2) { * Draw a floor. */ void drawFloor() { - glDisable(GL_LIGHTING); - - //if (useTexture) { - // glEnable(GL_TEXTURE_2D); - //} - - /*glBegin(GL_QUADS); - glTexCoord2f(0.0, 0.0); - glVertex3fv(floorVertices[0]); - glTexCoord2f(0.0, 16.0); - glVertex3fv(floorVertices[1]); - glTexCoord2f(16.0, 16.0); - glVertex3fv(floorVertices[2]); - glTexCoord2f(16.0, 0.0); - glVertex3fv(floorVertices[3]); - glEnd();*/ - -drawSquare(0, -10.0, -10.0, 10.0, 10.0); + +drawSquare(0, -1000.0, -1000.0, 1000.0, 1000.0); /*if (useTexture) { glDisable(GL_TEXTURE_2D); }*/ - glEnable(GL_LIGHTING); } /*void drawSquare(GLfloat x1, GLfloat y1, GLfloat x2, GLfloat y2) { @@ -633,11 +612,13 @@ drawSquare(0, -10.0, -10.0, 10.0, 10.0); void display() { glClear(GL_COLOR_BUFFER_BIT | GL_DEPTH_BUFFER_BIT); glLoadIdentity(); - gluLookAt( - 0.0, 0.0, 60.0, /* eye is at (x,y,z) */ - 0.0, 0.0, 0.0, /* center is at (x,y,z) */ - 0.0, 1.0, 0.0 /* up is in postivie Y direction */ - ); + //gluLookAt( + // 0.0, 0.0, 30.0, /* eye is at (x,y,z) */ + // 0.0, 0.0, 0.0, /* center is at (x,y,z) */ + // 0.0, 1.0, 0.0 /* up is in postivie Y direction */ + // ); + + glRotatef(30.0, 1.0, 0.0, 0.0); /* Reposition the light source. */ lightPosition[0] = 12*cos(lightAngle); @@ -647,7 +628,7 @@ void display() { glPushMatrix(); /* Perform scene rotations based on user mouse input. */ - glRotatef(angle2, 1.0, 0.0, 0.0); + glRotatef(angle, 0.0, 1.0, 0.0); glLightfv(GL_LIGHT0, GL_POSITION, lightPosition);