vectozavr-shooter/engine/physics/Solver.cpp

35 lines
1.2 KiB
C++
Raw Normal View History

2021-09-13 15:53:43 +03:00
//
// Created by Иван Ильин on 10.03.2021.
//
#include "Solver.h"
2021-10-09 13:41:12 +03:00
#include "../utils/Log.h"
2021-09-13 15:53:43 +03:00
void Solver::solveCollision(std::shared_ptr<RigidBody> obj1, std::shared_ptr<RigidBody> obj2, const CollisionPoint& collision) {
2021-09-13 15:53:43 +03:00
Vec3D obj1_velocity_parallel = collision.normal * obj1->velocity().dot(collision.normal);
Vec3D obj1_velocity_perpendicular = obj1->velocity() - obj1_velocity_parallel;
2021-09-13 15:53:43 +03:00
Vec3D obj2_velocity_parallel = collision.normal * obj2->velocity().dot(collision.normal);
Vec3D obj2_velocity_perpendicular = obj2->velocity() - obj2_velocity_parallel;
2021-09-13 15:53:43 +03:00
if(obj1->isCollision()) {
if(obj1->velocity().dot(collision.normal) > 0) {
obj1->setVelocity(obj1_velocity_perpendicular);
}
}
if(obj2->isCollision()) {
obj2->setVelocity(obj2_velocity_perpendicular - obj2_velocity_parallel * 0.8);
}
if(obj1->isCollision() && obj2->isCollision()) {
obj1->translate(-collision.normal * collision.depth/2.0);
obj2->translate(collision.normal * collision.depth/2.0);
} else if(obj1->isCollision()) {
2021-09-13 15:53:43 +03:00
obj1->translate(-collision.normal * collision.depth);
}
2021-09-13 15:53:43 +03:00
else
obj2->translate(collision.normal * collision.depth);
}