Open Inventor Reference
MeVis/ThirdParty/Sources/Inventor/inventor/lib/database/include/Inventor/SoPickedPoint.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   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 defines the base SoPickedPoint class.
00048  |
00049  |   Author(s)          : Paul S. Strauss
00050  |
00051  ______________  S I L I C O N   G R A P H I C S   I N C .  ____________
00052  _______________________________________________________________________
00053  */
00054 
00055 #ifndef _SO_PICKED_POINT_
00056 #define _SO_PICKED_POINT_
00057 
00058 #include <Inventor/SbLinear.h>
00059 #include <Inventor/SbViewportRegion.h>
00060 #include <Inventor/SoLists.h>
00061 
00062 class SoDetail;
00063 class SoGetMatrixAction;
00064 class SoPath;
00065 class SoState;
00066 
00067 
00070 
00087 
00088 
00089 class INVENTOR_API SoPickedPoint {
00090 
00091   public:
00092 
00094     SoPickedPoint(const SoPickedPoint &pp);
00095 
00097     ~SoPickedPoint();
00098 
00101     SoPickedPoint *     copy() const;
00102 
00105     const SbVec3f &     getPoint() const         { return worldPoint; }
00108     const SbVec3f &     getNormal() const        { return worldNormal; }
00111     const SbVec4f &     getTextureCoords() const { return imageTexCoords; }
00112 
00117     int                 getMaterialIndex() const { return materialIndex; }
00118 
00120     SoPath *            getPath() const          { return path; }
00121 
00125     SbBool              isOnGeometry() const     { return onGeometry; }
00126 
00133 
00139     const SoDetail *    getDetail(const SoNode *node = NULL) const;
00140 
00146 
00147 
00148     SbMatrix            getObjectToWorld(const SoNode *node = NULL) const;
00149     SbMatrix            getWorldToObject(const SoNode *node = NULL) const;
00150     SbMatrix            getObjectToImage(const SoNode *node = NULL) const;
00151     SbMatrix            getImageToObject(const SoNode *node = NULL) const;
00152     SbVec3f             getObjectPoint(const SoNode *node = NULL) const;
00153     SbVec3f             getObjectNormal(const SoNode *node = NULL) const;
00154     SbVec4f             getObjectTextureCoords(const SoNode *node=NULL) const;
00155 
00157 
00158   SoEXTENDER public:
00159 
00164 
00166     void                setObjectNormal(const SbVec3f &normal);
00167 
00169     void                setObjectTextureCoords(const SbVec4f &texCoords);
00170 
00172     void                setMaterialIndex(int index)  { materialIndex = index; }
00173 
00177     void                setDetail(SoDetail *detail, SoNode *node);
00178 
00179   SoINTERNAL public:
00180 
00182     SoPickedPoint(const SoPath *path, SoState *state,
00183                   const SbVec3f &objSpacePoint);
00184 
00185   private:
00187     static SoGetMatrixAction    *matrixAction;
00188 
00191     SbVec3f             worldPoint;
00192     SbVec3f             worldNormal;
00193     SbVec4f             imageTexCoords;
00194 
00196     SbViewportRegion    vpRegion;
00197 
00199     int                 materialIndex;
00200 
00202     SbBool              onGeometry;
00203 
00205     SoPath              *path;
00206 
00209     SoDetailList        details;
00210 
00215     SoState             *state;
00216 
00218     int                 getNodeIndex(const SoNode *node) const;
00219 
00221     void                getMatrix(const SoNode *node) const;
00222 
00224     static SbVec4f multVecMatrix4(const SbMatrix &m, const SbVec4f v);
00225 };
00226 
00227 #endif /* _SO_PICKED_POINT_ */