211 lines
6.7 KiB
C++
211 lines
6.7 KiB
C++
#include "Level.h"
|
|
#include "CollisionManager.h"
|
|
#include "Game.h"
|
|
|
|
using namespace GameLogic;
|
|
using namespace Utility::DynamicMemory;
|
|
using namespace Oyster::Physics;
|
|
|
|
|
|
Level::Level(void)
|
|
{
|
|
|
|
}
|
|
Level::~Level(void)
|
|
{
|
|
delete this->levelObj;
|
|
this->levelObj = 0;
|
|
}
|
|
|
|
void Level::InitiateLevel(std::string levelPath)
|
|
{
|
|
|
|
}
|
|
void Level::InitiateLevel(float radius)
|
|
{
|
|
//float heading = Utility::Value::Radian(180.0f);
|
|
//float attitude = Utility::Value::Radian(0.0f);
|
|
//float bank = Utility::Value::Radian(0);
|
|
//
|
|
//double c1 = cos(heading/2);
|
|
//double s1 = sin(heading/2);
|
|
//double c2 = cos(attitude/2);
|
|
//double s2 = sin(attitude/2);
|
|
//double c3 = cos(bank/2);
|
|
//double s3 = sin(bank/2);
|
|
//double c1c2 = c1*c2;
|
|
//double s1s2 = s1*s2;
|
|
//double w =c1c2*c3 - s1s2*s3;
|
|
//double x =c1c2*s3 + s1s2*c3;
|
|
//double y =s1*c2*c3 + c1*s2*s3;
|
|
//double z =c1*s2*c3 - s1*c2*s3;
|
|
//double angle = 2 * acos(w);
|
|
//
|
|
//double norm = x*x+y*y+z*z;
|
|
//if (norm < 0.001) { // when all euler angles are zero angle =0 so
|
|
// // we can set axis to anything to avoid divide by zero
|
|
// x=1;
|
|
// y=z=0;
|
|
//} else {
|
|
// norm = sqrt(norm);
|
|
// x /= norm;
|
|
// y /= norm;
|
|
// z /= norm;
|
|
//}
|
|
|
|
int idCount = 100;
|
|
|
|
// add level sphere
|
|
API::SphericalBodyDescription sbDesc;
|
|
sbDesc.centerPosition = Oyster::Math::Float4(0,0,0,1);
|
|
sbDesc.ignoreGravity = true;
|
|
sbDesc.radius = 300;
|
|
sbDesc.mass = 10e12f;
|
|
sbDesc.frictionCoeff_Static = 0;
|
|
sbDesc.frictionCoeff_Dynamic = 0;
|
|
//sbDesc.rotation =
|
|
ICustomBody* rigidBody = API::Instance().CreateRigidBody(sbDesc).Release();
|
|
|
|
ICustomBody::State state;
|
|
rigidBody->GetState(state);
|
|
state.SetRestitutionCoeff(0.2);
|
|
rigidBody->SetState(state);
|
|
|
|
levelObj = new StaticObject(rigidBody, LevelCollisionBefore, LevelCollisionAfter, OBJECT_TYPE::OBJECT_TYPE_WORLD);
|
|
levelObj->objectID = idCount++;
|
|
rigidBody->SetCustomTag(levelObj);
|
|
|
|
/*
|
|
// add box
|
|
API::SimpleBodyDescription sbDesc_TestBox;
|
|
sbDesc_TestBox.centerPosition = Oyster::Math::Float4(10,320,0,0);
|
|
sbDesc_TestBox.ignoreGravity = false;
|
|
|
|
sbDesc_TestBox.mass = 50;
|
|
sbDesc_TestBox.size = Oyster::Math::Float4(2,2,2,0);
|
|
|
|
|
|
ICustomBody* rigidBody_TestBox;
|
|
|
|
int nrOfBoxex = 5;
|
|
int offset = 0;
|
|
for(int i =0; i< nrOfBoxex; i ++)
|
|
{
|
|
sbDesc_TestBox.centerPosition = Oyster::Math::Float4(-20 +( i*7) ,320,20,0);
|
|
rigidBody_TestBox = API::Instance().CreateRigidBody(sbDesc_TestBox).Release();
|
|
rigidBody_TestBox->SetSubscription(Level::PhysicsOnMoveLevel);
|
|
|
|
DynamicObject *box = new DynamicObject(rigidBody_TestBox,Object::DefaultCollisionBefore, Object::DefaultCollisionAfter, OBJECT_TYPE::OBJECT_TYPE_BOX);
|
|
box->objectID = idCount++;
|
|
this->dynamicObjects.Push(box);
|
|
rigidBody_TestBox->SetCustomTag(this->dynamicObjects[i]);
|
|
}
|
|
offset += nrOfBoxex;
|
|
for(int i =0; i< nrOfBoxex; i ++)
|
|
{
|
|
sbDesc_TestBox.centerPosition = Oyster::Math::Float4(-20,320, -20 +( i*7),0);
|
|
rigidBody_TestBox = API::Instance().CreateRigidBody(sbDesc_TestBox).Release();
|
|
rigidBody_TestBox->SetSubscription(Level::PhysicsOnMoveLevel);
|
|
|
|
this->dynamicObjects.Push(new DynamicObject(rigidBody_TestBox,Object::DefaultCollisionBefore, Object::DefaultCollisionAfter, OBJECT_TYPE::OBJECT_TYPE_BOX));
|
|
rigidBody_TestBox->SetCustomTag(this->dynamicObjects[i+offset]);
|
|
}
|
|
offset += nrOfBoxex;
|
|
for(int i =0; i< nrOfBoxex; i ++)
|
|
{
|
|
sbDesc_TestBox.centerPosition = Oyster::Math::Float4(20,320,-20 + ( i*7),0);
|
|
rigidBody_TestBox = API::Instance().CreateRigidBody(sbDesc_TestBox).Release();
|
|
rigidBody_TestBox->SetSubscription(Level::PhysicsOnMoveLevel);
|
|
|
|
this->dynamicObjects.Push(new DynamicObject(rigidBody_TestBox,Object::DefaultCollisionBefore, Object::DefaultCollisionAfter, OBJECT_TYPE::OBJECT_TYPE_BOX));
|
|
rigidBody_TestBox->SetCustomTag(this->dynamicObjects[i+offset]);
|
|
}
|
|
offset += nrOfBoxex;
|
|
for(int i =0; i< nrOfBoxex; i ++)
|
|
{
|
|
sbDesc_TestBox.centerPosition = Oyster::Math::Float4(-20 +( i*7) ,320,-20,0);
|
|
rigidBody_TestBox = API::Instance().CreateRigidBody(sbDesc_TestBox).Release();
|
|
rigidBody_TestBox->SetSubscription(Level::PhysicsOnMoveLevel);
|
|
|
|
this->dynamicObjects.Push(new DynamicObject(rigidBody_TestBox,Object::DefaultCollisionBefore, Object::DefaultCollisionAfter, OBJECT_TYPE::OBJECT_TYPE_BOX));
|
|
rigidBody_TestBox->SetCustomTag(this->dynamicObjects[i+offset]);
|
|
}
|
|
|
|
// add crystal
|
|
API::SimpleBodyDescription sbDesc_Crystal;
|
|
sbDesc_Crystal.centerPosition = Oyster::Math::Float4(10, 305, 0, 0);
|
|
sbDesc_Crystal.ignoreGravity = false;
|
|
sbDesc_Crystal.mass = 70;
|
|
sbDesc_Crystal.size = Oyster::Math::Float4(2,3,2,0);
|
|
|
|
ICustomBody* rigidBody_Crystal = API::Instance().CreateRigidBody(sbDesc_Crystal).Release();
|
|
rigidBody_Crystal->SetSubscription(Level::PhysicsOnMoveLevel);
|
|
DynamicObject *cry = new DynamicObject(rigidBody_Crystal,Object::DefaultCollisionBefore, Object::DefaultCollisionAfter, OBJECT_TYPE::OBJECT_TYPE_BOX);
|
|
cry->objectID = idCount++;
|
|
this->dynamicObjects.Push(cry);
|
|
rigidBody_Crystal->SetCustomTag(this->dynamicObjects[nrOfBoxex]);
|
|
|
|
|
|
// add house
|
|
API::SimpleBodyDescription sbDesc_House;
|
|
//sbDesc_House.centerPosition = Oyster::Math::Float4(212, 212, 0, 0);
|
|
sbDesc_House.centerPosition = Oyster::Math::Float4(-50, 290, 0, 0);
|
|
sbDesc_House.ignoreGravity = false;
|
|
sbDesc_House.rotation = Oyster::Math::Float3(0 ,Utility::Value::Radian(90.0f), 0);
|
|
sbDesc_House.mass = 70;
|
|
sbDesc_House.size = Oyster::Math::Float4(40,40,40,0);
|
|
|
|
|
|
ICustomBody* rigidBody_House = API::Instance().CreateRigidBody(sbDesc_House).Release();
|
|
rigidBody_House->SetSubscription(Level::PhysicsOnMoveLevel);
|
|
this->staticObjects.Push(new StaticObject(rigidBody_House,Object::DefaultCollisionBefore, Object::DefaultCollisionAfter, OBJECT_TYPE::OBJECT_TYPE_GENERIC));
|
|
rigidBody_House->SetCustomTag(this->staticObjects[0]);
|
|
rigidBody_House->GetState(state);
|
|
Oyster::Math::Float4x4 world = state.GetOrientation();
|
|
|
|
*/
|
|
|
|
// add gravitation
|
|
API::Gravity gravityWell;
|
|
gravityWell.gravityType = API::Gravity::GravityType_Well;
|
|
gravityWell.well.mass = 1e17f;
|
|
gravityWell.well.position = Oyster::Math::Float4(0,0,0,1);
|
|
API::Instance().AddGravity(gravityWell);
|
|
}
|
|
|
|
void Level::AddPlayerToTeam(Player *player, int teamID)
|
|
{
|
|
this->teamManager.AddPlayerToTeam(player,teamID);
|
|
}
|
|
|
|
void Level::CreateTeam(int teamSize)
|
|
{
|
|
this->teamManager.CreateTeam(teamSize);
|
|
}
|
|
|
|
void Level::RespawnPlayer(Player *player)
|
|
{
|
|
this->teamManager.RespawnPlayerRandom(player);
|
|
}
|
|
|
|
int Level::getNrOfDynamicObj()
|
|
{
|
|
return this->dynamicObjects.Size();
|
|
}
|
|
Object* Level::GetObj( int ID) const
|
|
{
|
|
for (int i = 0; i< this->dynamicObjects.Size(); i++)
|
|
{
|
|
if(this->dynamicObjects[i]->GetID() == ID)
|
|
return this->dynamicObjects[i];
|
|
}
|
|
return NULL;
|
|
}
|
|
void Level::PhysicsOnMoveLevel(const ICustomBody *object)
|
|
{
|
|
// function call from physics update when object was moved
|
|
Object* temp = (Object*)object->GetCustomTag();
|
|
((Game*)&Game::Instance())->onMoveFnc(temp);
|
|
|
|
}
|