Planet
navi homePPSaboutscreenshotsdownloaddevelopmentforum

Changeset 6727 in orxonox.OLD for branches/height_map_merge/src/lib/graphics


Ignore:
Timestamp:
Jan 25, 2006, 5:46:16 PM (19 years ago)
Author:
bottac
Message:
 
Location:
branches/height_map_merge/src/lib/graphics/importer
Files:
2 edited

Legend:

Unmodified
Added
Removed
  • branches/height_map_merge/src/lib/graphics/importer/height_map.cc

    r6603 r6727  
    3737lowResModel  = new VertexArrayModel();
    3838
    39 this->load(i1,j1,i2,j2,hm,highResModel,2);
     39this->load(i1,j1,i2,j2,hm,highResModel,4);
    4040this->load(i1,j1,i2,j2,hm,lowResModel, 8);
    4141}
     
    5757                                                                //FIXME
    5858    float cameraDistance = (State::getCamera()->getAbsCoor() - Vector(0.0,100.0,0.0)).len();
    59     if (cameraDistance > 5000 )
     59    if (cameraDistance > 10000 )
    6060    {
    6161   
    6262    }
    63     else if (cameraDistance > 1000 )
     63    else if (cameraDistance >= 50000 )
    6464    {
    6565      this->drawLowRes();
     
    9898        int sampleRate = Res;
    9999       
    100          float height = 0;
     100        float height = 0;
    101101        int offset = 0;
    102102       
     
    128128                model->addVertex(scaleX*(heightMap->h -i)+ shiftX,shiftY,scaleZ*(w)+ shiftZ); // Top Right
    129129                model->addNormal(normalVectorField[i][w].y,normalVectorField[i][w].z,normalVectorField[i][w].x);
    130                 model->addTexCoor((((w -sampleRate)/sampleRate)%4)/4.0,(((i-sampleRate)/sampleRate)%4)/4.0);
     130                model->addTexCoor((float)(j1-sampleRate) /(texRate), (float)(i %heightMap->h)/(texRate));
    131131                model->addColor(r/255.0,g/255.0,b/255.0);
    132132               
     
    147147                height +=  (float)(unsigned char)hm->heights[j +sampleRate+ (i+2)*(heightMap->w )];
    148148                height +=  (float)(unsigned char)hm->heights[j+sampleRate + (i)*(heightMap->w )];
    149                
    150149                height=height/5.0;
    151150               
    152151                model->addVertex(scaleX*(heightMap->h -i) + shiftX ,((double)(height)*scaleY) + shiftY ,scaleZ*(j) + shiftZ); // Top Right     
    153152                model->addNormal(normalVectorField[i][j].y,normalVectorField[i][j].z,normalVectorField[i][j].x);
    154                 model->addTexCoor((float)j /(texRate), (float)(i %heightMap->h)/(texRate));
     153                model->addTexCoor((float)(j) /(texRate), (float)(i %heightMap->h)/(texRate));
    155154               
    156155                //PRINTF(0)("TexCoord:  %f %f \n",(float)j / 100.0, (float)(i %heightMap->h)/100.0);
     
    163162                model->addVertex(scaleX*(heightMap->h -i)+ shiftX,shiftY,scaleZ*(w)+ shiftZ); // Top Right
    164163                model->addNormal(normalVectorField[i][w].y,normalVectorField[i][w].z,normalVectorField[i][w].x);
    165                 model->addTexCoor((((w+sampleRate)/sampleRate))/4.0,(((i+ sampleRate)/sampleRate))/4.0);
     164                model->addTexCoor((float)(j2+sampleRate) /(texRate), (float)(i %heightMap->h)/(texRate));
    166165                model->addColor(r/255.0,g/255.0,b/255.0);
    167166               
     
    208207                model->addVertex(scaleX*(heightMap->h -i) + shiftX , shiftY ,scaleZ*(j) + shiftZ); // Top Right
    209208                model->addNormal(normalVectorField[i][j].y,normalVectorField[i][j].z,normalVectorField[i][j].x);
    210                 model->addTexCoor(((j/sampleRate))/texRatef,(((i - sampleRate)/sampleRate))/texRatef);
     209                model->addTexCoor((float)j /(texRate), (float)((i - sampleRate) %heightMap->h)/(texRate));
    211210                model->addColor(r/255.0,g/255.0,b/255.0);               
    212211       
     
    225224                model->addVertex(scaleX*(heightMap->h -i) + shiftX , ((double)(height)*scaleY) +shiftY ,scaleZ*(j) + shiftZ); // Top Right     
    226225                model->addNormal(normalVectorField[i][j].y,normalVectorField[i][j].z,normalVectorField[i][j].x);
    227                 model->addTexCoor(((j/sampleRate))/texRatef,(((i)/sampleRate))/texRatef);
     226                model->addTexCoor((float)j /(texRate), (float)(i %heightMap->h)/(texRate));
    228227                model->addColor(r/255.0,g/255.0,b/255.0);
    229228           
     
    246245                model->addVertex(scaleX*(heightMap->h -i) + shiftX , shiftY ,scaleZ*(j) + shiftZ); // Top Right
    247246                model->addNormal(normalVectorField[i][j].y,normalVectorField[i][j].z,normalVectorField[i][j].x);
    248                 model->addTexCoor(((j/sampleRate)%texRate)/texRatef,(((i- sampleRate)/sampleRate)%texRate)/texRatef);
     247                model->addTexCoor((float)j /(texRate), (float)((i+ sampleRate) %heightMap->h)/(texRate));
    249248                model->addColor(r/255.0,g/255.0,b/255.0);               
    250249       
     
    255254            {
    256255                int i = i2;
    257                         height = (float)(unsigned char) hm->heights[j +sampleRate+ i*(heightMap->w )];
     256                height = (float)(unsigned char) hm->heights[j +sampleRate+ i*(heightMap->w )];
    258257                height += (float)(unsigned char) hm->heights[j+ 1 + sampleRate + (i+1)*(heightMap->w )];
    259258                height +=  (float) (unsigned char) hm->heights[j -1+ sampleRate   + (i+1)*(heightMap->w )];
     
    263262                model->addVertex(scaleX*(heightMap->h -i) + shiftX , ((double)(height)*scaleY) +shiftY ,scaleZ*(j) + shiftZ); // Top Right     
    264263                model->addNormal(normalVectorField[i][j].y,normalVectorField[i][j].z,normalVectorField[i][j].x);
    265                 model->addTexCoor(((j/sampleRate)%texRate)/texRatef,((i/sampleRate)%texRate)/texRatef);
     264                model->addTexCoor((float)j /(texRate), (float)(i %heightMap->h)/(texRate));
    266265                model->addColor(r/255.0,g/255.0,b/255.0);
    267266           
     
    452451        for(int j = 1; j < j_max ; j++)
    453452        {
    454                
    455453         tiles[i][j]->draw();
    456454        }       
     
    500498
    501499
    502 
    503 
    504 
    505500void HeightMap::scale(Vector v)
    506501{
     
    510505}
    511506
    512 void HeightMap::shift(Vector v)
    513 {
    514  shiftX = v.x;
    515  shiftY = v.y;
    516  shiftZ = v.z;
    517 }
    518 
    519 
    520 float HeightMap::getHeight(float x, float y)
    521 {
     507void HeightMap::setAbsCoor(Vector v)
     508{
     509 offsetX = v.x;
     510 offsetY = v.y;
     511 offsetZ  = v.z;
     512}
     513
     514
     515float HeightMap::getHeight(float x, float y)
     516{
     517
     518 //x -= offsetX;
     519 //y -= offsetZ;
     520 
     521 
    522522 int xInt = (int)x / scaleX;  x -= (float)xInt*scaleX; xInt = heightMap->h - xInt;
    523  int yInt = (int)y / scaleZ;    y -= (float)yInt*scaleZ;
    524  if(xInt <= 0 || xInt >= heightMap->h || yInt <= 0 || yInt >= heightMap->w  ) return 0.0f;
     523 int yInt = (int)y / scaleZ;    y -= (float)yInt*scaleZ; /*yInt = heightMap->w - yInt;*/
     524 
     525 if(xInt <= 0 || xInt >= heightMap->h || yInt <= 0 || yInt >= heightMap->w  ) return shiftY;
     526 
    525527 float height = heights[yInt + (xInt)*heightMap->w]*scaleY;
     528 
    526529 float a = normalVectorField[(xInt)][yInt].x;
    527530 float b = normalVectorField [(xInt)][yInt].z;
    528531 float c = normalVectorField [(xInt)][yInt].y;
    529   height -= ( (a/c)*(x) + (b/c)*(y))*scaleY;
    530  return height;
    531 }
     532 
     533 height -= ( (a/c)*(x) + (b/c)*(y);
     534 
     535 return (height );
     536}
  • branches/height_map_merge/src/lib/graphics/importer/height_map.h

    r6603 r6727  
    1010
    1111   ### File Specific:
    12    main-programmer:
     12   main-programmer: bottac@ee.ethz.ch
    1313*/
    1414
     
    1717
    1818
    19 #define texRate      64
     19#define texRate      32
    2020#define texRatef     4.0f
    21 #define tileSize     64
     21#define tileSize     128
    2222
    2323class SDL_Surface;
     
    5858void load(const char*, int Mode);
    5959void scale( Vector V);
    60 void shift (Vector V);
     60void setAbsCoor(Vector V);
    6161float getHeight(float x, float y);
     62float getNormal(float x, float y);
    6263HeightMap();
    6364HeightMap(const char*);
     
    7879Vector  **  normalVectorField ;
    7980Tile    ***  tiles;
    80 Vector     camCoords;
     81Vector    camCoords;
     82Vector offsetCoords; 
    8183Material * tmp_mat;
    8284Material* red_mat;
     
    8688float scaleY ;
    8789float scaleZ ;
    88 float shiftX ;
    89 float shiftY ;
    90 float shiftZ ;
     90float shiftX ; // to be removed
     91float shiftY ; // to be removed
     92float shiftZ ; // to be removed
     93float offsetX;
     94float offsetY;
     95float offsetZ;
    9196int   cmScaleX;
    9297int   cmScaleY;
Note: See TracChangeset for help on using the changeset viewer.