aboutsummaryrefslogtreecommitdiff
path: root/src/crepe/PhysicsSystem.cpp
diff options
context:
space:
mode:
authorLoek Le Blansch <loek@pipeframe.xyz>2024-11-05 16:12:47 +0100
committerLoek Le Blansch <loek@pipeframe.xyz>2024-11-05 16:12:47 +0100
commite36ea050972fcaaf3d85d672755bad4ebb2dcd80 (patch)
tree5145e0b66650eea1df301106b7d197a586be65f3 /src/crepe/PhysicsSystem.cpp
parent333b07775be1ef20fdb5909672c1e4dcabec1b40 (diff)
parentb770475741b7c33d57331f3139c55a3f237ad274 (diff)
merge `master` into `loek/savemgr`
Diffstat (limited to 'src/crepe/PhysicsSystem.cpp')
-rw-r--r--src/crepe/PhysicsSystem.cpp62
1 files changed, 0 insertions, 62 deletions
diff --git a/src/crepe/PhysicsSystem.cpp b/src/crepe/PhysicsSystem.cpp
deleted file mode 100644
index 16f4c10..0000000
--- a/src/crepe/PhysicsSystem.cpp
+++ /dev/null
@@ -1,62 +0,0 @@
-#include <iostream>
-
-#include "api/Force.h"
-#include "api/Rigidbody.h"
-#include "api/Transform.h"
-
-#include "ComponentManager.h"
-#include "PhysicsSystem.h"
-
-using namespace crepe;
-using namespace crepe::api;
-
-PhysicsSystem::PhysicsSystem() {}
-
-void PhysicsSystem::update() {
- ComponentManager & mgr = ComponentManager::get_instance();
- std::vector<std::reference_wrapper<Rigidbody>> rigidbodies
- = mgr.get_components_by_type<Rigidbody>();
- std::vector<std::reference_wrapper<Transform>> transforms
- = mgr.get_components_by_type<Transform>();
-
- for (Rigidbody & rigidbody : rigidbodies) {
-
- switch (rigidbody.body_type) {
- case BodyType::DYNAMIC:
- for (Transform & transform : transforms) {
- if (transform.game_object_id == rigidbody.game_object_id) {
- rigidbody.velocity_x = 0;
- rigidbody.velocity_y = 0;
- std::vector<std::reference_wrapper<Force>> forces
- = mgr.get_components_by_id<Force>(
- rigidbody.game_object_id);
- rigidbody.velocity_y
- += rigidbody.gravity_scale * 1 * rigidbody.mass;
-
- for (Force & force : forces) {
- rigidbody.velocity_x += force.force_x;
- rigidbody.velocity_y += force.force_y;
- }
-
- std::cout << "before transform.postion.x "
- << transform.position.x << std::endl;
- std::cout << "before transform.postion.y "
- << transform.position.y << std::endl;
- transform.position.x += rigidbody.velocity_x;
- transform.position.y += rigidbody.velocity_y;
- std::cout << "after transform.postion.x "
- << transform.position.x << std::endl;
- std::cout << "after transform.postion.y "
- << transform.position.y << std::endl;
- }
- }
- break;
- case BodyType::KINEMATIC:
- break; //(scripts)
- case BodyType::STATIC:
- break; //(unmoveable objects)
- default:
- break;
- }
- }
-}