X-Git-Url: https://git.ucc.asn.au/?p=atyndall%2Fcits2231.git;a=blobdiff_plain;f=helper.c;h=b13e8f9041b1a9dbe0c7785dc3f5c0cc13fd2ed1;hp=5c82e414e9389b3b8a889c457e6385f28c7fe0b9;hb=87e683d3752833b7efc3e9b8d323b9916edc74b9;hpb=fa7aa48eba358f8175a644b3261f8571ebbfe5e0 diff --git a/helper.c b/helper.c index 5c82e41..b13e8f9 100644 --- a/helper.c +++ b/helper.c @@ -207,99 +207,118 @@ int makeSubmenuFromArray( const char *menuEntries[], unsigned int menuEntriesSiz } /** - * Recursive function to draw a square by drawing smaller and smaller - * divisions of the square, determined by drawFloorRecurse. - * @param recurseLevel Current level of recursion, only pass 0 - * @param x1 top-left x - * @param z1 top-left z - * @param x2 bottom-left x - * @param z2 bottom-left z + * Draw a floor by looping over the floorSize and squareSize variables */ -void drawSquare(int recurseLevel, float x1, float z1, float x2, float z2) { +void drawFloor() { + if ( currentGroundTexture == 0 ) { + getTexture(1); + glBindTexture(GL_TEXTURE_2D, 1); + } else { + getTexture(currentGroundTexture); + glBindTexture(GL_TEXTURE_2D, currentGroundTexture); + } + + glBegin(GL_QUADS); + + + // **NOTE: Code under development to solve the texture-is-larger-than-square problem /* - if ( drawFloorRecurse != recurseLevel ) { - // Calculate middle points - float xm = (x1 + x2) / 2.0; - float zm = (z1 + z2) / 2.0; + int textureTileSize = 50; + int divisions = 2; - // Increment recursion level - int rnew = recurseLevel + 1; + for ( int tx = -floorSize; tx <= floorSize; tx += textureTileSize ) { + for ( int tz = -floorSize; tz <= floorSize; tz += textureTileSize ) { + int subTileWidth = textureTileSize / divisions; + for ( int x = 0; x <= divisions * 2; x++ ) { + for ( int z = 0; z <= divisions * 2; z++ ) { + glColor3f( 1.0, 1.0, 1.0 ); - // Split into four sub-quads - drawSquare(rnew, x1, z1, xm, zm); - drawSquare(rnew, x1, zm, xm, z2); - drawSquare(rnew, xm, zm, x2, z2); - drawSquare(rnew, xm, z1, x2, zm); + printf("Creating a subtile.\n"); + printf("Texture box is: (%d, %d), (%d, %d), (%d, %d), (%d, %d)\n",tx+textureTileSize, tz+textureTileSize,tx+textureTileSize, tz,tx, tz, tx, tz+textureTileSize ); + printf("Polygon box is: (%d, %d), (%d, %d), (%d, %d), (%d, %d)\n",(x+1)*subTileWidth+tx, (z+1)*subTileWidth+tz ,(x+1)*subTileWidth+tx, z*subTileWidth+tz, x*subTileWidth+tx, z*subTileWidth+tz, x*subTileWidth+tx, (z+1)*subTileWidth+tz); - } else { - // Draw square. - // **NOTE: Is the polygon facing in the right direction? - - float xm = (x1 + x2) / 2.0; - drawSquare(recurseLevel, ) - - glBegin(GL_QUADS); - glNormal3f(0,1,0); - glVertex3f(x1, 0.0, z1); - glVertex3f(x1, 0.0, z2); - glVertex3f(x2, 0.0, z2); - glVertex3f(x2, 0.0, z1); - glEnd(); - }*/ - - unsigned int GridSizeX = 100; - unsigned int GridSizeY = 100; - unsigned int SizeX = 2; - unsigned int SizeY = 2; - - - for (unsigned int x =0;x