X-Git-Url: https://git.ucc.asn.au/?p=atyndall%2Fcits2231.git;a=blobdiff_plain;f=scene.c;h=76b437bce3b06a1041baaf7899a9db680ce125ed;hp=3e0f34f5c2a708ad83b160c018af88a76d414f48;hb=b3158562a1e3a41388cd858ec6544ca0d48de6de;hpb=023daaaaab63ad4475c5839c7218407903815958 diff --git a/scene.c b/scene.c index 3e0f34f..76b437b 100644 --- a/scene.c +++ b/scene.c @@ -109,6 +109,17 @@ char *dirDefault2 = "/cslinux/examples/CITS2231/project-files/models-textures"; char dataDir[200]; // Stores the directory name for the meshes and textures. +static GLfloat floorVertices[4][3] = { + { -1000.0, 0.0, 1000.0 }, + { 1000.0, 0.0, 1000.0 }, + { 1000.0, 0.0, -1000.0 }, + { -1000.0, 0.0, -1000.0 }, +}; + +static GLfloat lightColor[] = {1.0, 1.0, 1.0, 1.0}; // White light +static GLfloat lightPosition[4]; +static float lightAngle = 10.0, lightHeight = 20; + /** * Prints out error message when file cannot be read * @param fileName Name of file that could not be read @@ -491,43 +502,106 @@ void mouse(int btn, int state, int x, int y) { } +/** + * 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(); + + /*if (useTexture) { + glDisable(GL_TEXTURE_2D); + }*/ + + glEnable(GL_LIGHTING); +} + /** * Display function */ void display() { - glClear(GL_COLOR_BUFFER_BIT | GL_DEPTH_BUFFER_BIT); - glLoadIdentity(); - - glTranslatef( 0.0f, 0.0f, 0.0f); - glBegin(GL_QUADS); - glVertex3f( 0.0f, 1.0f, -1.0f); - glVertex3f( 0.0f, 1.0f, 1.0f); - glVertex3f( 0.0f, -1.0f, 1.0f); - glVertex3f( 0.0f, -1.0f, -1.0f); - glEnd(); + glClear(GL_COLOR_BUFFER_BIT | GL_DEPTH_BUFFER_BIT); + glLoadIdentity(); + gluLookAt( + 0.0, 10000.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 */ + ); + + /* Reposition the light source. */ + lightPosition[0] = 12*cos(lightAngle); + lightPosition[1] = lightHeight; + lightPosition[2] = 12*sin(lightAngle); + lightPosition[3] = 0.0; + + glPushMatrix(); + glLightfv(GL_LIGHT0, GL_POSITION, lightPosition); + + glEnable(GL_BLEND); + glBlendFunc(GL_SRC_ALPHA, GL_ONE_MINUS_SRC_ALPHA); + drawFloor(); + glDisable(GL_BLEND); + + glPushMatrix(); + + //glTranslatef(0.0, 0.0, 0.0); + glLoadIdentity(); + glutSolidTeapot(5); // Draw teapot for test + glPopMatrix(); + glPushMatrix(); + glDisable(GL_LIGHTING); + glColor3f(1.0, 1.0, 1.0); - glTranslatef( 0.0f, 0.0f, -5.0f); // Move into the Screen 10.0 - glutSolidTeapot(1); + /* Draw a yellow ball at the light source. */ + glTranslatef(lightPosition[0], lightPosition[1], lightPosition[2]); + glutSolidSphere(1.0, 5, 5); - glMatrixMode(GL_MODELVIEW); - glLoadIdentity(); - gluLookAt(0.7f, 0.4f, 0.9f, -2.0f, -1.0f, -7.0f, 1.0f, 10.0f, 1.0f); + glEnable(GL_LIGHTING); + glPopMatrix(); + glPopMatrix(); - glMatrixMode(GL_PROJECTION); - glLoadIdentity(); - glutSwapBuffers(); + glutSwapBuffers(); } /** - * init function, sets OpenGL's starting state + * init function; sets initial OpenGL state */ void init() { glMatrixMode(GL_PROJECTION); glLoadIdentity(); - gluPerspective( 60, 1, 0.1, 1000.0); + + gluPerspective( + 60.0, /* field of view in degree */ + 1.0, /* aspect ratio */ + 0.0, /* Z near */ + 900.0 /* Z far */ + ); + + glLightModeli(GL_LIGHT_MODEL_LOCAL_VIEWER, 1); + glLightfv(GL_LIGHT0, GL_DIFFUSE, lightColor); + glLightf(GL_LIGHT0, GL_CONSTANT_ATTENUATION, 0.1); + glLightf(GL_LIGHT0, GL_LINEAR_ATTENUATION, 0.05); + glEnable(GL_LIGHT0); + glEnable(GL_LIGHTING); + glMatrixMode(GL_MODELVIEW); + glLoadIdentity(); } /** @@ -537,39 +611,42 @@ void init() { * @return Program exit code */ int main(int argc, char **argv) { + if(argc>1) + strcpy(dataDir, argv[1]); + else if(opendir(dirDefault1)) + strcpy(dataDir, dirDefault1); + else if(opendir(dirDefault2)) + strcpy(dataDir, dirDefault2); + else fileErr(dirDefault1); - if(argc>1) - strcpy(dataDir, argv[1]); - else if(opendir(dirDefault1)) - strcpy(dataDir, dirDefault1); - else if(opendir(dirDefault2)) - strcpy(dataDir, dirDefault2); - else fileErr(dirDefault1); + for(int i=0; i