source: GTP/trunk/Lib/Vis/Preprocessing/src/Triangle3.h @ 1328

Revision 1328, 796 bytes checked in by mattausch, 18 years ago (diff)
Line 
1#ifndef __TRIANGLE3_H
2#define __TRIANGLE3_H
3
4#include "Vector3.h"
5
6
7namespace GtpVisibilityPreprocessor {
8
9class AxisAlignedBox3;
10class Ray;
11
12
13struct Triangle3
14{
15        Triangle3() {};
16        Triangle3(const Vector3 &a, const Vector3 &b, const Vector3 &c);
17
18        void Init(const Vector3 &a, const Vector3 &b, const Vector3 &c);
19
20        Vector3 GetNormal() const;
21
22        Vector3 GetCenter() const;
23
24        float GetSpatialAngle(const Vector3 &point) const;
25
26        float GetArea() const;
27
28        /// returns bounding box around this triangle
29        AxisAlignedBox3 GetBoundingBox() const;
30
31        /// Casts ray into this triangle. Returns hit
32        int CastRay(const Ray &ray, float &t, const float nearestT) const;
33
34        //////////////////////////////
35
36        /// the triangle vertices
37        Vector3 mVertices[3];
38};
39
40}
41
42#endif
43
Note: See TracBrowser for help on using the repository browser.