source: GTP/trunk/App/Demos/Vis/FriendlyCulling/src/Polyhedron.h @ 2913

Revision 2913, 2.2 KB checked in by mattausch, 16 years ago (diff)
Line 
1#ifndef _POLYHEDRON_H__
2#define _POLYHEDRON_H__
3
4
5#include "common.h"
6#include "AxisAlignedBox3.h"
7#include "Polygon3.h"
8
9#include <iostream>
10
11
12
13namespace CHCDemoEngine
14{
15
16class Plane3;
17class AxisAlignedBox3;
18class Vector3;
19
20
21/** Class representing a convex polyhedron.
22*/
23class Polyhedron
24{
25public:
26       
27        Polyhedron();
28        /** Copy constructor making a deep copy of the polygons.
29        */
30        Polyhedron(const Polyhedron &rhs);
31        /** Initialises the Polyhedron with the given polygons.
32                @NOTE The polygons are NOT duplicated, only
33                a shallow copy is used.
34        */     
35    Polyhedron(const PolygonContainer &polys);
36
37        ~Polyhedron();
38        /** Computes the intersection of the polyhedron with the given plane
39                @returns NULL if the geometry is not split by this plane
40        */
41        Polyhedron *CalcIntersection(const Plane3 &splitPlane) const;
42        /** Adds a polygon to the polyhedron.
43        */
44        void Add(Polygon3 *poly);
45        /** Computes bounding box of the geometry.
46        */
47        AxisAlignedBox3 GetBoundingBox() const;
48        /** Returns
49                1 if geometry in front of the plane
50                0 if plane intersects geometry,
51                -1 if geometry is behind the plane
52        */
53        int Side(const Plane3 &plane) const;
54        /** Returns true if this geometry is well shaped.
55        */
56        bool Valid() const;
57        /** Number of polygons.
58        */
59        int NumPolygons() const;
60        /** Returns the polygons in a container.
61        */
62        const PolygonContainer &GetPolygons() const;
63
64        float GetArea() const;
65
66        float GetVolume() const;
67
68        Vector3 CenterOfMass() const;
69        /** Returns all the vertices of this polyhedron
70        */
71        void CollectVertices(VertexArray &vertices) const;
72       
73        inline friend std::ostream &operator<<(std::ostream &s, const Polyhedron &a);
74
75protected:
76
77        /** Splits the given polygon with the polyhedron
78                Returns the part of the polygon inside of the polyhedron.
79        */
80        Polygon3 *SplitPolygon(Polygon3 *polygon) const;
81
82       
83       
84        ///////////////
85
86        /// the polygons
87        PolygonContainer mPolygons;
88        /// the bounding box
89        AxisAlignedBox3 mBox;
90};
91
92
93std::ostream &operator<<(std::ostream &s, const Polyhedron &a)
94{
95        PolygonContainer::const_iterator it, it_end = a.mPolygons.end();
96
97        for (it = a.mPolygons.begin(); it != it_end; ++ it)
98                s << *(*it) << std::endl;
99        return s << std::endl;
100}
101
102
103}
104
105#endif
Note: See TracBrowser for help on using the repository browser.