X-Git-Url: https://git.ucc.asn.au/?p=atyndall%2Fcits2231.git;a=blobdiff_plain;f=helper.c;h=a1f126ed392a81d1cf2f9500b86d72d7919ed7e0;hp=bb5760358f1e312975f2cd05c5310f00fee1aa09;hb=88ac4af87506f6e5027666f37f2ea247e2083ec7;hpb=139101a6a30d0fdefafe6c2b5f23a80d3ae9f114 diff --git a/helper.c b/helper.c index bb57603..a1f126e 100644 --- a/helper.c +++ b/helper.c @@ -207,100 +207,115 @@ 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(currentGroundTexture); + glBindTexture(GL_TEXTURE_2D, currentGroundTexture); + } + + glBegin(GL_QUADS); + + + // **NOTE: Code under development to solve the texture-is-larger than square problem + + int textureTileSize = 50; + int divisions = 2; + + 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 <= textureTileSize; x += subTileWidth ) { + for ( int z = 0; z <= textureTileSize; z += subTileWidth ) { + glColor3f( 1.0, 1.0, 1.0 ); + + 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, (z+1)*subTileWidth ,(x+1)*subTileWidth, z*subTileWidth, x*subTileWidth, z*subTileWidth, x*subTileWidth, (z+1)*subTileWidth); + + glTexCoord2f( tx+textureTileSize, tz+textureTileSize ); + glVertex3f ( (x+1)*subTileWidth, 0.0, (z+1)*subTileWidth ); + + glTexCoord2f( tx+textureTileSize, tz ); + glVertex3f ( (x+1)*subTileWidth, 0.0, z*subTileWidth ); + + glTexCoord2f( tx, tz ); + glVertex3f ( x*subTileWidth, 0.0, z*subTileWidth ); + + glTexCoord2f( tx, tz+textureTileSize ); + glVertex3f ( x*subTileWidth, 0.0, (z+1)*subTileWidth ); + } + } + } + } + /* - if ( drawFloorRecurse != recurseLevel ) { - // Calculate middle points - float xm = (x1 + x2) / 2.0; - float zm = (z1 + z2) / 2.0; - - // Increment recursion level - int rnew = recurseLevel + 1; - - // 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); - - } 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 =-GridSizeX;x