MPhysicsProperties

(Difference between revisions)
Jump to: navigation, search
(Mass)
(Ghost: mistake)
Line 71: Line 71:
 
Set the entity as a ghost.
 
Set the entity as a ghost.
 
<pre>
 
<pre>
entity->setGhost(true); //set entity as ghost
+
phyProps->setGhost(true); //set entity as ghost
entity->setGhost(false); //entity is no more a ghost
+
phyProps->setGhost(false); //entity is no more a ghost
 
</pre>
 
</pre>
  
Line 78: Line 78:
 
Check if the entity is a ghost.
 
Check if the entity is a ghost.
 
<pre>
 
<pre>
if(entity->isGhost())
+
if(phyProps->isGhost())
 
   printf("Entity is a ghost");
 
   printf("Entity is a ghost");
 
</pre>
 
</pre>

Revision as of 18:31, 20 October 2013

MPhysicsProperties is a class used by MOEntity.

The class is defined in the MOEntity source code itself.

This class has and can set the MPhysicsConstraint.

MPhysicsProperties contains all the properties that will be used by the physics engine.

These properties can also be edited in the Maratis Editor.

The properties are mere value holders for the physics engine. This means that editing them when the game is already started will have no effect at all. The properties take effect only when the scene prepares the physics (MScene::preparePhysics) creating the collision objects for every entity.

However you can apply the new values using these methods of MPhysicsContext:

setObjectMass

setObjectRestitution

setObjectFriction

setObjectLinearFactor

setObjectAngularFactor

setObjectDamping

Another option is to reload all the physics properties of the entity using MScene::prepareCollisionShape and MScene::PrepareCollisionObject.


Contents

Source code

MOEntity.h

MOEntity.cpp


API

constraint

deleteConstraint

[...]

createConstraint

[...]

getConstraint

[...]

Shape ID

setShapeId

[...]

getShapeId

[...]

Collision object ID

The ID of the very collision object used by MPhysicsContext. See the introduction of this page.

setCollisionObjectId

[...]

getCollisionObjectId

[...]

Collision shape

setCollisionShape

[...]

getCollisionShape

[...]

Ghost

Setting the entity as a ghost disables all the physics properties (e.g. mass) but the collision shape. Constraints are also disabled.

This is generally used as a child object of another entity which is moving, so you can check if there is a collision at specific areas (e.g. feet).

setGhost

Set the entity as a ghost.

phyProps->setGhost(true); //set entity as ghost
phyProps->setGhost(false); //entity is no more a ghost

isGhost

Check if the entity is a ghost.

if(phyProps->isGhost())
  printf("Entity is a ghost");

Mass

Set the mass of the entity.

Notice that the property is not applied until you create/update the real physics object. See Creating and updating physics objects

setMass

Set the Mass. Float type.

phyProps->setMass(5.2f);

getMass

Retrieve the Mass. Float type.

float mass = phyProp->getMass();

Friction

setFriction

[...]

getFriction

[...]

Restitution

setRestitution

[...]

getRestitution

[...]

Linear damping

setLinearDamping

[...]

getLinearDamping

[...]

Angular damping

setAngularDamping

[...]

getAngularDamping

[...]

Angular factor

setAngularFactor

[...]

getAngularFactor

[...]

Linear factor

setLinearFactor

[...]

getLinearFactor

[...]

Personal tools
Namespaces
Variants
Actions
Navigation
Toolbox