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) by Kongsberg Oil & Gas Technologies.
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 Kongsberg Oil & Gas Technologies
18  * about acquiring a Coin Professional Edition License.
19  *
20  * See http://www.coin3d.org/ for more information.
21  *
22  * Kongsberg Oil & Gas Technologies, Bygdoy Alle 5, 0257 Oslo, NORWAY.
23  * http://www.sim.no/ sales@sim.no coin-support@coin3d.org
24  *
25 \**************************************************************************/
26 
27 #include <Inventor/tools/SbLazyPimplPtr.h>
28 #include <Inventor/nodes/SoSubNode.h>
29 #include <Inventor/nodes/SoSeparator.h>
30 #include <Inventor/SbMatrix.h>
31 #include <Inventor/fields/SoSFVec3d.h>
32 #include <Inventor/fields/SoMFString.h>
33 
34 class SoState;
35 class SoGeoSeparatorP;
36 
37 class COIN_DLL_API SoGeoSeparator : public SoSeparator {
38  typedef SoSeparator inherited;
39 
41 
42 public:
43  static void initClass(void);
44  SoGeoSeparator(void);
45 
48 
49  virtual void callback(SoCallbackAction * action);
50  virtual void GLRenderBelowPath(SoGLRenderAction * action);
51  virtual void GLRenderInPath(SoGLRenderAction * action);
52  virtual void getBoundingBox(SoGetBoundingBoxAction * action);
53  virtual void getMatrix(SoGetMatrixAction * action);
54  virtual void rayPick(SoRayPickAction * action);
55  virtual void getPrimitiveCount(SoGetPrimitiveCountAction * action);
56 
57 protected:
58  virtual ~SoGeoSeparator(void);
59 
60 private:
61  SoGeoSeparator(const SoGeoSeparator & rhs);
62  SoGeoSeparator & operator = (const SoGeoSeparator & rhs);
63 
64  void applyTransformation(SoAction * action);
65  SbMatrix getTransform(SoState * state) const;
66 
67  SbLazyPimplPtr<SoGeoSeparatorP> pimpl;
68 
69 };
70 
71 
72 #endif // COIN_SOGEOSEPARATOR_H

Copyright © 1998-2010 by Kongsberg Oil & Gas Technologies. All rights reserved.

Generated for Coin by Doxygen 1.8.1.