Changeset 10023 for code/branches/modularships/src/orxonox/worldentities
- Timestamp:
- Apr 9, 2014, 9:50:45 PM (11 years ago)
- Location:
- code/branches/modularships/src/orxonox/worldentities/pawns
- Files:
-
- 4 edited
Legend:
- Unmodified
- Added
- Removed
-
code/branches/modularships/src/orxonox/worldentities/pawns/ModularSpaceShip.cc
r10019 r10023 88 88 if((this->partList_[j]->getName() == this->getAttachedObject(i)->getName()) && !this->partList_[j]->hasEntity(orxonox_cast<StaticEntity*>(this->getAttachedObject(i)))) 89 89 { 90 // The Entity is added to the part's entityList_ 90 91 this->partList_[j]->addEntity(orxonox_cast<StaticEntity*>(this->getAttachedObject(i))); 92 // An entry in the partMap_ is created, assigning the part to the entity. 93 this->addPartEntityAssignment((StaticEntity*)(this->getAttachedObject(i)), this->partList_[j]); 91 94 orxout() << "A matching part-entity-pair with name " << this->partList_[j]->getName() << " was found!" << endl; 92 95 this->partList_[j]->printEntities(); // FIXME: (noep) remove debug … … 94 97 } 95 98 } 99 100 orxout() << "List of all assignments:" << endl; 101 for (std::map<StaticEntity*, ShipPart*>::const_iterator it = this->partMap_.begin(); it != this->partMap_.end(); ++it) 102 { 103 orxout() << "Entity: " << it->first << " Part: " << it->second << endl; 104 } 96 105 } 97 106 … … 143 152 orxout() << "UserPtr of said collisionShape: " << cs->getUserPointer() << endl; 144 153 145 // List all attached Objects 154 155 // Print all attached objects & parts 156 /* 146 157 orxout() << " " << this->getName() << " has the following Objects attached:" << endl; 147 for (int i=0; i<10; i++) 158 159 for (int i=0; i<50; i++) 148 160 { 149 161 if (this->getAttachedObject(i)==NULL) … … 157 169 { 158 170 orxout() << " " << i << ": " << this->partList_[i] << " (" << this->partList_[i]->getName() << ")" << endl; 159 } 171 }*/ 172 160 173 161 174 //int collisionShapeIndex = this->isMyCollisionShape(cs); 162 175 //orxout() << collisionShapeIndex << endl; 163 176 164 orxout() << "ShipPart of Entity " << cs->getUserPointer() << ": " << this->getPartOfEntity((StaticEntity*)(cs->getUserPointer())) << endl; 177 //orxout() << "ShipPart of Entity " << cs->getUserPointer() << ": " << this->getPartOfEntity((StaticEntity*)(cs->getUserPointer())) << endl; 178 179 orxout() << "CP_start" << endl; 165 180 166 181 if (this->getPartOfEntity((StaticEntity*)(cs->getUserPointer())) != NULL) 167 182 this->getPartOfEntity((StaticEntity*)(cs->getUserPointer()))->handleHit(damage, healthdamage, shielddamage, originator); 168 //else 169 // SpaceShip::damage(damage, healthdamage, shielddamage, originator, cs); 183 else 184 SpaceShip::damage(damage, healthdamage, shielddamage, originator, cs); 185 186 orxout() << "CP_end" << endl; 170 187 171 188 /* … … 208 225 OrxAssert(part != NULL, "The ShipPart cannot be NULL."); 209 226 this->partList_.push_back(part); 227 part->setParent(this); 210 228 //part->addToSpaceShip(this); //FIXME: (noep) add 211 229 this->updatePartAssignment(); … … 242 260 } 243 261 262 void ModularSpaceShip::removeShipPart(ShipPart* part) 263 { 264 // Remove the part from the partList_ 265 std::vector<ShipPart*>::iterator it = this->partList_.begin(); 266 for(unsigned int i = 0; i < this->partList_.size(); i++) 267 { 268 if(this->partList_[i] == part) 269 this->partList_.erase(it); 270 it++; 271 } 272 // Remove the part-entity assignment and detach the Entity of this ShipPart 273 for (std::map<StaticEntity*, ShipPart*>::iterator itt = this->partMap_.begin(); itt != this->partMap_.end(); ++itt) 274 { 275 if (itt->second == part) 276 { 277 this->detach(itt->first); 278 this->partMap_.erase(itt); 279 } 280 } 281 } 282 244 283 } -
code/branches/modularships/src/orxonox/worldentities/pawns/ModularSpaceShip.h
r10019 r10023 48 48 /** 49 49 @brief 50 The ModularSpaceShip is the principal entity through which the player interacts with the game. Its main function is to fly, however many things, such as @ref orxonox::Engine Engines or @ref orxonox::Weapon Weapons, can be attached to it. 50 The SpaceShip is the principal entity through which the player interacts with the game. Its main function is to fly, however many things, such as @ref orxonox::Engine Engines or @ref orxonox::Weapon Weapons, can be attached to it. 51 The ModularSpaceShip is an extension of a @ref orxonox::SpaceShip SpaceShip, which uses @ref orxonox::ShipPart ShipParts to allow entities attached to it to be destroyed individually. 51 52 52 53 There are several parameters that define the behavior of the ModularSpaceShip> … … 56 57 - The <b>lift</b> creates a more natural flight feeling through the addition of a lift force. There are again tow parameters that can be specified. The <b>lift</b> which is the lift force that is applied. And the <b>stallSpeed</b> which is the forward speed after which no more lift is generated. 57 58 58 As mentioned @ref orxonox::Engine Engines can be mounted on the ModularSpaceShip. Here is a (primitive) example of a ModularSpaceShip defined in XML: 59 As mentioned @ref orxonox::Engine Engines can be mounted on the ModularSpaceShip. 60 In order to assign attached entities to a ShipPart, a ShipPart with the same name as the corresponding entity needs to be created in the <parts> tag. 61 Here is a (primitive) example of a ModularSpaceShip defined in XML: 59 62 @code 60 63 <ModularSpaceShip … … 77 80 angularDamping = 0.9999999 78 81 > 82 <attached> 83 <StaticEntity name="wing" . . . /> 84 <StaticEntity name="tail" . . . /> 85 </attached> 86 <parts> 87 <ShipPart name="wing" . . . /> 88 <ShipPart name="tail" . . . /> 89 </parts> 79 90 <engines> 80 91 <Engine /> … … 85 96 86 97 @author 87 Fabian 'x3n' Landau 98 Fabian 'x3n' Landau, Noe Pedrazzini 88 99 */ 89 100 class _OrxonoxExport ModularSpaceShip : public SpaceShip … … 105 116 ShipPart* getShipPart(unsigned int index); 106 117 bool hasShipPart(ShipPart* part) const; 118 void removeShipPart(ShipPart* part); 107 119 108 120 virtual void updatePartAssignment(); -
code/branches/modularships/src/orxonox/worldentities/pawns/Pawn.cc
r10011 r10023 252 252 void Pawn::damage(float damage, float healthdamage, float shielddamage, Pawn* originator, const btCollisionShape* cs) 253 253 { 254 orxout() << "damage(): Collision detected on " << this->getName() << ", btCS*: " << cs << endl; 255 256 int collisionShapeIndex = this->isMyCollisionShape(cs); 257 orxout() << collisionShapeIndex << endl; 254 //FIXME: (noep) remove debug 255 //orxout() << "damage(): Collision detected on " << this->getName() << ", btCS*: " << cs << endl; 256 257 //int collisionShapeIndex = this->isMyCollisionShape(cs); 258 //orxout() << collisionShapeIndex << endl; 258 259 259 260 // Applies multiplier given by the DamageBoost Pickup. … … 587 588 // List all attached Objects 588 589 orxout() << " " << this->getName() << " has the following Objects attached:" << endl; 589 for (int i=0; i< 10; i++)590 for (int i=0; i<50; i++) 590 591 { 591 592 if (this->getAttachedObject(i)==NULL) -
code/branches/modularships/src/orxonox/worldentities/pawns/Pawn.h
r10019 r10023 229 229 unsigned int numexplosionchunks_; 230 230 231 virtual int isMyCollisionShape(const btCollisionShape* cs); 231 virtual int isMyCollisionShape(const btCollisionShape* cs); // FIXME: (noep) remove debug 232 232 void printBtChildShapes(btCompoundShape* cs, int indent, int subshape); // FIXME: (noep) remove debug 233 233 void printSpaces(int num); // FIXME: (noep) remove debug
Note: See TracChangeset
for help on using the changeset viewer.