X-Git-Url: https://git.ucc.asn.au/?a=blobdiff_plain;f=scene.c;h=7e72ae66e4dc340802a0567e44fb20a7bd43ed04;hb=ef6b009c8781673f3e353d47ae270a9f712bd4bf;hp=3571fefcfe227c8dbebac7d30c6d5bc6dcd2ffc2;hpb=7ad17b3e5493842a631f32b4de6478307d6f4b1d;p=atyndall%2Fcits2231.git diff --git a/scene.c b/scene.c index 3571fef..7e72ae6 100644 --- a/scene.c +++ b/scene.c @@ -464,20 +464,18 @@ void makeMenu() { * @param height New height */ void windowReshape(int width, int height) { - glViewport(0, 0, (GLsizei)width, (GLsizei)height); + /*glViewport(0, 0, (GLsizei)width, (GLsizei)height); + printf("Width: %d, height: %d\n", width, height); glMatrixMode(GL_PROJECTION); - glLoadIdentity(); - - gluPerspective(60, (GLfloat)width / (GLfloat)height, 0.1, 1000.0); - - /*glViewport(0, 0, w, h); - glMatrixMode(GL_PROJECTION); /* switch matrix mode - glLoadIdentity(); - if (w <= h) - gluOrtho2D(-2.0, 2.0, -2.0 * (GLfloat) h / (GLfloat) w, 2.0 * (GLfloat) h / (GLfloat) w); - else - gluOrtho2D(-2.0 * (GLfloat) w / (GLfloat) h, 2.0 * (GLfloat) w / (GLfloat) h, -2.0, 2.0); - glMatrixMode(GL_MODELVIEW); /* return to modelview mode */ + glLoadIdentity(); + gluPerspective( 60 * ((GLfloat)height/(GLfloat)width), (GLfloat)width/(GLfloat)height, 0.1, 1000.0); + glMatrixMode(GL_MODELVIEW); + + GLdouble near = 0.1; + GLdouble far = 1000.0; + GLdouble a = (GLfloat)height/(GLfloat)width; + GLdouble fov = 60; + glFrustum( -a*near*tan(fov/2), a*near*tan(fov/2), -a*near*tan(fov/2), a*near*tan(fov/2), near, far )*/ } /** @@ -498,16 +496,9 @@ void display() { glClear(GL_COLOR_BUFFER_BIT | GL_DEPTH_BUFFER_BIT); glLoadIdentity(); - glTranslatef(0.0f,0.0f,-6.0f); // Move Left 1.5 Units And Into The Screen 6.0 - + glTranslatef(0.0f,0.0f,-10.0f); // Move into the Screen 10.0 - glBegin(GL_QUADS); - glColor3f(1.0f,0.0f,0.0f); // Set The Color To Red - glVertex3f(-1.0f, 1.0f, 0.0f); // Top left - glVertex3f( 1.0f, 1.0f, 0.0f); // Top Right - glVertex3f( 1.0f,-1.0f, 0.0f); // Bottom Right - glVertex3f(-1.0f,-1.0f, 0.0f); // Bottom Left - glEnd(); + glutSolidTeapot(1); glutSwapBuffers(); } @@ -550,5 +541,11 @@ int main(int argc, char **argv) { glutMouseFunc(mouse); makeMenu(); + + glMatrixMode(GL_PROJECTION); + glLoadIdentity(); + gluPerspective( 60, 1, 0.1, 1000.0); + glMatrixMode(GL_MODELVIEW); + glutMainLoop(); }