File: CollisionDetection.h

package info (click to toggle)
astromenace 1.3.2%2Brepack-7.1
  • links: PTS, VCS
  • area: contrib
  • in suites: forky, sid
  • size: 4,496 kB
  • sloc: cpp: 61,665; makefile: 25; sh: 19
file content (86 lines) | stat: -rwxr-xr-x 3,463 bytes parent folder | download | duplicates (5)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
/************************************************************************************

	AstroMenace (Hardcore 3D space shooter with spaceship upgrade possibilities)
	Copyright © 2006-2013 Michael Kurinnoy, Viewizard


	AstroMenace is free software: you can redistribute it and/or modify
	it under the terms of the GNU General Public License as published by
	the Free Software Foundation, either version 3 of the License, or
	(at your option) any later version.

	AstroMenace is distributed in the hope that it will be useful,
	but WITHOUT ANY WARRANTY; without even the implied warranty of
	MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
	GNU General Public License for more details.

	You should have received a copy of the GNU General Public License
	along with AstroMenace. If not, see <http://www.gnu.org/licenses/>.


	Web Site: http://www.viewizard.com/
	Project: http://sourceforge.net/projects/openastromenace/
	E-mail: viewizard@viewizard.com

*************************************************************************************/


#ifndef COLLISIONDETECTION_H
#define COLLISIONDETECTION_H


#include "../Base.h"
#include "../Math/Math.h"
#include "../Model3D/Model3D.h"



// Важно! Расположение точек в OBB и AABB в момент инициализации
//
//	VECTOR3D OBB[8], AABB[8];
//
//	OBB[0] = AABB[0] = VECTOR3D(MaxX, MaxY, MaxZ);
//	OBB[1] = AABB[1] = VECTOR3D(MinX, MaxY, MaxZ);
//	OBB[2] = AABB[2] = VECTOR3D(MinX, MaxY, MinZ);
//	OBB[3] = AABB[3] = VECTOR3D(MaxX, MaxY, MinZ);
//	OBB[4] = AABB[4] = VECTOR3D(MaxX, MinY, MaxZ);
//	OBB[5] = AABB[5] = VECTOR3D(MinX, MinY, MaxZ);
//	OBB[6] = AABB[6] = VECTOR3D(MinX, MinY, MinZ);
//	OBB[7] = AABB[7] = VECTOR3D(MaxX, MinY, MinZ);



// проверка на попадание точки в треугольник
bool vw_PointInTriangle(VECTOR3D point, VECTOR3D pa, VECTOR3D pb, VECTOR3D pc);



// Проверка столкновения Sphere-Sphere
bool vw_SphereSphereCollision(float Object1Radius, VECTOR3D Object1Location,
							float Object2Radius, VECTOR3D Object2Location, VECTOR3D Object2PrevLocation);
// Проверка столкновений Sphere-AABB
bool vw_SphereAABBCollision(VECTOR3D Object1AABB[8], VECTOR3D Object1Location,
							float Object2Radius, VECTOR3D Object2Location, VECTOR3D Object2PrevLocation);
// Проверка столкновений Sphere-OBB
bool vw_SphereOBBCollision(VECTOR3D Object1OBB[8], VECTOR3D Object1OBBLocation, VECTOR3D Object1Location, float Object1RotationMatrix[9],
							float Object2Radius, VECTOR3D Object2Location, VECTOR3D Object2PrevLocation);
// Проверка столкновений Sphere-Mesh
bool vw_SphereMeshCollision(VECTOR3D Object1Location, eObjectBlock *Object1DrawObjectList, float Object1RotationMatrix[9],
							float Object2Radius, VECTOR3D Object2Location, VECTOR3D Object2PrevLocation,
							VECTOR3D *CollisionLocation);



// Проверка столкновений AABB-AABB
bool vw_AABBAABBCollision(VECTOR3D Object1AABB[8], VECTOR3D Object1Location, VECTOR3D Object2AABB[8], VECTOR3D Object2Location);


// Проверка столкновений OBB-OBB
bool vw_OBBOBBCollision(VECTOR3D Object1OBB[8], VECTOR3D Object1OBBLocation, VECTOR3D Object1Location, float Object1RotationMatrix[9],
						VECTOR3D Object2OBB[8], VECTOR3D Object2OBBLocation, VECTOR3D Object2Location, float Object2RotationMatrix[9]);




#endif // COLLISIONDETECTION_H