home *** CD-ROM | disk | FTP | other *** search
/ Hackers Magazine 57 / CdHackersMagazineNr57.iso / Software / Multimedia / k3d-setup-0.7.11.0.exe / include / k3d / k3dsdk / plane.h < prev    next >
Encoding:
C/C++ Source or Header  |  2008-11-07  |  1.9 KB  |  64 lines

  1. #ifndef K3DSDK_PLANE_H
  2. #define K3DSDK_PLANE_H
  3.  
  4. // K-3D
  5. // Copyright (c) 1995-2006, Timothy M. Shead
  6. //
  7. // Contact: tshead@k-3d.com
  8. //
  9. // This library is free software; you can redistribute it and/or
  10. // modify it under the terms of the GNU General Public
  11. // License as published by the Free Software Foundation; either
  12. // version 2 of the License, or (at your option) any later version.
  13. //
  14. // This library is distributed in the hope that it will be useful,
  15. // but WITHOUT ANY WARRANTY; without even the implied warranty of
  16. // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
  17. // General Public License for more details.
  18. //
  19. // You should have received a copy of the GNU General Public
  20. // License along with this library; if not, write to the Free Software
  21. // Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307  USA
  22.  
  23. /** \file
  24.     \author Tim Shead (tshead@k-3d.com)
  25. */
  26.  
  27. #include "vector3.h"
  28.  
  29. namespace k3d
  30. {
  31.  
  32. class matrix4;
  33. class point3;
  34.  
  35. /// Encapsulates a 3D plane surface
  36. class plane
  37. {
  38. public:
  39.     /// Constructs a plane from its normal and distance from the origin
  40.     plane(const vector3& Normal, const double Distance);
  41.     /// Constructs a plane from its normal and one point located within the plane
  42.     plane(const vector3& Normal, const point3& Point);
  43.     /// Constructs a plane from three points contained within the plane
  44.     plane(const point3& PointA, const point3& PointB, const point3& PointC);
  45.  
  46.     /// Stores the plane's normal vector
  47.     vector3 normal;
  48.     /// Stores the plane's distance from the origin
  49.     double distance;
  50. };
  51.  
  52. std::ostream& operator<<(std::ostream& Stream, const plane& RHS);
  53. std::istream& operator>>(std::istream& Stream, plane& RHS);
  54.  
  55. /// Linear transformation if a plane by a transformation matrix
  56. const plane operator*(const matrix4& Matrix, const plane& Plane);
  57. /// Linear transformation if a plane by a transformation matrix
  58. const plane operator*(const plane& Plane, const matrix4& Matrix);
  59.  
  60. } // namespace k3d
  61.  
  62. #endif // !K3DSDK_PLANE_H
  63.  
  64.