Changeset 8922 in orxonox.OLD for branches/single_player_map/src
- Timestamp:
- Jun 29, 2006, 9:48:25 PM (19 years ago)
- Location:
- branches/single_player_map/src/lib
- Files:
-
- 2 edited
Legend:
- Unmodified
- Added
- Removed
-
branches/single_player_map/src/lib/collision_reaction/cr_physics_ground_walk.cc
r8915 r8922 63 63 // normal.normalize(); 64 64 65 // put it back66 // PRINTF(0)("putting it back to lastPos: \n");67 //this->lastPositions[0].debug();68 // PRINTF(0)("current pos:\n");69 collision->getEntityB()->getAbsCoor().debug();70 71 72 65 73 66 float height; … … 80 73 return; 81 74 } 82 83 75 76 84 77 // collision position maths 85 78 Vector collPos = collision->getEntityB()->getAbsCoor() + box->center - ce->getCollisionPosition(); … … 91 84 //PRINTF(0)("height: %f , model height: %f\n", height, box->halfLength[1]); 92 85 // PRINTF(0)(" ground normal: %f, %f, %f\n", normal.x, normal.y, normal.z); 93 // 86 // 94 87 95 88 switch( ce->getType()) 96 89 { 97 90 98 91 case COLLISION_TYPE_AXIS_X: 99 // PRINTF(0)("height: %f , model height: %f\n", height, box->halfLength[1]); 100 // PRINTF(0)(" ground normal: %f, %f, %f\n", normal.x, normal.y, normal.z); 101 // PRINTF(0)("COLLISION_TYPE_AXIS_X \n"); 102 break; 103 case COLLISION_TYPE_AXIS_Y: 92 93 break; 94 95 case COLLISION_TYPE_AXIS_Y: 104 96 105 97 height = collPos.y - box->halfLength[1]; 106 // PRINTF(0)("height: %f , model height: %f\n", height, box->halfLength[1]); 107 // PRINTF(0)(" ground normal: %f, %f, %f\n", normal.x, normal.y, normal.z); 108 // PRINTF(0)("COLLISION_TYPE_AXIS_Y \n"); 109 // // object is beneath the plane (ground) 110 // if( height <= 0.0f ) 111 // { 112 // entity->shiftCoor(Vector(0, -height, 0)); 113 // } 114 // // object is already in the wall 115 // else if( ce->isInWall()) 116 // { 117 // entity->setAbsCoor(entity->getLastAbsCoor()); 118 // } 119 // break; 120 break; 121 122 98 99 PRINTF(0)("height: %f\n", height); 100 PRINTF(0)("in wall %i\n", ce->isInWall()); 101 102 // object is beneath the plane (ground) 103 if( height <= 0.0f ) 104 { 105 entity->shiftCoor(Vector(0, -height, 0)); 106 } 107 // object is already in the wall 108 else if( ce->isInWall()) 109 { 110 entity->setAbsCoor(entity->getLastAbsCoor()); 111 } 112 break; 113 break; 114 115 123 116 case COLLISION_TYPE_AXIS_Z: 124 // PRINTF(0)("height: %f , model height: %f\n", height, box->halfLength[1]); 125 // PRINTF(0)(" ground normal: %f, %f, %f\n", normal.x, normal.y, normal.z); 126 // PRINTF(0)("COLLISION_TYPE_AXIS_Z \n"); 127 break; 128 129 } 117 118 break; 119 120 } 130 121 131 122 … … 143 134 144 135 145 if( box != NULL) { 146 147 148 if(ce->getCollisionPosition().x <= 0.9 && ce->getGroundNormal().len() <= 1.4f) { 136 if( box != NULL) 137 { 138 139 140 if(ce->getCollisionPosition().x <= 0.9 && ce->getGroundNormal().len() <= 1.4f) 141 { 149 142 collision->getEntityB()->setAbsCoor(collision->getEntityB()->getLastAbsCoor()); 150 143 return; 151 144 } 152 if(ce->getCollisionPosition().z <= 0.9 && ce->getGroundNormal().len() <= 1.4f) { 145 if(ce->getCollisionPosition().z <= 0.9 && ce->getGroundNormal().len() <= 1.4f) 146 { 153 147 collision->getEntityB()->setAbsCoor(collision->getEntityB()->getLastAbsCoor()); 154 148 return; 155 149 } 156 150 157 if(ce->getGroundNormal().len() <= 0.1f) { 151 if(ce->getGroundNormal().len() <= 0.1f) 152 { 158 153 collision->getEntityB()->setAbsCoor(collision->getEntityB()->getLastAbsCoor()); 159 154 return; … … 161 156 162 157 163 if(ce->getGroundNormal().len() >= 1.4f) { 158 if(ce->getGroundNormal().len() >= 1.4f) 159 { 164 160 downspeed++; 165 161 collision->getEntityB()->setAbsCoor(collision->getEntityB()->getAbsCoor() + Vector(0.0,-0.08*downspeed,0.0)); … … 181 177 182 178 } 183 else { 179 else 180 { 184 181 if(height.y < box->halfLength[1] + 0.0f /* && height.y > - 55.0f*/) // below ground 185 182 { … … 212 209 void CRPhysicsGroundWalk::update(WorldEntity* owner) 213 210 { 214 215 211 } 216 212 -
branches/single_player_map/src/lib/graphics/importer/bsp_manager.cc
r8912 r8922 1 1 /* 2 2 orxonox - the future of 3D-vertical-scrollers 3 3 4 4 Copyright (C) 2006 orx 5 5 6 6 This program is free software; you can redistribute it and/or modify 7 7 it under the terms of the GNU General Public License as published by 8 8 the Free Software Foundation; either version 2, or (at your option) 9 9 any later version. 10 10 11 11 ### File Specific: 12 12 main-programmer: bottac@ee.ethz.ch 13 13 14 14 Inspired by: 15 15 Rendering Q3 Maps by Morgan McGuire http://graphics.cs.brown.edu/games/quake/quake3.html 16 16 Unofficial Quake 3 Map Specs by Kekoa Proudfoot http://graphics.stanford.edu/~kekoa/q3/ 17 17 18 18 Collision detection adapted from: 19 19 Quake 3 Collision Detection by Nathan Ostgard http://www.devmaster.net/articles/quake3collision/ … … 69 69 BspManager::BspManager(const TiXmlElement* root) 70 70 { 71 72 71 72 73 73 if( root != NULL) 74 74 this->loadParams(root); 75 75 76 76 CDEngine::getInstance()->setBSPModel(this); 77 77 } */ … … 111 111 this->root = this->bspFile->get_root(); 112 112 this->alreadyVisible = new bool [this->bspFile->numFaces]; 113 113 114 114 CDEngine::getInstance()->setBSPModel(this); 115 115 } … … 986 986 987 987 if( box != NULL) { 988 position = worldEntity->getAbsCoor() + box->center ; //+ box->axis[1] * box->halfLength[1];988 position = worldEntity->getAbsCoor() + box->center + box->axis[1] * box->halfLength[1]; 989 989 dest = worldEntity->getAbsCoor() + box->center - box->axis[1] * box->halfLength[1] * 40.0; 990 990 … … 998 998 } else { 999 999 // Init positions and destinations to anything useful! 1000 1000 1001 1001 } 1002 1002 … … 1049 1049 bool xCollision = false; 1050 1050 bool zCollision = false; 1051 1051 1052 1052 1053 1053 // 2nd Collision Detection … … 1070 1070 //out.z = this->outputFraction; 1071 1071 1072 1072 1073 1073 1074 1074 // 3rd Collision Detection … … 1078 1078 this->inputStart = position2; 1079 1079 this->inputEnd = dest2; 1080 1080 1081 1081 this->checkCollisionRayN(this->root,0.0f,1.0f, &position2, &dest2 ); 1082 1082 //out.x = this->outputFraction; … … 1092 1092 zCollision = true; 1093 1093 } 1094 1094 1095 1095 //end if 1096 1096 /* … … 1102 1102 1103 1103 // Return the normal here: Normal's stored in this->collPlane; 1104 /* if( collision) { 1105 PRINTF(5)("We got a collision!! Are you sure: outputFraction = %f\n", this->outputFraction); 1104 if( collision) { 1106 1105 worldEntity->registerCollision(COLLISION_TYPE_AXIS_Y , this->parent, worldEntity, Vector(testPlane->x, testPlane->y, testPlane->z), out, SolidFlag); 1107 } */1106 } 1108 1107 if(xCollision) { 1109 1108 worldEntity->registerCollision(COLLISION_TYPE_AXIS_X , this->parent, worldEntity, Vector(testPlane->x, testPlane->y, testPlane->z), out, SolidFlag);
Note: See TracChangeset
for help on using the changeset viewer.