00001 #ifndef COIN_SBPROJECTOR_H
00002 #define COIN_SBPROJECTOR_H
00003
00004
00005
00006
00007
00008
00009
00010
00011
00012
00013
00014
00015
00016
00017
00018
00019
00020
00021
00022
00023
00024
00025
00026
00027 #include <Inventor/SbVec3f.h>
00028 #include <Inventor/SbLine.h>
00029 #include <Inventor/SbMatrix.h>
00030 #include <Inventor/SbViewVolume.h>
00031
00032 class SbVec2f;
00033
00034 class COIN_DLL_API SbProjector {
00035 public:
00036 virtual SbVec3f project(const SbVec2f & point) = 0;
00037 virtual void setViewVolume(const SbViewVolume & vol);
00038 const SbViewVolume & getViewVolume(void) const;
00039 virtual void setWorkingSpace(const SbMatrix & space);
00040 const SbMatrix & getWorkingSpace(void) const;
00041 virtual SbProjector * copy(void) const = 0;
00042
00043 protected:
00044 SbProjector(void);
00045 virtual ~SbProjector() { }
00046
00047 SbLine getWorkingLine(const SbVec2f & point) const;
00048
00049 SbViewVolume viewVol;
00050 SbMatrix worldToWorking, workingToWorld;
00051
00052 float findVanishingDistance(void) const;
00053 SbBool verifyProjection(const SbVec3f & projpt) const;
00054 };
00055
00056 #endif // !COIN_SBPROJECTOR_H