Coin Logo http://www.sim.no
http://www.coin3d.org

SoGeoSeparator.h
1 #ifndef COIN_SOGEOSEPARATOR_H
2 #define COIN_SOGEOSEPARATOR_H
3 
4 /**************************************************************************\
5  *
6  * This file is part of the Coin 3D visualization library.
7  * Copyright (C) 1998-2007 by Systems in Motion. All rights reserved.
8  *
9  * This library is free software; you can redistribute it and/or
10  * modify it under the terms of the GNU General Public License
11  * ("GPL") version 2 as published by the Free Software Foundation.
12  * See the file LICENSE.GPL at the root directory of this source
13  * distribution for additional information about the GNU GPL.
14  *
15  * For using Coin with software that can not be combined with the GNU
16  * GPL, and for taking advantage of the additional benefits of our
17  * support services, please contact Systems in Motion about acquiring
18  * a Coin Professional Edition License.
19  *
20  * See http://www.coin3d.org/ for more information.
21  *
22  * Systems in Motion, Postboks 1283, Pirsenteret, 7462 Trondheim, NORWAY.
23  * http://www.sim.no/ sales@sim.no coin-support@coin3d.org
24  *
25 \**************************************************************************/
26 
27 #include <Inventor/nodes/SoSubNode.h>
28 #include <Inventor/nodes/SoSeparator.h>
29 #include <Inventor/SbMatrix.h>
30 #include <Inventor/fields/SoSFVec3d.h>
31 #include <Inventor/fields/SoMFString.h>
32 
33 class SoState;
34 class SoGeoSeparatorP;
35 
36 class COIN_DLL_API SoGeoSeparator : public SoSeparator {
37  typedef SoSeparator inherited;
38 
39  SO_NODE_HEADER(SoGeoSeparator);
40 
41 public:
42  static void initClass(void);
43  SoGeoSeparator(void);
44 
47 
48  virtual void callback(SoCallbackAction * action);
49  virtual void GLRenderBelowPath(SoGLRenderAction * action);
50  virtual void GLRenderInPath(SoGLRenderAction * action);
51  virtual void getBoundingBox(SoGetBoundingBoxAction * action);
52  virtual void getMatrix(SoGetMatrixAction * action);
53  virtual void rayPick(SoRayPickAction * action);
54  virtual void getPrimitiveCount(SoGetPrimitiveCountAction * action);
55 
56 protected:
57  virtual ~SoGeoSeparator();
58 
59 private:
60  void applyTransformation(SoAction * action);
61  SbMatrix getTransform(SoState * state) const;
62 
63  SoGeoSeparatorP * pimpl;
64 };
65 
66 
67 #endif // COIN_SOGEOSEPARATOR_H
SoState
The SoState class manages the Coin scenegraph traversal state data.
Definition: SoState.h:35
SoMField::getNum
int getNum(void) const
Definition: SoMField.h:86
SoGeoSeparator::getBoundingBox
virtual void getBoundingBox(SoGetBoundingBoxAction *action)
Definition: SoGeoSeparator.cpp:158
SoState::pop
void pop(void)
Definition: SoState.cpp:284
SbMatrix
The SbMatrix class is a 4x4 dimensional representation of a matrix.
Definition: SbMatrix.h:37
SoGeoSeparator::rayPick
virtual void rayPick(SoRayPickAction *action)
Definition: SoGeoSeparator.cpp:199
SoDebugError::post
static void post(const char *const source, const char *const format,...)
Definition: SoDebugError.cpp:314
SoSeparator::getBoundingBox
virtual void getBoundingBox(SoGetBoundingBoxAction *action)
Definition: SoSeparator.cpp:461
SoGeoOrigin
The SoGeoOrigin class is used to specify an absolute geographic location against which geometry is re...
Definition: SoGeoOrigin.h:34
SoSeparator::GLRenderInPath
virtual void GLRenderInPath(SoGLRenderAction *action)
Definition: SoSeparator.cpp:692
SoNode::VRML1
@ VRML1
Definition: SoNode.h:61
SoNode::rayPickS
static void rayPickS(SoAction *action, SoNode *node)
Definition: SoNode.cpp:1067
SoState::push
void push(void)
Definition: SoState.cpp:265
SoGeoOrigin::geoCoords
SoSFVec3d geoCoords
Definition: SoGeoOrigin.h:43
SbVec3d::getValue
const double * getValue(void) const
Definition: SbVec3d.cpp:206
SoGetMatrixAction::getInverse
SbMatrix & getInverse(void)
Definition: SoGetMatrixAction.cpp:160
SoGeoSeparator::callback
virtual void callback(SoCallbackAction *action)
Definition: SoGeoSeparator.cpp:186
SbMatrix::inverse
SbMatrix inverse(void) const
Definition: SbMatrix.cpp:418
SoAction
The SoAction class is the base class for all traversal actions.
Definition: SoAction.h:67
SoGeoSeparator::GLRenderBelowPath
virtual void GLRenderBelowPath(SoGLRenderAction *action)
Definition: SoGeoSeparator.cpp:136
SoSeparator::callback
virtual void callback(SoCallbackAction *action)
Definition: SoSeparator.cpp:559
SoGeoSeparator::getPrimitiveCount
virtual void getPrimitiveCount(SoGetPrimitiveCountAction *action)
Definition: SoGeoSeparator.cpp:212
SoSeparator::GLRenderBelowPath
virtual void GLRenderBelowPath(SoGLRenderAction *action)
Definition: SoSeparator.cpp:605
SoGeoSeparator::~SoGeoSeparator
virtual ~SoGeoSeparator()
Definition: SoGeoSeparator.cpp:112
SoSFVec3d
The SoSFVec3d class is a container for an SbVec3d vector.
Definition: SoSFVec3d.h:31
SoField::setDefault
void setDefault(SbBool def)
Definition: SoField.cpp:650
SoGetMatrixAction
The SoGetMatrixAction class is an action for accumulating the transformation matrix of a subgraph.
Definition: SoGetMatrixAction.h:35
SoGetMatrixAction::getMatrix
SbMatrix & getMatrix(void)
Definition: SoGetMatrixAction.cpp:151
SoGeoSeparator
The SoGeoSeparator class is used to georeference a scene graph.
Definition: SoGeoSeparator.h:36
SoGeoOrigin::geoSystem
SoMFString geoSystem
Definition: SoGeoOrigin.h:44
SoBase
The SoBase class is the top-level superclass for a number of class-hierarchies.
Definition: SoBase.h:41
SoAction::getState
SoState * getState(void) const
Definition: SoAction.cpp:1028
SoSeparator::getMatrix
virtual void getMatrix(SoGetMatrixAction *action)
Definition: SoSeparator.cpp:812
SoMFString
The SoMFString class is a container for SbString values.
Definition: SoMFString.h:31
SoGetBoundingBoxAction
The SoGetBoundingBoxAction class calculates bounding boxes for nodes and subgraphs.
Definition: SoGetBoundingBoxAction.h:34
SoMFString::getValues
const SbString * getValues(const int start) const
Definition: SoMFString.h:34
SoGeoSeparator::GLRenderInPath
virtual void GLRenderInPath(SoGLRenderAction *action)
Definition: SoGeoSeparator.cpp:147
SoCallbackAction
The SoCallbackAction class invokes callbacks at specific nodes.
Definition: SoCallbackAction.h:70
SoRayPickAction::addMethod
static void addMethod(const SoType type, SoActionMethod method)
Definition: SoRayPickAction.cpp:225
SoSeparator::rayPick
virtual void rayPick(SoRayPickAction *action)
Definition: SoSeparator.cpp:787
SoSeparator::getPrimitiveCount
virtual void getPrimitiveCount(SoGetPrimitiveCountAction *action)
Definition: SoSeparator.cpp:871
SoSeparator
The SoSeparator class is a state-preserving group node.
Definition: SoSeparator.h:34
SoMField::setNum
void setNum(const int num)
Definition: SoMField.cpp:615
SoGeoSeparator::getMatrix
virtual void getMatrix(SoGetMatrixAction *action)
Definition: SoGeoSeparator.cpp:177
SbMatrix::identity
static SbMatrix identity(void)
Definition: SbMatrix.cpp:748
SoGeoSeparator::geoCoords
SoSFVec3d geoCoords
Definition: SoGeoSeparator.h:45
SoRayPickAction
The SoRayPickAction class does ray intersection with scene graphs.
Definition: SoRayPickAction.h:40
SoGeoSeparator::geoSystem
SoMFString geoSystem
Definition: SoGeoSeparator.h:46
SoGLRenderAction
The SoGLRenderAction class renders the scene graph with OpenGL calls.
Definition: SoGLRenderAction.h:39
SoGeoSeparator::SoGeoSeparator
SoGeoSeparator(void)
Definition: SoGeoSeparator.cpp:96
SoGetPrimitiveCountAction
The SoGetPrimitiveCountAction class counts the primitives in a scene.
Definition: SoGetPrimitiveCountAction.h:32

Copyright © 1998-2007 by Systems in Motion AS. All rights reserved.

Generated on Mon Jul 27 2020 for Coin by Doxygen. 1.8.18