summaryrefslogtreecommitdiffhomepage
path: root/Opcode/OpcodeLib/OPC_AABBCollider.h
diff options
context:
space:
mode:
authorAki <please@ignore.pl>2021-10-03 16:51:12 +0200
committerAki <please@ignore.pl>2021-10-03 16:51:12 +0200
commit104248aabf40b692231fccd1adf1a2a494f1589a (patch)
tree5eee42a18a9688b03b483aff5c2bedffb4fe8a6c /Opcode/OpcodeLib/OPC_AABBCollider.h
parentddd76aa4e1571c8d5965709db5c3cd47a89c9a38 (diff)
parentd2f333bf998691760b8970c2784756d0fa81e820 (diff)
downloadstarshatter-104248aabf40b692231fccd1adf1a2a494f1589a.zip
starshatter-104248aabf40b692231fccd1adf1a2a494f1589a.tar.gz
starshatter-104248aabf40b692231fccd1adf1a2a494f1589a.tar.bz2
Stars45 can now be built under MSYS2/Mingw32
Diffstat (limited to 'Opcode/OpcodeLib/OPC_AABBCollider.h')
-rw-r--r--Opcode/OpcodeLib/OPC_AABBCollider.h97
1 files changed, 0 insertions, 97 deletions
diff --git a/Opcode/OpcodeLib/OPC_AABBCollider.h b/Opcode/OpcodeLib/OPC_AABBCollider.h
deleted file mode 100644
index 9a86948..0000000
--- a/Opcode/OpcodeLib/OPC_AABBCollider.h
+++ /dev/null
@@ -1,97 +0,0 @@
-///////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////
-/*
- * OPCODE - Optimized Collision Detection
- * Copyright (C) 2001 Pierre Terdiman
- * Homepage: http://www.codercorner.com/Opcode.htm
- */
-///////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////
-
-///////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////
-/**
- * Contains code for an AABB collider.
- * \file OPC_AABBCollider.h
- * \author Pierre Terdiman
- * \date January, 1st, 2002
- */
-///////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////
-
-///////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////
-// Include Guard
-#ifndef __OPC_AABBCOLLIDER_H__
-#define __OPC_AABBCOLLIDER_H__
-
- struct OPCODE_API AABBCache : VolumeCache
- {
- AABBCache() : FatCoeff(1.1f)
- {
- FatBox.mCenter.Zero();
- FatBox.mExtents.Zero();
- }
-
- // Cached faces signature
- CollisionAABB FatBox; //!< Box used when performing the query resulting in cached faces
- // User settings
- float FatCoeff; //!< mRadius2 multiplier used to create a fat sphere
- };
-
- class OPCODE_API AABBCollider : public VolumeCollider
- {
- public:
- // Constructor / Destructor
- AABBCollider();
- virtual ~AABBCollider();
-
- ///////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////
- /**
- * Generic collision query for generic OPCODE models. After the call, access the results:
- * - with GetContactStatus()
- * - with GetNbTouchedPrimitives()
- * - with GetTouchedPrimitives()
- *
- * \param cache [in/out] a box cache
- * \param box [in] collision AABB in world space
- * \param model [in] Opcode model to collide with
- * \return true if success
- * \warning SCALE NOT SUPPORTED. The matrices must contain rotation & translation parts only.
- */
- ///////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////
- bool Collide(AABBCache& cache, const CollisionAABB& box, const Model& model);
- //
- bool Collide(AABBCache& cache, const CollisionAABB& box, const AABBTree* tree);
- protected:
- CollisionAABB mBox; //!< Query box in (center, extents) form
- IcePoint mMin; //!< Query box min point
- IcePoint mMax; //!< Query box max point
- // Leaf description
- IcePoint mLeafVerts[3]; //!< Triangle vertices
- // Internal methods
- void _Collide(const AABBCollisionNode* node);
- void _Collide(const AABBNoLeafNode* node);
- void _Collide(const AABBQuantizedNode* node);
- void _Collide(const AABBQuantizedNoLeafNode* node);
- void _Collide(const AABBTreeNode* node);
- void _CollideNoPrimitiveTest(const AABBCollisionNode* node);
- void _CollideNoPrimitiveTest(const AABBNoLeafNode* node);
- void _CollideNoPrimitiveTest(const AABBQuantizedNode* node);
- void _CollideNoPrimitiveTest(const AABBQuantizedNoLeafNode* node);
- // Overlap tests
- inline_ BOOL AABBContainsBox(const IcePoint& bc, const IcePoint& be);
- inline_ BOOL AABBAABBOverlap(const IcePoint& b, const IcePoint& Pb);
- inline_ BOOL TriBoxOverlap();
- // Init methods
- BOOL InitQuery(AABBCache& cache, const CollisionAABB& box);
- };
-
- class OPCODE_API HybridAABBCollider : public AABBCollider
- {
- public:
- // Constructor / Destructor
- HybridAABBCollider();
- virtual ~HybridAABBCollider();
-
- bool Collide(AABBCache& cache, const CollisionAABB& box, const HybridModel& model);
- protected:
- Container mTouchedBoxes;
- };
-
-#endif // __OPC_AABBCOLLIDER_H__