Planet
navi homePPSaboutscreenshotsdownloaddevelopmentforum

Changeset 9093 in orxonox.OLD for branches/presentation/src


Ignore:
Timestamp:
Jul 4, 2006, 2:59:07 AM (19 years ago)
Author:
patrick
Message:

cr y axis full

File:
1 edited

Legend:

Unmodified
Added
Removed
  • branches/presentation/src/lib/graphics/importer/bsp_manager.cc

    r9091 r9093  
    11661166  {
    11671167    forward  = entity->getAbsCoor() +  box->center + dirX * (box->halfLength[0]  + BSP_X_OFFSET);
    1168     backward = entity->getAbsCoor() -  box->center + dirX * (box->halfLength[0]  + BSP_X_OFFSET);
     1168    backward = entity->getAbsCoor() +  box->center - dirX * (box->halfLength[0]  + BSP_X_OFFSET);
    11691169  }
    11701170  else
     
    12031203
    12041204  // collision registration
    1205   if( xCollisionForward) {
     1205  if( xCollisionForward)
     1206  {
    12061207    entity->registerCollision(COLLISION_TYPE_AXIS_X ,
    12071208                              this->parent, entity,
     
    12411242
    12421243  // collision registration
    1243   if( xCollisionBackward) {
     1244  if( xCollisionBackward)
     1245  {
    12441246    entity->registerCollision(COLLISION_TYPE_AXIS_X_NEG ,
    12451247                              this->parent, entity,
     
    12481250                              SolidFlag);
    12491251  }
    1250 
    1251 }
     1252}
     1253
    12521254
    12531255/**
    1254  * check the collision in the y direction (up, down)
     1256 * check the collision in the z direction (up, down)
    12551257 */
    12561258void BspManager::checkCollisionY(WorldEntity* entity)
     1259{
     1260
     1261  // Retrieve Bounding box
     1262  AABB* box = entity->getModelAABB();
     1263
     1264
     1265  plane*            testPlane          = NULL;  //!< the collision test plane
     1266
     1267  Vector            up;                         //!< up collision ray
     1268  Vector            down;                       //!< down collision ray
     1269  Vector            collPos;                    //!< the collision position
     1270
     1271  bool              yCollisionUp       = false; //!< flag true if right collision
     1272  bool              yCollisionDown     = false; //!< flag true if left collision
     1273  bool              SolidFlag          = false; //!< flag set true if solid
     1274
     1275  Vector            position;                   //!< current position of the entity
     1276  Vector            dirY;                       //!< direction x
     1277
     1278  position = entity->getAbsCoor();
     1279  collPos = position;
     1280  dirY =  Vector(0.0, 1.0, 0.0);
     1281
     1282  // calculate the rays
     1283  if( box != NULL)
     1284  {
     1285    up   = position +  box->center + dirY * (box->halfLength[1]  + BSP_Y_OFFSET);
     1286    down = position +  box->center - dirY * (box->halfLength[1]  + BSP_Y_OFFSET);
     1287  }
     1288  else
     1289  {
     1290    up   = position + dirY * 4.0f;
     1291    down = position + Vector(0.0, 1.0, 0.0) + dirY * 4.0;
     1292  }
     1293
     1294
     1295
     1296
     1297  /*   Y Ray up */
     1298  // init some member variables before collision check
     1299  this->inputStart = position;
     1300  this->inputEnd   = up;
     1301  this->checkCollisionRayN(this->root,0.0f,1.0f, &position, &up );
     1302
     1303  if( !this->outputStartsOut )
     1304  {
     1305    this->collPlane = new plane;
     1306    this->collPlane->x = 0.0f;
     1307    this->collPlane->y = 0.0f;
     1308    this->collPlane->z = 0.0f;
     1309    yCollisionUp = true;
     1310  }
     1311  else
     1312  {
     1313    if( this->outputFraction == 1.0f)
     1314    {
     1315      if( this->outputAllSolid )
     1316      {
     1317        this->collPlane = new plane;
     1318        this->collPlane->x = 0.0f;
     1319        this->collPlane->y = 0.0f;
     1320        this->collPlane->z = 0.0f;
     1321        yCollisionUp = true;
     1322        SolidFlag = true;
     1323      }
     1324      else
     1325      {
     1326        yCollisionUp = false;
     1327        collPos = up;
     1328      }
     1329    }
     1330    else
     1331    {
     1332      yCollisionUp = true;
     1333      collPos = position + (up - position) * this->outputFraction;
     1334      this->out = collPos;        // why this????
     1335    }
     1336  }
     1337  testPlane = this->collPlane;
     1338
     1339  // collision registration
     1340  if( yCollisionUp)
     1341  {
     1342    entity->registerCollision(COLLISION_TYPE_AXIS_Y , this->parent,
     1343                              entity,
     1344                              Vector(testPlane->x, testPlane->y, testPlane->z),
     1345                              collPos, SolidFlag);
     1346  }
     1347
     1348
     1349
     1350
     1351  /*   Y Ray down */
     1352  // init some member variables before collision check
     1353  this->inputStart = position;
     1354  this->inputEnd   = down;
     1355  this->checkCollisionRayN(this->root,0.0f,1.0f, &position, &down );
     1356
     1357  if( !this->outputStartsOut )
     1358  {
     1359    this->collPlane = new plane;
     1360    this->collPlane->x = 0.0f;
     1361    this->collPlane->y = 0.0f;
     1362    this->collPlane->z = 0.0f;
     1363    yCollisionDown = true;
     1364  }
     1365  else
     1366  {
     1367    if( this->outputFraction == 1.0f)
     1368    {
     1369      if( this->outputAllSolid )
     1370      {
     1371        this->collPlane = new plane;
     1372        this->collPlane->x = 0.0f;
     1373        this->collPlane->y = 0.0f;
     1374        this->collPlane->z = 0.0f;
     1375        yCollisionDown = true;
     1376        SolidFlag = true;
     1377      }
     1378      else
     1379      {
     1380        yCollisionDown = false;
     1381        collPos = down;
     1382      }
     1383    }
     1384    else
     1385    {
     1386      yCollisionDown = true;
     1387      collPos = position + (down - position) * this->outputFraction;
     1388      this->out = collPos;        // why this????
     1389    }
     1390  }
     1391  testPlane = this->collPlane;
     1392
     1393  // collision registration
     1394  if( yCollisionDown)
     1395  {
     1396    entity->registerCollision(COLLISION_TYPE_AXIS_Y_NEG , this->parent,
     1397                              entity,
     1398                              Vector(testPlane->x, testPlane->y, testPlane->z),
     1399                              collPos, SolidFlag);
     1400  }
     1401
     1402
     1403}
     1404
     1405
     1406
     1407
     1408/**
     1409 * check the collision in the z direction (left, right)
     1410 */
     1411void BspManager::checkCollisionZ(WorldEntity* entity)
    12571412{
    12581413  // Retrieve Bounding box
     
    12801435  {
    12811436    right = entity->getAbsCoor() +  box->center + dirZ * (box->halfLength[2]  + BSP_Z_OFFSET);
    1282     left  = entity->getAbsCoor() -  box->center + dirZ * (box->halfLength[2]  + BSP_Z_OFFSET);
     1437    left  = entity->getAbsCoor() +  box->center - dirZ * (box->halfLength[2]  + BSP_Z_OFFSET);
    12831438  }
    12841439  else
     
    13211476  if( zCollisionRight) {
    13221477    entity->registerCollision(COLLISION_TYPE_AXIS_Z , this->parent,
    1323                                    entity,
    1324                                    Vector(testPlane->x, testPlane->y, testPlane->z),
    1325                                    collPos , SolidFlag);
     1478                              entity,
     1479                              Vector(testPlane->x, testPlane->y, testPlane->z),
     1480                              collPos , SolidFlag);
    13261481  }
    13271482
     
    13661521
    13671522}
    1368 
    1369 
    1370 /**
    1371  * check the collision in the z direction (left, right)
    1372  */
    1373 void BspManager::checkCollisionZ(WorldEntity* entity)
    1374 {
    1375 
    1376 }
    1377 
    13781523
    13791524
Note: See TracChangeset for help on using the changeset viewer.