Merged physics.cc.
This commit is contained in:
commit
ff5bd0dae1
File diff suppressed because it is too large
Load Diff
@ -221,6 +221,25 @@
|
|||||||
</object>
|
</object>
|
||||||
</composition>
|
</composition>
|
||||||
|
|
||||||
|
<!-- Rotated Bridge Block -->
|
||||||
|
<composition>
|
||||||
|
<typeID>141</typeID>
|
||||||
|
<ignoreHeightmap>true</ignoreHeightmap>
|
||||||
|
<object>
|
||||||
|
<modelPath>block.obj</modelPath>
|
||||||
|
<xOffset>0.0</xOffset>
|
||||||
|
<yOffset>20.0</yOffset>
|
||||||
|
<zOffset>0.0</zOffset>
|
||||||
|
<xRot>0.0</xRot>
|
||||||
|
<yRot>90.0</yRot>
|
||||||
|
<zRot>0.0</zRot>
|
||||||
|
<scale>1.5</scale>
|
||||||
|
<mass>0.0</mass>
|
||||||
|
</object>
|
||||||
|
</composition>
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
<!-- Bridge Block on Pillar-->
|
<!-- Bridge Block on Pillar-->
|
||||||
<composition>
|
<composition>
|
||||||
<typeID>160</typeID>
|
<typeID>160</typeID>
|
||||||
@ -271,6 +290,56 @@
|
|||||||
</object>
|
</object>
|
||||||
</composition>
|
</composition>
|
||||||
|
|
||||||
|
<!-- Rotated Bridge Block on Pillar-->
|
||||||
|
<composition>
|
||||||
|
<typeID>161</typeID>
|
||||||
|
<ignoreHeightmap>true</ignoreHeightmap>
|
||||||
|
<object>
|
||||||
|
<modelPath>block.obj</modelPath>
|
||||||
|
<xOffset>0.0</xOffset>
|
||||||
|
<yOffset>20.0</yOffset>
|
||||||
|
<zOffset>0.0</zOffset>
|
||||||
|
<xRot>0.0</xRot>
|
||||||
|
<yRot>90.0</yRot>
|
||||||
|
<zRot>0.0</zRot>
|
||||||
|
<scale>1.5</scale>
|
||||||
|
<mass>0.0</mass>
|
||||||
|
</object>
|
||||||
|
<object>
|
||||||
|
<modelPath>column.obj</modelPath>
|
||||||
|
<xOffset>0.0</xOffset>
|
||||||
|
<yOffset>18.0</yOffset>
|
||||||
|
<zOffset>0.0</zOffset>
|
||||||
|
<xRot>0.0</xRot>
|
||||||
|
<yRot>90.0</yRot>
|
||||||
|
<zRot>0.0</zRot>
|
||||||
|
<scale>1.5</scale>
|
||||||
|
<mass>0.0</mass>
|
||||||
|
</object>
|
||||||
|
<object>
|
||||||
|
<modelPath>column.obj</modelPath>
|
||||||
|
<xOffset>0.0</xOffset>
|
||||||
|
<yOffset>15.0</yOffset>
|
||||||
|
<zOffset>0.0</zOffset>
|
||||||
|
<xRot>0.0</xRot>
|
||||||
|
<yRot>90.0</yRot>
|
||||||
|
<zRot>0.0</zRot>
|
||||||
|
<scale>1.5</scale>
|
||||||
|
<mass>0.0</mass>
|
||||||
|
</object>
|
||||||
|
<object>
|
||||||
|
<modelPath>column.obj</modelPath>
|
||||||
|
<xOffset>0.0</xOffset>
|
||||||
|
<yOffset>12.0</yOffset>
|
||||||
|
<zOffset>0.0</zOffset>
|
||||||
|
<xRot>0.0</xRot>
|
||||||
|
<yRot>90.0</yRot>
|
||||||
|
<zRot>0.0</zRot>
|
||||||
|
<scale>1.5</scale>
|
||||||
|
<mass>0.0</mass>
|
||||||
|
</object>
|
||||||
|
</composition>
|
||||||
|
|
||||||
<!-- Wall -->
|
<!-- Wall -->
|
||||||
<composition>
|
<composition>
|
||||||
<typeID>180</typeID>
|
<typeID>180</typeID>
|
||||||
@ -283,7 +352,7 @@
|
|||||||
<xRot>0.0</xRot>
|
<xRot>0.0</xRot>
|
||||||
<yRot>0.0</yRot>
|
<yRot>0.0</yRot>
|
||||||
<zRot>0.0</zRot>
|
<zRot>0.0</zRot>
|
||||||
<scale>1.49</scale>
|
<scale>1.48</scale>
|
||||||
<mass>0.0</mass>
|
<mass>0.0</mass>
|
||||||
</object>
|
</object>
|
||||||
</composition>
|
</composition>
|
||||||
@ -300,7 +369,7 @@
|
|||||||
<xRot>0.0</xRot>
|
<xRot>0.0</xRot>
|
||||||
<yRot>90.0</yRot>
|
<yRot>90.0</yRot>
|
||||||
<zRot>0.0</zRot>
|
<zRot>0.0</zRot>
|
||||||
<scale>1.49</scale>
|
<scale>1.48</scale>
|
||||||
<mass>0.0</mass>
|
<mass>0.0</mass>
|
||||||
</object>
|
</object>
|
||||||
</composition>
|
</composition>
|
||||||
@ -339,6 +408,23 @@
|
|||||||
</object>
|
</object>
|
||||||
</composition>
|
</composition>
|
||||||
|
|
||||||
|
<!-- Rotated Gate -->
|
||||||
|
<composition>
|
||||||
|
<typeID>221</typeID>
|
||||||
|
<ignoreHeightmap>true</ignoreHeightmap>
|
||||||
|
<object>
|
||||||
|
<modelPath>gate.obj</modelPath>
|
||||||
|
<xOffset>0.0</xOffset>
|
||||||
|
<yOffset>25.0</yOffset>
|
||||||
|
<zOffset>0.0</zOffset>
|
||||||
|
<xRot>0.0</xRot>
|
||||||
|
<yRot>90.0</yRot>
|
||||||
|
<zRot>0.0</zRot>
|
||||||
|
<scale>1.5</scale>
|
||||||
|
<mass>0.0</mass>
|
||||||
|
</object>
|
||||||
|
</composition>
|
||||||
|
|
||||||
<!-- Block for Switch -->
|
<!-- Block for Switch -->
|
||||||
<composition>
|
<composition>
|
||||||
<typeID>240</typeID>
|
<typeID>240</typeID>
|
||||||
@ -449,7 +535,7 @@
|
|||||||
<dampningA>0.5</dampningA>
|
<dampningA>0.5</dampningA>
|
||||||
</objectData>
|
</objectData>
|
||||||
|
|
||||||
<!-- Width height and length are not exact, Wall should be a TriangleMesh but that does not work... -->
|
<!-- lengh may not be exact -->
|
||||||
<objectData>
|
<objectData>
|
||||||
<modelPath>simpleWall.obj</modelPath>
|
<modelPath>simpleWall.obj</modelPath>
|
||||||
<texturePath>simpleWallTexture.png</texturePath>
|
<texturePath>simpleWallTexture.png</texturePath>
|
||||||
@ -457,9 +543,9 @@
|
|||||||
<diffuseFactor>0.6</diffuseFactor>
|
<diffuseFactor>0.6</diffuseFactor>
|
||||||
<specularFactor>0.4</specularFactor>
|
<specularFactor>0.4</specularFactor>
|
||||||
<shininess>2.0</shininess>
|
<shininess>2.0</shininess>
|
||||||
<physicType>TriangleMesh</physicType>
|
<physicType>Box</physicType>
|
||||||
<width>1.5</width>
|
<width>1.2</width>
|
||||||
<height>10</height>
|
<height>6</height>
|
||||||
<length>6</length>
|
<length>6</length>
|
||||||
<dampningL>0.555</dampningL>
|
<dampningL>0.555</dampningL>
|
||||||
<dampningA>0.5</dampningA>
|
<dampningA>0.5</dampningA>
|
||||||
@ -472,7 +558,10 @@
|
|||||||
<diffuseFactor>0.6</diffuseFactor>
|
<diffuseFactor>0.6</diffuseFactor>
|
||||||
<specularFactor>0.4</specularFactor>
|
<specularFactor>0.4</specularFactor>
|
||||||
<shininess>2.0</shininess>
|
<shininess>2.0</shininess>
|
||||||
<physicType>TriangleMesh</physicType>
|
<physicType>Box</physicType>
|
||||||
|
<width>1.2</width>
|
||||||
|
<height>6</height>
|
||||||
|
<length>6</length>
|
||||||
<dampningL>0.555</dampningL>
|
<dampningL>0.555</dampningL>
|
||||||
<dampningA>0.5</dampningA>
|
<dampningA>0.5</dampningA>
|
||||||
</objectData>
|
</objectData>
|
||||||
@ -484,7 +573,10 @@
|
|||||||
<diffuseFactor>0.6</diffuseFactor>
|
<diffuseFactor>0.6</diffuseFactor>
|
||||||
<specularFactor>0.4</specularFactor>
|
<specularFactor>0.4</specularFactor>
|
||||||
<shininess>2.0</shininess>
|
<shininess>2.0</shininess>
|
||||||
<physicType>TriangleMesh</physicType>
|
<physicType>Box</physicType>
|
||||||
|
<width>2</width>
|
||||||
|
<height>1.88</height>
|
||||||
|
<length>1.99</length>
|
||||||
<dampningL>0.555</dampningL>
|
<dampningL>0.555</dampningL>
|
||||||
<dampningA>0.5</dampningA>
|
<dampningA>0.5</dampningA>
|
||||||
</objectData>
|
</objectData>
|
||||||
|
Binary file not shown.
Before Width: | Height: | Size: 1.2 KiB After Width: | Height: | Size: 2.3 KiB |
Binary file not shown.
File diff suppressed because it is too large
Load Diff
Binary file not shown.
Before Width: | Height: | Size: 24 KiB After Width: | Height: | Size: 27 KiB |
Binary file not shown.
31
physics.cc
31
physics.cc
@ -25,11 +25,12 @@ void Physics::init(std::string geometryPath) //prepares bullet by creating all i
|
|||||||
void Physics::takeUpdateStep(float timeDiff)
|
void Physics::takeUpdateStep(float timeDiff)
|
||||||
{
|
{
|
||||||
|
|
||||||
world->stepSimulation(timeDiff); //allows the world to be simmulated correctly indipendant of the timedifferences between frames
|
|
||||||
|
|
||||||
counter++;
|
counter++;
|
||||||
if(counter<10)
|
if(counter<1)
|
||||||
|
{
|
||||||
|
world->stepSimulation(timeDiff);//allows the world to be simmulated correctly indipendant of the timedifferences between frames
|
||||||
return;
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
for(unsigned i = 0; i < allPositionConstraints.size();i++) //this handles the spring constraints
|
for(unsigned i = 0; i < allPositionConstraints.size();i++) //this handles the spring constraints
|
||||||
{
|
{
|
||||||
@ -47,14 +48,24 @@ void Physics::takeUpdateStep(float timeDiff)
|
|||||||
position *= 5;
|
position *= 5;
|
||||||
position += playerBall->getCenterOfMassPosition(); //is the position 5 units away from the player in the direction of the camera
|
position += playerBall->getCenterOfMassPosition(); //is the position 5 units away from the player in the direction of the camera
|
||||||
|
|
||||||
|
position.setY(playerBall->getCenterOfMassPosition().getY() + 1);
|
||||||
|
|
||||||
|
|
||||||
btVector3 dir = cameraBody->getCenterOfMassPosition() - position;
|
btVector3 dir = cameraBody->getCenterOfMassPosition() - position;
|
||||||
float str = cameraBody->getInvMass()*30 * dir.length();
|
float str = cameraBody->getInvMass()*50 * dir.length();
|
||||||
cameraBody->applyCentralForce(-dir*str);//scale the force by camera mass
|
cameraBody->applyCentralForce(-dir*str);//scale the force by camera mass
|
||||||
cameraBody->applyCentralForce(btVector3(0,96,0)); //we leave gravity in because by contrasting gravity to this force we force the camera slightly higher than the ball when still, but it follows more closer to the level of the ball (though still slightly higher) when it is moving.
|
|
||||||
counter=0;
|
counter=0;
|
||||||
|
float speed = cameraBody->getLinearVelocity().length();
|
||||||
|
if(speed>20.0f)
|
||||||
|
{
|
||||||
|
printf("%f , %f \n", speed, position.length());
|
||||||
|
position = cameraBody->getLinearVelocity();
|
||||||
|
position.normalize();
|
||||||
|
cameraBody->setLinearVelocity(position*20);
|
||||||
}
|
}
|
||||||
|
world->stepSimulation(timeDiff);
|
||||||
|
}
|
||||||
|
//
|
||||||
void Physics::removePositionConstraint(int bodyIndice) //remover function for deleting all pos constraints on one body
|
void Physics::removePositionConstraint(int bodyIndice) //remover function for deleting all pos constraints on one body
|
||||||
{
|
{
|
||||||
for(unsigned i = 0; i < allPositionConstraints.size(); i++)
|
for(unsigned i = 0; i < allPositionConstraints.size(); i++)
|
||||||
@ -95,7 +106,7 @@ void Physics::addPlayer(float friction, float rad, Entity entity, float mass, fl
|
|||||||
btRigidBody::btRigidBodyConstructionInfo info(mass,motion,sphere,inertia); //next we process all data for the rigid body into info
|
btRigidBody::btRigidBodyConstructionInfo info(mass,motion,sphere,inertia); //next we process all data for the rigid body into info
|
||||||
|
|
||||||
info.m_friction = friction*2; //here we modify the friction and restitution (bounciness) of the object
|
info.m_friction = friction*2; //here we modify the friction and restitution (bounciness) of the object
|
||||||
info.m_restitution = 0;
|
info.m_restitution = 0.1f;
|
||||||
|
|
||||||
playerBall = new btRigidBody(info); //finally we create the rigid body using the info
|
playerBall = new btRigidBody(info); //finally we create the rigid body using the info
|
||||||
|
|
||||||
@ -130,8 +141,8 @@ void Physics::addTerrain(int width, int length, float** heightData) //The terrai
|
|||||||
highest++;
|
highest++;
|
||||||
|
|
||||||
btHeightfieldTerrainShape* terrainShape = new btHeightfieldTerrainShape(length,width,heightfield,highest,1,true,false);
|
btHeightfieldTerrainShape* terrainShape = new btHeightfieldTerrainShape(length,width,heightfield,highest,1,true,false);
|
||||||
|
|
||||||
btRigidBody::btRigidBodyConstructionInfo info(0,new btDefaultMotionState(),terrainShape,btVector3(0,0,0)); //next we process all data for the rigid body into info
|
btRigidBody::btRigidBodyConstructionInfo info(0,new btDefaultMotionState(),terrainShape,btVector3(0,0,0)); //next we process all data for the rigid body into info
|
||||||
|
info.m_friction = 1;
|
||||||
info.m_restitution = 0;
|
info.m_restitution = 0;
|
||||||
btRigidBody* tBody = new btRigidBody(info);
|
btRigidBody* tBody = new btRigidBody(info);
|
||||||
|
|
||||||
@ -278,7 +289,7 @@ void Physics::addBox(float width, float height, float length, Entity entity, flo
|
|||||||
|
|
||||||
void Physics::addSphere(float rad, Entity entity, float mass, float dampningL, float dampningA, unsigned indice,bool rotate)
|
void Physics::addSphere(float rad, Entity entity, float mass, float dampningL, float dampningA, unsigned indice,bool rotate)
|
||||||
{
|
{
|
||||||
if(bodies.size() == indice)
|
if(bodies.size() == indice) //(user's initial) height, not the actual height. More...
|
||||||
throw std::invalid_argument( "Bodies out of Sync" );
|
throw std::invalid_argument( "Bodies out of Sync" );
|
||||||
|
|
||||||
btSphereShape* sphere = new btSphereShape(rad);
|
btSphereShape* sphere = new btSphereShape(rad);
|
||||||
@ -329,6 +340,8 @@ void Physics::addCamera() //Camera Creator automatically called when player is c
|
|||||||
|
|
||||||
world->addRigidBody(cameraBody,COL_OBJECTS, objectsPhysicsCollision);
|
world->addRigidBody(cameraBody,COL_OBJECTS, objectsPhysicsCollision);
|
||||||
|
|
||||||
|
cameraBody->setGravity(btVector3(0,0,0));
|
||||||
|
|
||||||
cameraBody->setSleepingThresholds(0,0); //very important, otherwise camera may go to sleep, aka not move until next collision
|
cameraBody->setSleepingThresholds(0,0); //very important, otherwise camera may go to sleep, aka not move until next collision
|
||||||
|
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user