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

SoClipPlaneManip.h
1#ifndef COIN_SOCLIPPLANEMANIP_H
2#define COIN_SOCLIPPLANEMANIP_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/SoClipPlane.h>
28#include <Inventor/fields/SoSFVec3f.h>
29
30class SbBox3f;
31class SoChildList;
32class SoDragger;
33class SoFieldSensor;
34class SoPath;
35class SoSensor;
36
37
38class COIN_DLL_API SoClipPlaneManip : public SoClipPlane {
39 typedef SoClipPlane inherited;
40
41 SO_NODE_HEADER(SoClipPlaneManip);
42
43public:
44 static void initClass(void);
45 SoClipPlaneManip(void);
46
47 SoDragger * getDragger(void);
48 void setValue(const SbBox3f & box, const SbVec3f & planenormal,
49 float draggerscalefactor);
50 SbBool replaceNode(SoPath * p);
51 SbBool replaceManip(SoPath * p, SoClipPlane * newone) const;
52
53 virtual void doAction(SoAction * action);
54 virtual void callback(SoCallbackAction * action);
55 virtual void GLRender(SoGLRenderAction * action);
56 virtual void getBoundingBox(SoGetBoundingBoxAction * action);
57 virtual void getMatrix(SoGetMatrixAction * action);
58 virtual void handleEvent(SoHandleEventAction * action);
59 virtual void pick(SoPickAction * action);
60 virtual void search(SoSearchAction * action);
61
62 virtual SoChildList * getChildren(void) const;
63
65
66protected:
68
69 void setDragger(SoDragger * newdragger);
70
71 virtual void copyContents(const SoFieldContainer * fromfc, SbBool copyconnections);
72 static void valueChangedCB(void * f, SoDragger * d);
73 static void fieldSensorCB(void * f, SoSensor * d);
74 static void transferFieldValues(const SoClipPlane * from, SoClipPlane * to);
75
80
81private:
82 void attachSensors(const SbBool onoff);
83
84};
85
86#endif // !COIN_SOCLIPPLANEMANIP_H
The SbBox3f class is an abstraction for an axis aligned 3 dimensional box.
Definition SbBox3f.h:37
The SbVec3f class is a 3 dimensional vector with floating point coordinates.
Definition SbVec3f.h:37
The SoAction class is the base class for all traversal actions.
Definition SoAction.h:67
The SoCallbackAction class invokes callbacks at specific nodes.
Definition SoCallbackAction.h:70
The SoChildList class is a container for node children.
Definition SoChildList.h:33
SoDragger * getDragger(void)
Definition SoClipPlaneManip.cpp:236
SbBool replaceManip(SoPath *p, SoClipPlane *newone) const
Definition commoncode.cpp:163
SoChildList * children
Definition SoClipPlaneManip.h:79
SoClipPlaneManip(void)
Definition SoClipPlaneManip.cpp:176
void setValue(const SbBox3f &box, const SbVec3f &planenormal, float draggerscalefactor)
Definition SoClipPlaneManip.cpp:268
SoSFVec3f draggerPosition
Definition SoClipPlaneManip.h:64
static void valueChangedCB(void *f, SoDragger *d)
Definition SoClipPlaneManip.cpp:481
SoFieldSensor * planeFieldSensor
Definition SoClipPlaneManip.h:76
static void fieldSensorCB(void *f, SoSensor *d)
Definition SoClipPlaneManip.cpp:510
static void transferFieldValues(const SoClipPlane *from, SoClipPlane *to)
Definition SoClipPlaneManip.cpp:567
SoFieldSensor * draggerPosFieldSensor
Definition SoClipPlaneManip.h:78
void setDragger(SoDragger *newdragger)
Definition SoClipPlaneManip.cpp:218
SoFieldSensor * onFieldSensor
Definition SoClipPlaneManip.h:77
SbBool replaceNode(SoPath *p)
Definition SoClipPlaneManip.cpp:299
virtual void pick(SoPickAction *action)
Definition SoClipPlane.cpp:194
virtual void doAction(SoAction *action)
Definition SoClipPlane.cpp:165
virtual void GLRender(SoGLRenderAction *action)
Definition SoClipPlane.cpp:174
SoClipPlane(void)
Definition SoClipPlane.cpp:137
virtual void callback(SoCallbackAction *action)
Definition SoClipPlane.cpp:187
The SoDragger class is the base class for all draggers.
Definition SoDragger.h:53
SoFieldContainer(void)
Definition SoFieldContainer.cpp:101
The SoFieldSensor class detects changes to a field.
Definition SoFieldSensor.h:29
The SoGLRenderAction class renders the scene graph with OpenGL calls.
Definition SoGLRenderAction.h:39
The SoGetBoundingBoxAction class calculates bounding boxes for nodes and subgraphs.
Definition SoGetBoundingBoxAction.h:34
The SoGetMatrixAction class is an action for accumulating the transformation matrix of a subgraph.
Definition SoGetMatrixAction.h:35
The SoHandleEventAction class distributes user events to the scene.
Definition SoHandleEventAction.h:36
virtual SoChildList * getChildren(void) const
Definition SoNode.cpp:1265
virtual void handleEvent(SoHandleEventAction *action)
Definition SoNode.cpp:1031
virtual void getBoundingBox(SoGetBoundingBoxAction *action)
Definition SoNode.cpp:817
virtual void getMatrix(SoGetMatrixAction *action)
Definition SoNode.cpp:1001
virtual void copyContents(const SoFieldContainer *from, SbBool copyconnections)
Definition SoNode.cpp:1382
virtual void search(SoSearchAction *action)
Definition SoNode.cpp:1120
The SoPath class is a container class for traversal path descriptions.
Definition SoPath.h:43
The SoPickAction class is the base class for picking actions.
Definition SoPickAction.h:32
The SoSFVec3f class is a container for an SbVec3f vector.
Definition SoSFVec3f.h:31
The SoSearchAction class provides methods for searching through scene graphs.
Definition SoSearchAction.h:32
The SoSensor class is the abstract base class for all sensors.
Definition SoSensor.h:34

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

Generated on Thu Jan 16 2025 for Coin by Doxygen. 1.13.2