home *** CD-ROM | disk | FTP | other *** search
/ Photo CD Demo 1 / Demo.bin / graphtal / plane.h < prev    next >
C/C++ Source or Header  |  1992-10-22  |  1KB  |  45 lines

  1. /*
  2.  * Plane.h - class definition for geometric object plane.
  3.  *
  4.  * Copyright (C) 1992, Christoph Streit (streit@iam.unibe.ch)
  5.  * All rights reserved.
  6.  *
  7.  * This software may be freely copied, modified, and redistributed
  8.  * provided that this copyright notice is preserved on all copies.
  9.  *
  10.  * You may not distribute this software, in whole or in part, as part of
  11.  * any commercial product without the express consent of the authors.
  12.  *
  13.  * There is no warranty or other guarantee of fitness of this software
  14.  * for any purpose.  It is provided solely "as is".
  15.  *
  16.  */
  17.  
  18. #ifndef Plane_H
  19. # define Plane_H
  20.  
  21. #include "GeoObject.h"
  22.  
  23. //___________________________________________________________ Plane
  24.  
  25. class Plane : public GeoObject 
  26. {
  27. public:
  28.   static GeoObject* create(const Vector&, const Vector&);
  29.  
  30.   int intersect(const Ray&, real, real&);
  31.   Vector normal(const Vector&) const;
  32.   PolygonList* tesselate(const BoundingBox&);
  33.  
  34. private:
  35.   Plane(const Vector&, const Vector&);
  36.   int intersectPlaneWithSegment(const Vector&, const Vector&, Vector&);
  37.  
  38. private:
  39.   Vector n;   // plane normal
  40.   Vector pos; // point on the plane
  41.   real D;     // plane constant
  42. };
  43.  
  44. #endif // Plane_H
  45.