Planet
navi homePPSaboutscreenshotsdownloaddevelopmentforum

Ignore:
Timestamp:
Jun 29, 2006, 10:47:05 PM (19 years ago)
Author:
patrick
Message:

collision reaction refine

File:
1 edited

Legend:

Unmodified
Added
Removed
  • branches/single_player_map/src/lib/collision_reaction/cr_physics_ground_walk.cc

    r8923 r8924  
    7474
    7575  float height;
    76 
    77 
    78    const std::vector<CollisionEvent*>* collisionEvents = &(collision->getCollisionEvents());
    79    std::vector<CollisionEvent*>::const_iterator it = collisionEvents->begin();
    80    for(; it != collisionEvents->end(); it++)
    81    {
    82 
    83      CollisionEvent* ce = (*it);
    84      Vector normal = ce->getGroundNormal();
    85 
    86      // collision position maths
    87      Vector collPos =  collision->getEntityB()->getAbsCoor()  + box->center - ce->getCollisionPosition();
    88 
    89 
    90      // test the 3 axis differently
    91      switch( ce->getType())
    92      {
    93        // collision in the x-axis
    94        case COLLISION_TYPE_AXIS_X:
    95          PRINTF(0)("AXIS X\n");
    96          break;
    97 
    98 
    99        // collision in the y-axis
    100        case COLLISION_TYPE_AXIS_Y:
    101          // calulate the height above ground
    102          height = collPos.y - box->halfLength[1];
    103 
    104          PRINTF(0)("height: %f\n", height);
    105          PRINTF(0)("in wall %i\n", ce->isInWall());
    106 
    107          // object is beneath the plane (ground)
    108          if( height <= 0.0f )
    109          {
    110            entity->shiftCoor(Vector(0, -height, 0));
    111          }
    112          // object is already in the wall
    113          else if( ce->isInWall())
    114          {
    115            entity->setAbsCoor(entity->getLastAbsCoor());
    116          }
    117          break;
    118 
    119 
    120        // collision in the z-axis
    121        case COLLISION_TYPE_AXIS_Z:
    122          PRINTF(0)("AXIS Y\n");
    123          break;
    124      }
    125    }
     76  float front;
     77
     78
     79  const std::vector<CollisionEvent*>* collisionEvents = &(collision->getCollisionEvents());
     80  std::vector<CollisionEvent*>::const_iterator it = collisionEvents->begin();
     81  for(; it != collisionEvents->end(); it++)
     82  {
     83
     84    CollisionEvent* ce = (*it);
     85    Vector normal = ce->getGroundNormal();
     86
     87    // collision position maths
     88    Vector collPos =  collision->getEntityB()->getAbsCoor()  + box->center - ce->getCollisionPosition();
     89
     90
     91    // test the 3 axis differently
     92    switch( ce->getType())
     93    {
     94        // collision in the x-axis
     95      case COLLISION_TYPE_AXIS_X:
     96        front = collPos.x - box->halfLength[0];
     97
     98        PRINTF(0)("front: %f\n", front);
     99        PRINTF(0)("in wall %i\n", ce->isInWall());
     100
     101        // object is beneath the plane (ground)
     102        if( front <= 0.0f )
     103        {
     104//           entity->shiftCoor(Vector(front, 0.0f, 0.0f));
     105        }
     106        // object is already in the wall
     107        else if( ce->isInWall())
     108        {
     109//           entity->setAbsCoor(entity->getLastAbsCoor());
     110        }
     111        break;
     112
     113
     114        // collision in the y-axis
     115      case COLLISION_TYPE_AXIS_Y:
     116        // calulate the height above ground
     117        height = collPos.y - box->halfLength[1];
     118
     119
     120        // object is beneath the plane (ground)
     121        if( height <= 0.0f )
     122        {
     123          entity->shiftCoor(Vector(0.0f, -height, 0.0f));
     124        }
     125        // object is already in the wall
     126        else if( ce->isInWall())
     127        {
     128          entity->setAbsCoor(entity->getLastAbsCoor());
     129        }
     130        break;
     131
     132
     133        // collision in the z-axis
     134      case COLLISION_TYPE_AXIS_Z:
     135        break;
     136    }
     137  }
    126138
    127139
     
    212224 */
    213225void CRPhysicsGroundWalk::update(WorldEntity* owner)
    214 {
    215 }
    216 
    217 
     226{}
     227
     228
Note: See TracChangeset for help on using the changeset viewer.