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
|
|
|
|
2021-09-14 13:47:53 +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
|
|
|
|
2021-10-12 17:12:47 +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
|
|
|
|
2021-10-12 17:12:47 +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);
|
2021-10-16 16:14:51 +03:00
|
|
|
} else if(obj1->isCollision()) {
|
2021-09-13 15:53:43 +03:00
|
|
|
obj1->translate(-collision.normal * collision.depth);
|
2021-10-16 16:14:51 +03:00
|
|
|
}
|
2021-09-13 15:53:43 +03:00
|
|
|
else
|
|
|
|
obj2->translate(collision.normal * collision.depth);
|
|
|
|
}
|
|
|
|
|