Changeset 2303
- Timestamp:
- Dec 1, 2008, 11:09:43 PM (16 years ago)
- Location:
- code/branches/physics
- Files:
-
- 7 added
- 11 edited
Legend:
- Unmodified
- Added
- Removed
-
code/branches/physics/src/core/XMLPort.h
r2291 r2303 196 196 @param xmlelement The XMLElement (recieved through the XMLPort function) 197 197 @param mode The mode (load/save) (received through the XMLPort function) 198 @param bApplyLoaderMask If this is true, an added sub-object only gets loadedif it's class is included in the Loaders ClassTreeMask (this is usually false)199 @param bLoadBefore If this is true, the sub- cobject gets loaded (through XMLPort) BEFORE it gets added to the main class (this is usually true)198 @param bApplyLoaderMask If this is true, an added sub-object gets loaded only if it's class is included in the Loaders ClassTreeMask (this is usually false) 199 @param bLoadBefore If this is true, the sub-object gets loaded (through XMLPort) BEFORE it gets added to the main class (this is usually true) 200 200 201 201 bApplyLoaderMask is usually false for the following reason: … … 204 204 Of course, if there are "standalone" weapons in the level, they wont be loaded. 205 205 206 If bLoadBefore , an added object already has all attributes set (like it's name). This is most206 If bLoadBefore is true, an added object already has all attributes set (like it's name). This is most 207 207 likely the best option, so this is usually true. 208 208 … … 243 243 Note that "weapons" is the subsection. This allows you to add more types of sub-objects. In our example, 244 244 you could add pilots, blinking lights or other stuff. If you don't want a subsection, just use "" (an 245 empty string). The you can add sub-objects directly into the mainclass.245 empty string). Then you can add sub-objects directly into the mainclass. 246 246 */ 247 247 #define XMLPortObjectExtended(classname, objectclass, sectionname, loadfunction, savefunction, xmlelement, mode, bApplyLoaderMask, bLoadBefore) \ -
code/branches/physics/src/orxonox/CMakeLists.txt
r2300 r2303 71 71 # objects/worldentities/Backlight.cc 72 72 73 objects/worldentities/collisionshapes/CollisionShape.cc 74 objects/worldentities/collisionshapes/CompoundCollisionShape.cc 75 objects/worldentities/collisionshapes/SphereCollisionShape.cc 76 73 77 objects/quest/AddQuest.cc 74 78 objects/quest/AddQuestHint.cc -
code/branches/physics/src/orxonox/OrxonoxPrereqs.h
r2300 r2303 151 151 class Scores; 152 152 153 // collision 154 class CollisionShape; 155 class SphereCollisionShape; 156 153 157 // tools 154 158 class BillboardSet; … … 209 213 class btCollisionObject; 210 214 class btGhostObject; 215 211 216 class btCollisionShape; 212 217 class btSphereShape; 213 214 218 class btCompoundShape; 219 220 class btDiscreteDynamicsWorld; 221 222 // lua 215 223 struct lua_State; 216 224 -
code/branches/physics/src/orxonox/objects/Scene.cc
r2298 r2303 35 35 #include <OgreLight.h> 36 36 37 #include "BulletCollision/BroadphaseCollision/btAxisSweep3.h" 38 #include "BulletCollision/CollisionDispatch/btDefaultCollisionConfiguration.h" 39 #include "BulletDynamics/ConstraintSolver/btSequentialImpulseConstraintSolver.h" 40 #include "BulletDynamics/Dynamics/btDiscreteDynamicsWorld.h" 41 37 42 #include "core/CoreIncludes.h" 38 43 #include "core/Core.h" 39 44 #include "core/XMLPort.h" 40 41 #include "BulletCollision/BroadphaseCollision/btAxisSweep3.h" 42 #include "BulletDynamics/ConstraintSolver/btSequentialImpulseConstraintSolver.h" 43 #include "BulletCollision/CollisionDispatch/btDefaultCollisionConfiguration.h" 45 #include "objects/worldentities/WorldEntity.h" 44 46 45 47 namespace orxonox … … 123 125 124 126 XMLPortObjectExtended(Scene, BaseObject, "", addObject, getObject, xmlelement, mode, true, false); 127 128 // finally add all rigid bodies to the physics engine 129 if (hasPhysics()) 130 { 131 for (std::list<BaseObject*>::const_iterator it = this->objects_.begin(); it != this->objects_.end(); ++it) 132 { 133 WorldEntity* temp = dynamic_cast<WorldEntity*>(*it); 134 if (temp) 135 { 136 if (temp->getCollisionType() != WorldEntity::None) 137 this->physicalWorld_->addRigidBody(temp->getPhysicalBody()); 138 } 139 } 140 } 125 141 } 126 142 … … 157 173 { 158 174 if (physicalWorld_) 159 physicalWorld_->stepSimulation(dt, 10);175 physicalWorld_->stepSimulation(dt,(int)(dt/0.0166666f)); 160 176 } 161 177 -
code/branches/physics/src/orxonox/objects/Scene.h
r2292 r2303 37 37 #include "objects/Tickable.h" 38 38 39 #include "BulletDynamics/Dynamics/btDiscreteDynamicsWorld.h"40 41 39 namespace orxonox 42 40 { … … 70 68 { return this->bShadows_; } 71 69 72 inline const Vector3& getWorldAabbMax()73 {74 this->physicalWorld_->getBroadphase();75 }70 //inline const Vector3& getWorldAabbMax() 71 //{ 72 // this->physicalWorld_->getBroadphase(); 73 //} 76 74 77 75 inline bool hasPhysics() -
code/branches/physics/src/orxonox/objects/worldentities/MovableEntity.cc
r2300 r2303 30 30 #include "MovableEntity.h" 31 31 32 #include "BulletDynamics/Dynamics/btRigidBody.h" 33 32 34 #include "util/Exception.h" 33 35 #include "core/CoreIncludes.h" … … 61 63 { 62 64 } 63 64 //void MovableEntity::setPosition(const Vector3& position)65 //{66 // //if (isDynamic() && bAddedToPhysicalWorld_)67 // //{68 // // this->getScene()->getPhysicalWorld()->removeRigidBody(this->physicalBody_);69 // // this->getScene()->getPhysicalWorld()->addRigidBody(this->physicalBody_);70 // //}71 // this->node_->setPosition(position);72 // positionChanged();73 //}74 75 //void MovableEntity::translate(const Vector3& distance, Ogre::Node::TransformSpace relativeTo)76 //{77 // //if (isDynamic() && bAddedToPhysicalWorld_)78 // //{79 // // this->getScene()->getPhysicalWorld()->removeRigidBody(this->physicalBody_);80 // // this->getScene()->getPhysicalWorld()->addRigidBody(this->physicalBody_);81 // //}82 // this->node_->translate(distance, relativeTo);83 // positionChanged();84 //}85 86 //void MovableEntity::setOrientation(const Quaternion& orientation)87 //{88 // //if (isDynamic() && bAddedToPhysicalWorld_)89 // //{90 // // this->getScene()->getPhysicalWorld()->removeRigidBody(this->physicalBody_);91 // // this->getScene()->getPhysicalWorld()->addRigidBody(this->physicalBody_);92 // //}93 // this->node_->setOrientation(orientation);94 // orientationChanged();95 //}96 97 //void MovableEntity::rotate(const Quaternion& rotation, Ogre::Node::TransformSpace relativeTo)98 //{99 // //if (isDynamic() && bAddedToPhysicalWorld_)100 // //{101 // // this->getScene()->getPhysicalWorld()->removeRigidBody(this->physicalBody_);102 // // this->getScene()->getPhysicalWorld()->addRigidBody(this->physicalBody_);103 // //}104 // this->node_->rotate(rotation, relativeTo);105 // orientationChanged();106 //}107 108 //void MovableEntity::yaw(const Degree& angle, Ogre::Node::TransformSpace relativeTo)109 //{110 // //if (isDynamic() && bAddedToPhysicalWorld_)111 // //{112 // // this->getScene()->getPhysicalWorld()->removeRigidBody(this->physicalBody_);113 // // this->getScene()->getPhysicalWorld()->addRigidBody(this->physicalBody_);114 // //}115 // this->node_->yaw(angle, relativeTo);116 // orientationChanged();117 //}118 119 //void MovableEntity::pitch(const Degree& angle, Ogre::Node::TransformSpace relativeTo)120 //{121 // //if (isDynamic() && bAddedToPhysicalWorld_)122 // //{123 // // this->getScene()->getPhysicalWorld()->removeRigidBody(this->physicalBody_);124 // // this->getScene()->getPhysicalWorld()->addRigidBody(this->physicalBody_);125 // //}126 // this->node_->pitch(angle, relativeTo);127 // orientationChanged();128 //}129 130 //void MovableEntity::roll(const Degree& angle, Ogre::Node::TransformSpace relativeTo)131 //{132 // //if (isDynamic() && bAddedToPhysicalWorld_)133 // //{134 // // this->getScene()->getPhysicalWorld()->removeRigidBody(this->physicalBody_);135 // // this->getScene()->getPhysicalWorld()->addRigidBody(this->physicalBody_);136 // //}137 // this->node_->roll(angle, relativeTo);138 // orientationChanged();139 //}140 141 //void MovableEntity::lookAt(const Vector3& target, Ogre::Node::TransformSpace relativeTo, const Vector3& localDirectionVector)142 //{143 // //if (isDynamic() && bAddedToPhysicalWorld_)144 // //{145 // // this->getScene()->getPhysicalWorld()->removeRigidBody(this->physicalBody_);146 // // this->getScene()->getPhysicalWorld()->addRigidBody(this->physicalBody_);147 // //}148 // this->node_->lookAt(target, relativeTo, localDirectionVector);149 // orientationChanged();150 //}151 152 //void MovableEntity::setDirection(const Vector3& direction, Ogre::Node::TransformSpace relativeTo, const Vector3& localDirectionVector)153 //{154 // //if (isDynamic() && bAddedToPhysicalWorld_)155 // //{156 // // this->getScene()->getPhysicalWorld()->removeRigidBody(this->physicalBody_);157 // // this->getScene()->getPhysicalWorld()->addRigidBody(this->physicalBody_);158 // //}159 // this->node_->setDirection(direction, relativeTo, localDirectionVector);160 // orientationChanged();161 //}162 65 163 66 void MovableEntity::setPosition(const Vector3& position) -
code/branches/physics/src/orxonox/objects/worldentities/StaticEntity.cc
r2300 r2303 62 62 bool StaticEntity::isCollisionTypeLegal(WorldEntity::CollisionType type) const 63 63 { 64 if (type == WorldEntity:: Static)64 if (type == WorldEntity::Kinematic || type == WorldEntity::Dynamic) 65 65 { 66 ThrowException(PhysicsViolation, "Cannot tell a MovableEntity to have static collision type");66 ThrowException(PhysicsViolation, "Cannot tell a StaticEntity to have kinematic or dynamic collision type"); 67 67 return false; 68 68 } -
code/branches/physics/src/orxonox/objects/worldentities/WorldEntity.cc
r2300 r2303 33 33 #include <OgreSceneManager.h> 34 34 35 #include "BulletCollision/CollisionShapes/btSphereShape.h" 35 #include "BulletCollision/CollisionShapes/btCollisionShape.h" 36 #include "BulletDynamics/Dynamics/btDiscreteDynamicsWorld.h" 37 #include "BulletDynamics/Dynamics/btRigidBody.h" 36 38 37 39 #include "util/Exception.h" … … 41 43 42 44 #include "objects/Scene.h" 45 #include "objects/worldentities/collisionshapes/CollisionShape.h" 46 #include "objects/worldentities/collisionshapes/CompoundCollisionShape.h" 43 47 44 48 namespace orxonox … … 68 72 // Default behaviour does not include physics 69 73 this->physicalBody_ = 0; 74 this->collisionShape_ = 0; 75 this->mass_ = 0; 70 76 updateCollisionType(); 71 77 … … 100 106 101 107 XMLPortParam(WorldEntity, "collisionType", setCollisionTypeStr, getCollisionTypeStr, xmlelement, mode); 102 XMLPortParam(WorldEntity, "collisionRadius", setCollisionRadius, getCollisionRadius, xmlelement, mode);108 //XMLPortParam(WorldEntity, "collisionRadius", setCollisionRadius, getCollisionRadius, xmlelement, mode); 103 109 XMLPortParam(WorldEntity, "mass", setMass, getMass, xmlelement, mode); 104 110 105 111 XMLPortObject(WorldEntity, WorldEntity, "attached", attach, getAttachedObject, xmlelement, mode); 106 107 // Add the physical after loading because we cannot change its attributes without removing. 108 if (getCollisionType() != None) 109 this->getScene()->getPhysicalWorld()->addRigidBody(this->physicalBody_); 112 XMLPortObject(WorldEntity, CollisionShape, "collisionShapes", attachCollisionShape, getAttachedCollisionShape, xmlelement, mode); 110 113 } 111 114 … … 131 134 void WorldEntity::attach(WorldEntity* object) 132 135 { 136 // check first whether attaching is even allowed 137 if (object->hasPhysics()) 138 { 139 if (!this->hasPhysics()) 140 ThrowException(PhysicsViolation, "Cannot attach a physical object to a non physical one."); 141 else if (object->isDynamic()) 142 ThrowException(PhysicsViolation, "Cannot attach a dynamic object to a WorldEntity."); 143 else if (object->isKinematic() && this->isDynamic()) 144 ThrowException(PhysicsViolation, "Cannot attach a kinematic object to a dynamic one."); 145 else if (object->isKinematic()) 146 ThrowException(NotImplemented, "Cannot attach a kinematic object to a static or kinematic one: Not yet implemented."); 147 else if (object->physicalBody_->isInWorld() || this->physicalBody_->isInWorld()) 148 ThrowException(PhysicsViolation, "Cannot attach a physical object at runtime."); 149 else 150 { 151 // static to static/kinematic/dynamic --> merge shapes 152 this->attachCollisionShape(object->getCollisionShape()); 153 // Remove the btRigidBody from the child object. 154 // That also implies that cannot add a physics WE to the child afterwards. 155 object->setCollisionType(None); 156 } 157 } 158 133 159 if (object->getParent()) 134 160 object->detachFromParent(); … … 144 170 object->parent_ = this; 145 171 object->parentID_ = this->getObjectID(); 146 147 // Do the physical connection if required 148 //this->attachPhysicalObject(object); 149 } 150 151 //void WorldEntity::attachPhysicalObject(WorldEntity* object) 152 //{ 153 // StaticEntity* staticObject = dynamic_cast<StaticEntity*>(object); 154 // if (staticObject != 0 && this->hasPhysics()) 155 // { 156 // btCompoundShape* compoundShape = dynamic_cast<btCompoundShape*>(this->physicalBody_->getCollisionShape()); 157 // if (compoundShape == 0) 158 // { 159 // // create a compound shape and add both 160 // compoundShape = new btCompoundShape(); 161 // compoundShape->addChildShape(this->physicalBody_->getCollisionShape()); 162 // compoundShape->addChildShape(staticObject->getCollisionShape()); 163 // this->physicalBody_->setCollisionShape(); 164 // } 165 // else 166 // { 167 // compoundShape -> addChildShape(staticObject->getCollisionShape()); 168 // } 169 // } 170 //} 172 } 171 173 172 174 void WorldEntity::detach(WorldEntity* object) … … 192 194 } 193 195 194 float WorldEntity::getMass() const 195 { 196 if (!checkPhysics()) 197 return 0.0f; 198 199 if (this->physicalBody_->getInvMass() == 0.0f) 200 return 0.0f; 201 else 202 return 1.0f/this->physicalBody_->getInvMass(); 196 void WorldEntity::mergeCollisionShape(CollisionShape* shape) 197 { 198 if (!this->collisionShape_) 199 this->collisionShape_ = new CompoundCollisionShape(this); 200 assert(this->collisionShape_->isCompoundShape()); 201 202 // merge with transform 203 CompoundCollisionShape* compoundShape = static_cast<CompoundCollisionShape*>(this->collisionShape_); 204 assert(compoundShape); 205 compoundShape->addChildShape(shape); 206 } 207 208 void WorldEntity::attachCollisionShape(CollisionShape* shape) 209 { 210 this->attachedShapes_.push_back(shape); 211 212 if (!this->collisionShape_ && shape->hasNoTransform()) 213 { 214 // Simply add the shape as is. 215 shape->getCollisionShape()->setLocalScaling(shape->getTotalScaling()); 216 this->collisionShape_ = shape; 217 } 218 else 219 { 220 if (this->collisionShape_ && !this->collisionShape_->isCompoundShape()) 221 { 222 // We have to create a new compound shape and add the old one first. 223 CollisionShape* thisShape = this->collisionShape_; 224 this->collisionShape_ = 0; 225 this->mergeCollisionShape(thisShape); 226 } 227 this->mergeCollisionShape(shape); 228 } 229 230 if (this->physicalBody_) 231 { 232 if (this->physicalBody_->isInWorld()) 233 COUT(2) << "Warning: Cannot attach a physical object at runtime."; 234 else 235 this->physicalBody_->setCollisionShape(this->collisionShape_->getCollisionShape()); 236 } 237 } 238 239 CollisionShape* WorldEntity::getAttachedCollisionShape(unsigned int index) const 240 { 241 if (index < this->attachedShapes_.size()) 242 return attachedShapes_[index]; 243 else 244 return 0; 245 } 246 247 //BlinkingBillboard* WorldEntity::getAttachedAsdfObject(unsigned int index) const 248 //{ 249 // return 0; 250 //} 251 252 void WorldEntity::setScale3D(const Vector3& scale) 253 { 254 if (this->hasPhysics()) 255 ThrowException(NotImplemented, "Cannot set the scale of a physical object: Not yet implemented."); 256 257 this->node_->setScale(scale); 258 } 259 260 void WorldEntity::scale3D(const Vector3& scale) 261 { 262 if (this->hasPhysics()) 263 ThrowException(NotImplemented, "Cannot set the scale of a physical object: Not yet implemented."); 264 265 this->node_->scale(scale); 203 266 } 204 267 205 268 void WorldEntity::setMass(float mass) 206 269 { 207 if (!checkPhysics()) 208 return; 270 this->mass_ = mass; 271 if (!hasPhysics()) 272 COUT(2) << "Warning: Setting the mass of a WorldEntity with no physics has no effect." << std::endl; 209 273 else if (this->physicalBody_->isInWorld()) 210 { 211 CCOUT(2) << "Cannot set the physical mass at run time." << std::endl; 212 assert(false); 213 } 214 else 215 { 216 this->physicalBody_->setMassProps(mass, btVector3(0,0,0)); 217 updateCollisionType(); 274 COUT(2) << "Warning: Cannot set the physical mass at run time. Storing temporarily." << std::endl; 275 else 276 { 277 if (this->collisionType_ != Dynamic) 278 COUT(2) << "Warning: Cannot set the physical mass of a static or kinematic object. Storing temporarily." << std::endl; 279 else if (mass == 0.0f) 280 COUT(2) << "Warning: Cannot set physical mass of a dynamic object to zero. Storing temporarily." << std::endl; 281 else 282 this->physicalBody_->setMassProps(mass, btVector3(0,0,0)); 218 283 } 219 284 } … … 221 286 void WorldEntity::setCollisionType(CollisionType type) 222 287 { 223 // Check first whether we have to create or destroy. 288 // If we are already attached to a parent, this would be a bad idea.. 289 if (this->parent_) 290 ThrowException(PhysicsViolation, "Cannot set the collision type of a WorldEntity with a parent"); 291 else if (this->physicalBody_ && this->physicalBody_->isInWorld()) 292 ThrowException(PhysicsViolation, "Warning: Cannot set the collision type at run time."); 293 294 // Check for type legality. Could be StaticEntity or MovableEntity 295 if (!this->isCollisionTypeLegal(type)) 296 return; // exception gets issued anyway 297 298 // Check whether we have to create or destroy. 224 299 if (type != None && this->collisionType_ == None) 225 300 { 226 // First, check whether our SceneNode is relative to the root space of the scene.227 // TODO: Static and Kinematic objects don't always have to obey this rule.228 if (this->node_->getParent() != this->getScene()->getRootSceneNode())229 ThrowException(PhysicsViolation, "Cannot make WorldEntity physical that is not in the root space of the Scene.");230 231 301 // Create new rigid body 232 btRigidBody::btRigidBodyConstructionInfo bodyConstructionInfo(0, this, 0, btVector3(0,0,0)); 302 btCollisionShape* temp = 0; 303 if (this->collisionShape_) 304 temp = this->collisionShape_->getCollisionShape(); 305 btRigidBody::btRigidBodyConstructionInfo bodyConstructionInfo(0, this, temp, btVector3(0,0,0)); 233 306 this->physicalBody_ = new btRigidBody(bodyConstructionInfo); 234 307 this->physicalBody_->setUserPointer(this); 235 236 // Adjust parameters according to the node237 //btTransform nodeTransform;238 //this->239 308 } 240 309 else if (type == None && this->collisionType_ != None) … … 243 312 if (this->physicalBody_->isInWorld()) 244 313 this->getScene()->getPhysicalWorld()->removeRigidBody(this->physicalBody_); 245 if (this->physicalBody_->getCollisionShape())246 delete this->physicalBody_->getCollisionShape();247 314 delete this->physicalBody_; 248 315 this->physicalBody_ = 0; … … 250 317 return; 251 318 } 252 253 // Check for type legality. Could be StaticEntity or MovableEntity254 if (!this->isCollisionTypeLegal(type))255 return; // exception gets issued anyway256 319 257 320 // Change type … … 271 334 } 272 335 336 // update our variable for faster checks 337 updateCollisionType(); 338 273 339 // Mass non zero is a bad idea for kinematic and static objects 274 if ((type == Kinematic || type == Static) && getMass()!= 0.0f)340 if ((type == Kinematic || type == Static) && this->mass_ != 0.0f) 275 341 this->setMass(0.0f); 276 342 // Mass zero is not such a good idea for dynamic objects 277 else if (type == Dynamic && getMass()== 0.0f)343 else if (type == Dynamic && this->mass_ == 0.0f) 278 344 this->setMass(1.0f); 279 280 // finally update our variable for faster checks 281 updateCollisionType(); 345 else if (hasPhysics()) 346 this->physicalBody_->setMassProps(this->mass_, btVector3(0,0,0)); 282 347 } 283 348 … … 329 394 } 330 395 331 void WorldEntity::setCollisionRadius(float radius) 332 { 333 if (!checkPhysics()) 334 return; 335 336 // destroy old one first 337 btCollisionShape* oldShape = this->physicalBody_->getCollisionShape(); 338 if (oldShape) 339 delete oldShape; 340 341 this->physicalBody_->setCollisionShape(new btSphereShape(btScalar(radius))); 342 } 343 344 float WorldEntity::getCollisionRadius() const 345 { 346 if (checkPhysics()) 347 { 348 btSphereShape* sphere = dynamic_cast<btSphereShape*>(this->physicalBody_->getCollisionShape()); 349 if (sphere) 350 return (float)sphere->getRadius(); 351 } 352 return 0.0f; 353 } 396 //void WorldEntity::setCollisionRadius(float radius) 397 //{ 398 // if (!checkPhysics()) 399 // return; 400 401 // // destroy old one first 402 // btCollisionShape* oldShape = this->physicalBody_->getCollisionShape(); 403 // if (oldShape) 404 // delete oldShape; 405 406 // //if (this->getName() == "blubb") 407 // //{ 408 // // btCompoundShape* cShape = new btCompoundShape(); 409 // // cShape->setLocalScaling(btVector3(1,1,1)); 410 // // btTransform offset(btQuaternion(0, 0, 0), btVector3(0, 0, 0)); 411 // // offset.setBasis(btMatrix3x3(3, 0, 0, 0, 3, 0, 0, 0, 3)); 412 // // btSphereShape* sphere = new btSphereShape(radius); 413 // // sphere->setLocalScaling(btVector3(1,1,3)); 414 // // cShape->addChildShape(offset, sphere); 415 // // this->physicalBody_->setCollisionShape(cShape); 416 // //} 417 // //else 418 // this->physicalBody_->setCollisionShape(new btSphereShape(btScalar(radius))); 419 //} 420 421 //float WorldEntity::getCollisionRadius() const 422 //{ 423 // if (checkPhysics()) 424 // { 425 // btSphereShape* sphere = dynamic_cast<btSphereShape*>(this->physicalBody_->getCollisionShape()); 426 // if (sphere) 427 // return (float)sphere->getRadius(); 428 // } 429 // return 0.0f; 430 //} 354 431 355 432 bool WorldEntity::checkPhysics() const -
code/branches/physics/src/orxonox/objects/worldentities/WorldEntity.h
r2300 r2303 36 36 37 37 #include "LinearMath/btMotionState.h" 38 #include "BulletDynamics/Dynamics/btRigidBody.h"39 38 40 39 #include "network/Synchronisable.h" … … 108 107 { this->setDirection(Vector3(x, y, z), relativeTo, localDirectionVector); } 109 108 110 inline void setScale3D(const Vector3& scale) 111 { this->node_->setScale(scale); } 109 void setScale3D(const Vector3& scale); 112 110 inline void setScale3D(float x, float y, float z) 113 { this-> node_->setScale(x, y, z); }111 { this->setScale3D(Vector3(x, y, z)); } 114 112 inline const Vector3& getScale3D(void) const 115 113 { return this->node_->getScale(); } 116 114 117 inlinevoid setScale(float scale)118 { this-> node_->setScale(scale, scale, scale); }115 void setScale(float scale) 116 { this->setScale3D(scale, scale, scale); } 119 117 inline float getScale() const 120 118 { Vector3 scale = this->getScale3D(); return (scale.x == scale.y && scale.x == scale.z) ? scale.x : 1; } 121 119 122 inline void scale3D(const Vector3& scale) 123 { this->node_->scale(scale); } 120 void scale3D(const Vector3& scale); 124 121 inline void scale3D(float x, float y, float z) 125 { this-> node_->scale(x, y, z); }122 { this->scale3D(Vector3(x, y, z)); } 126 123 inline void scale(float scale) 127 { this-> node_->scale(scale, scale, scale); }124 { this->scale3D(scale, scale, scale); } 128 125 129 126 void attach(WorldEntity* object); 127 // void attachAsdf(BlinkingBillboard* object); 130 128 void detach(WorldEntity* object); 131 129 WorldEntity* getAttachedObject(unsigned int index) const; 130 // BlinkingBillboard* getAttachedAsdfObject(unsigned int index) const; 132 131 inline const std::set<WorldEntity*>& getAttachedObjects() const 133 132 { return this->children_; } … … 195 194 196 195 void setMass(float mass); 197 float getMass() const; 198 199 void setCollisionRadius(float radius); 200 float getCollisionRadius() const; 196 inline float getMass() const 197 { return this->mass_; } 198 199 void attachCollisionShape(CollisionShape* shape); 200 CollisionShape* getAttachedCollisionShape(unsigned int index) const; 201 202 CollisionShape* getCollisionShape() { return this->collisionShape_; } 203 btRigidBody* getPhysicalBody() { return this->physicalBody_; } 201 204 202 205 protected: … … 211 214 212 215 private: 213 CollisionType collisionType_; 214 216 void mergeCollisionShape(CollisionShape* shape); 217 218 CollisionType collisionType_; 219 std::vector<CollisionShape*> attachedShapes_; 220 CollisionShape* collisionShape_; 221 btScalar mass_; 215 222 }; 216 223 } -
code/branches/physics/src/orxonox/objects/worldentities/pawns/SpaceShip.cc
r2298 r2303 29 29 #include "OrxonoxStableHeaders.h" 30 30 #include "SpaceShip.h" 31 32 #include "BulletDynamics/Dynamics/btRigidBody.h" 31 33 32 34 #include "util/Math.h" -
code/branches/physics/visual_studio/vc8/orxonox.vcproj
r2300 r2303 348 348 </File> 349 349 </Filter> 350 <Filter 351 Name="collisionShapes" 352 > 353 <File 354 RelativePath="..\..\src\orxonox\objects\worldentities\collisionShapes\CollisionShape.cc" 355 > 356 </File> 357 <File 358 RelativePath="..\..\src\orxonox\objects\worldentities\collisionShapes\CompoundCollisionShape.cc" 359 > 360 </File> 361 <File 362 RelativePath="..\..\src\orxonox\objects\worldentities\collisionShapes\SphereCollisionShape.cc" 363 > 364 </File> 365 </Filter> 350 366 </Filter> 351 367 <Filter … … 1252 1268 </File> 1253 1269 </Filter> 1270 <Filter 1271 Name="collisionShapes" 1272 > 1273 <File 1274 RelativePath="..\..\src\orxonox\objects\worldentities\collisionShapes\CollisionShape.h" 1275 > 1276 </File> 1277 <File 1278 RelativePath="..\..\src\orxonox\objects\worldentities\collisionShapes\CompoundCollisionShape.h" 1279 > 1280 </File> 1281 <File 1282 RelativePath="..\..\src\orxonox\objects\worldentities\collisionShapes\SphereCollisionShape.h" 1283 > 1284 </File> 1285 </Filter> 1254 1286 </Filter> 1255 1287 <Filter … … 1419 1451 <File 1420 1452 RelativePath="..\..\src\orxonox\tools\BillboardSet.h" 1453 > 1454 </File> 1455 <File 1456 RelativePath="..\..\src\orxonox\tools\BulletConversions.h" 1421 1457 > 1422 1458 </File>
Note: See TracChangeset
for help on using the changeset viewer.