source: molecuilder/src/Plane.hpp@ c53e0b

Last change on this file since c53e0b was 465abf, checked in by Tillmann Crueger <crueger@…>, 15 years ago

Added a method that allows construction of three arbitrary points on a plane.

  • Property mode set to 100644
File size: 1.1 KB
Line 
1/*
2 * Plane.hpp
3 *
4 * Created on: Apr 7, 2010
5 * Author: crueger
6 */
7
8#ifndef PLANE_HPP_
9#define PLANE_HPP_
10
11#include <memory>
12#include <vector>
13
14class Vector;
15
16class Plane
17{
18 typedef std::auto_ptr<Vector> vec_ptr;
19public:
20 Plane(const Vector &y1, const Vector &y2, const Vector &y3);
21 Plane(const Vector &y1, const Vector &y2, double _offset);
22 Plane(const Vector &_normalVector, double _offset=0);
23 Plane(const Vector &_normalVector, const Vector &_offsetVector);
24 virtual ~Plane();
25
26 // Accessor Functions
27 /**
28 * returns normal Vector for a plane
29 */
30 Vector getNormal();
31 /**
32 * returns the distance of the plane from the origin
33 */
34 double getOffset();
35 /**
36 * returns a vector that points on the plane.
37 * Same as getOffset()*getNormal();
38 */
39 Vector getOffsetVector();
40
41 /**
42 * returns three seperate points on this plane
43 */
44 std::vector<Vector> getPointsOnPlane();
45
46 // some calculations
47 Vector GetIntersection(const Vector &Origin, const Vector &LineVector);
48
49private:
50 vec_ptr normalVector;
51 double offset;
52};
53
54#endif /* PLANE_HPP_ */
Note: See TracBrowser for help on using the repository browser.