mirror of
https://github.com/orange-cpp/omath.git
synced 2026-02-13 23:13:26 +00:00
58 lines
1.7 KiB
C++
58 lines
1.7 KiB
C++
//
|
|
// Created by Vlad on 11/9/2025.
|
|
//
|
|
#include "omath/engines/source_engine/collider.hpp"
|
|
#include <gtest/gtest.h>
|
|
#include <omath/collision/gjk_algorithm.hpp>
|
|
#include <omath/engines/source_engine/mesh.hpp>
|
|
namespace
|
|
{
|
|
const omath::source_engine::Mesh mesh = {
|
|
{{-1.f, -1.f, -1.f},
|
|
{-1.f, -1.f, 1.f},
|
|
{-1.f, 1.f, -1.f},
|
|
{-1.f, 1.f, 1.f},
|
|
{1.f, 1.f, 1.f},
|
|
{1.f, 1.f, -1.f},
|
|
{1.f, -1.f, 1.f},
|
|
{1.f, -1.f, -1.f}},
|
|
{}};
|
|
}
|
|
TEST(UnitTestGjk, TestCollisionTrue)
|
|
{
|
|
const omath::source_engine::MeshCollider collider_a(mesh);
|
|
|
|
auto mesh_b = mesh;
|
|
mesh_b.set_origin({0.f, 0.5f, 0.f});
|
|
|
|
const omath::source_engine::MeshCollider collider_b(mesh_b);
|
|
|
|
using GjkAlgorithm = omath::collision::GjkAlgorithm<omath::source_engine::MeshCollider>;
|
|
|
|
const auto result = GjkAlgorithm::is_collide(collider_a, collider_b);
|
|
|
|
EXPECT_TRUE(result);
|
|
}
|
|
TEST(UnitTestGjk, TestCollisionFalse)
|
|
{
|
|
const omath::source_engine::MeshCollider collider_a(mesh);
|
|
auto mesh_b = mesh;
|
|
mesh_b.set_origin({0.f, 2.1f, 0.f});
|
|
const omath::source_engine::MeshCollider collider_b(mesh_b);
|
|
|
|
const auto result =
|
|
omath::collision::GjkAlgorithm<omath::source_engine::MeshCollider>::is_collide(collider_a, collider_b);
|
|
|
|
EXPECT_FALSE(result);
|
|
}
|
|
|
|
TEST(UnitTestGjk, TestCollisionEqualOrigin)
|
|
{
|
|
const omath::source_engine::MeshCollider collider_a(mesh);
|
|
const omath::source_engine::MeshCollider collider_b(mesh);
|
|
|
|
const auto result =
|
|
omath::collision::GjkAlgorithm<omath::source_engine::MeshCollider>::is_collide(collider_a, collider_b);
|
|
|
|
EXPECT_TRUE(result);
|
|
} |