fix cr/lfs and remove trailing whitespaces...
[supertux.git] / src / collision.hpp
1 //  $Id$
2 //
3 //  SuperTux
4 //  Copyright (C) 2006 Matthias Braun <matze@braunis.de>
5 //
6 //  This program is free software; you can redistribute it and/or
7 //  modify it under the terms of the GNU General Public License
8 //  as published by the Free Software Foundation; either version 2
9 //  of the License, or (at your option) any later version.
10 //
11 //  This program is distributed in the hope that it will be useful,
12 //  but WITHOUT ANY WARRANTY; without even the implied warranty of
13 //  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
14 //  GNU General Public License for more details.
15 //
16 //  You should have received a copy of the GNU General Public License
17 //  along with this program; if not, write to the Free Software
18 //  Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA
19 //  02111-1307, USA.
20 #ifndef __COLLISION_H__
21 #define __COLLISION_H__
22
23 #include <float.h>
24 #include "collision_hit.hpp"
25
26 class Vector;
27 class Rect;
28 class AATriangle;
29
30 namespace collision
31 {
32
33 class Constraints
34 {
35 public:
36   Constraints() {
37     left = -INFINITY;
38     right = INFINITY;
39     top = -INFINITY;
40     bottom = INFINITY;
41   }
42
43   bool has_constraints() const {
44     return left > -INFINITY || right < INFINITY
45         || top > -INFINITY || bottom < INFINITY;
46   }
47
48   float left;
49   float right;
50   float top;
51   float bottom;
52   Vector ground_movement;
53   CollisionHit hit;
54 };
55
56 /** checks if 2 rectangle intersect each other */
57 bool intersects(const Rect& r1, const Rect& r2);
58
59 /** does collision detection between a rectangle and an axis aligned triangle
60  * Returns true in case of a collision and fills in the hit structure then.
61  */
62 bool rectangle_aatriangle(Constraints* constraints, const Rect& rect,
63                                    const AATriangle& triangle);
64
65 void set_rectangle_rectangle_constraints(Constraints* constraints,
66         const Rect& r1, const Rect& r2);
67
68 }
69
70 #endif