2021-04-21 15:06:03 -05:00
|
|
|
/*
|
|
|
|
Dane Johnson <dane@danejohnson.org>
|
|
|
|
|
|
|
|
LICENSE
|
|
|
|
|
|
|
|
Couch Copyright (C) 2021 Dane Johnson
|
|
|
|
|
|
|
|
This program comes with ABSOLUTELY NO WARRANTY; without event the
|
|
|
|
implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
|
|
|
|
See the GNU General Public License for details at
|
|
|
|
https://www.gnu.org/licenses/gpl-3.0.html
|
|
|
|
|
|
|
|
This is free software, and you are welcome to redistribute it
|
|
|
|
under the terms of the GNU General Public License as published
|
|
|
|
by the Free Software Foundation; either version 3 of the License,
|
|
|
|
or (at your option) any later version.
|
|
|
|
|
|
|
|
DESCRIPTION
|
|
|
|
|
|
|
|
The physics world
|
|
|
|
*/
|
2021-01-24 22:55:36 -06:00
|
|
|
#include "World.h"
|
|
|
|
|
|
|
|
World* World::GetWorld() {
|
|
|
|
if (!world) {
|
|
|
|
world = new World();
|
|
|
|
}
|
|
|
|
|
|
|
|
return world;
|
|
|
|
}
|
|
|
|
|
|
|
|
void World::AddRigidbody(Rigidbody *rigidbody) {
|
|
|
|
btWorld->addRigidBody(rigidbody->btBody);
|
|
|
|
}
|
|
|
|
|
2021-01-27 16:17:22 -06:00
|
|
|
void World::Step(float delta) {
|
2021-01-24 22:55:36 -06:00
|
|
|
btWorld->stepSimulation(delta);
|
|
|
|
}
|
|
|
|
|
|
|
|
World* World::world { new World() };
|
|
|
|
|
|
|
|
World::World() {
|
|
|
|
// Some Java-ass code to follow
|
|
|
|
collisionConfiguration = new btDefaultCollisionConfiguration();
|
|
|
|
dispatcher = new btCollisionDispatcher(collisionConfiguration);
|
|
|
|
overlappingPairCache = new btDbvtBroadphase();
|
|
|
|
solver = new btSequentialImpulseConstraintSolver();
|
|
|
|
btWorld = new btDiscreteDynamicsWorld(dispatcher, overlappingPairCache, solver, collisionConfiguration);
|
|
|
|
btWorld->setGravity(btVector3(0, -10, 0));
|
|
|
|
}
|
|
|
|
|
|
|
|
World::~World() {
|
|
|
|
delete btWorld;
|
|
|
|
delete solver;
|
|
|
|
delete overlappingPairCache;
|
|
|
|
delete dispatcher;
|
|
|
|
delete collisionConfiguration;
|
|
|
|
}
|