Open Inventor Reference
MeVis/ThirdParty/Sources/Inventor/inventor/lib/database/include/Inventor/projectors/SbCylinderSectionProjector.h
Go to the documentation of this file.
00001 /*
00002  *
00003  *  Copyright (C) 2000 Silicon Graphics, Inc.  All Rights Reserved. 
00004  *
00005  *  This library is free software; you can redistribute it and/or
00006  *  modify it under the terms of the GNU Lesser General Public
00007  *  License as published by the Free Software Foundation; either
00008  *  version 2.1 of the License, or (at your option) any later version.
00009  *
00010  *  This library is distributed in the hope that it will be useful,
00011  *  but WITHOUT ANY WARRANTY; without even the implied warranty of
00012  *  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
00013  *  Lesser General Public License for more details.
00014  *
00015  *  Further, this software is distributed without any warranty that it is
00016  *  free of the rightful claim of any third person regarding infringement
00017  *  or the like.  Any license provided herein, whether implied or
00018  *  otherwise, applies only to this software file.  Patent licenses, if
00019  *  any, provided herein do not apply to combinations of this program with
00020  *  other software, or any other product whatsoever.
00021  * 
00022  *  You should have received a copy of the GNU Lesser General Public
00023  *  License along with this library; if not, write to the Free Software
00024  *  Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307  USA
00025  *
00026  *  Contact information: Silicon Graphics, Inc., 1600 Amphitheatre Pkwy,
00027  *  Mountain View, CA  94043, or:
00028  * 
00029  *  http://www.sgi.com 
00030  * 
00031  *  For further information regarding this notice, see: 
00032  * 
00033  *  http://oss.sgi.com/projects/GenInfo/NoticeExplan/
00034  *
00035  */
00036 
00037 
00038 /*
00039  * Copyright (C) 1990,91,92   Silicon Graphics, Inc.
00040  *
00041  _______________________________________________________________________
00042  ______________  S I L I C O N   G R A P H I C S   I N C .  ____________
00043  |
00044  |   $Revision: 1.1.1.1 $
00045  |
00046  |   Description:
00047  |      This file contains the definition of the SbCylinderSectionProjector
00048  |      class. This projector projects the mouse position onto the
00049  |      section of a cylinder that has been sliced by a plane.
00050  |
00051  |      The tolerance slice can be specified as a fraction of the radius
00052  |      of the cylinder. The projection point will not extend beyond the
00053  |      sliced portion of the cylinder.
00054  |
00055  |   Author(s)          : Howard Look, Paul Isaacs
00056  |
00057  ______________  S I L I C O N   G R A P H I C S   I N C .  ____________
00058  _______________________________________________________________________
00059  */
00060 
00061 #ifndef _SB_CYLINDER_SECTION_PROJECTOR_
00062 #define _SB_CYLINDER_SECTION_PROJECTOR_
00063 
00064 #include <Inventor/projectors/SbCylinderProjector.h>
00065 
00068 
00089 
00090 
00091 class INVENTOR_API SbCylinderSectionProjector : public SbCylinderProjector
00092 {
00093   public:
00100     SbCylinderSectionProjector(float  edgeTol = .9,
00101                                SbBool orientToEye = TRUE);
00102 
00104     SbCylinderSectionProjector( const SbCylinder &cyl,
00105                                 float edgeTol = .9,
00106                                 SbBool orientToEye = TRUE);
00107 
00109     ~SbCylinderSectionProjector() {}
00110     
00113     virtual SbProjector *    copy() const;
00114 
00118     virtual SbVec3f     project(const SbVec2f &point);
00119 
00121     virtual SbRotation  getRotation(const SbVec3f &point1,
00122                                     const SbVec3f &point2);
00123 
00125     void                setTolerance(float edgeTol);
00126 
00131     float               getTolerance() const              { return tolerance; }
00132 
00135     SbBool              isWithinTolerance(const SbVec3f &point);
00136     
00137   protected:
00139     virtual void        setupTolerance();
00140 
00142     float               tolerance;  
00143     float               tolDist;    
00144     
00146     SbVec3f     planeDir;               
00147     SbLine      planeLine;              
00148     float       planeDist;              
00149     SbPlane     tolPlane;               
00150 };
00151 
00152 #endif /* _SB_CYLINDER_SECTION_PROJECTOR_ */
00153