Coin Logo http://www.coin3d.org/
http://www.kongsberg.com/kogt/

SoCenterballDragger.h
1 #ifndef COIN_SOCENTERBALLDRAGGER_H
2 #define COIN_SOCENTERBALLDRAGGER_H
3 
4 /**************************************************************************\
5  * Copyright (c) Kongsberg Oil & Gas Technologies AS
6  * All rights reserved.
7  *
8  * Redistribution and use in source and binary forms, with or without
9  * modification, are permitted provided that the following conditions are
10  * met:
11  *
12  * Redistributions of source code must retain the above copyright notice,
13  * this list of conditions and the following disclaimer.
14  *
15  * Redistributions in binary form must reproduce the above copyright
16  * notice, this list of conditions and the following disclaimer in the
17  * documentation and/or other materials provided with the distribution.
18  *
19  * Neither the name of the copyright holder nor the names of its
20  * contributors may be used to endorse or promote products derived from
21  * this software without specific prior written permission.
22  *
23  * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
24  * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
25  * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
26  * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
27  * HOLDER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
28  * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
29  * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
30  * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
31  * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
32  * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
33  * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
34 \**************************************************************************/
35 
37 #include <Inventor/tools/SbLazyPimplPtr.h>
38 #include <Inventor/fields/SoSFRotation.h>
39 #include <Inventor/fields/SoSFVec3f.h>
40 
41 class SoSensor;
42 class SoFieldSensor;
43 class SoCenterballDraggerP;
44 
45 class COIN_DLL_API SoCenterballDragger : public SoDragger {
46  typedef SoDragger inherited;
47 
48  SO_KIT_HEADER(SoCenterballDragger);
49 
50  SO_KIT_CATALOG_ENTRY_HEADER(XAxis);
51  SO_KIT_CATALOG_ENTRY_HEADER(XAxisSwitch);
52  SO_KIT_CATALOG_ENTRY_HEADER(XCenterChanger);
53  SO_KIT_CATALOG_ENTRY_HEADER(XRotator);
54  SO_KIT_CATALOG_ENTRY_HEADER(YAxis);
55  SO_KIT_CATALOG_ENTRY_HEADER(YAxisSwitch);
56  SO_KIT_CATALOG_ENTRY_HEADER(YCenterChanger);
57  SO_KIT_CATALOG_ENTRY_HEADER(YRotator);
58  SO_KIT_CATALOG_ENTRY_HEADER(ZAxis);
59  SO_KIT_CATALOG_ENTRY_HEADER(ZAxisSwitch);
60  SO_KIT_CATALOG_ENTRY_HEADER(ZCenterChanger);
61  SO_KIT_CATALOG_ENTRY_HEADER(ZRotator);
62  SO_KIT_CATALOG_ENTRY_HEADER(antiSquish);
63  SO_KIT_CATALOG_ENTRY_HEADER(lightModel);
64  SO_KIT_CATALOG_ENTRY_HEADER(rot2X90);
65  SO_KIT_CATALOG_ENTRY_HEADER(rotX90);
66  SO_KIT_CATALOG_ENTRY_HEADER(rotY90);
67  SO_KIT_CATALOG_ENTRY_HEADER(rotator);
68  SO_KIT_CATALOG_ENTRY_HEADER(surroundScale);
69  SO_KIT_CATALOG_ENTRY_HEADER(translateToCenter);
70 
71 public:
72  static void initClass(void);
73  SoCenterballDragger(void);
74 
75  virtual void saveStartParameters(void);
76 
79 
80 protected:
81  virtual ~SoCenterballDragger(void);
82  void transferCenterDraggerMotion(SoDragger * childdragger);
83  void setSwitches(SoDragger * activechild);
84  virtual SbBool setUpConnections(SbBool onoff, SbBool doitalways = FALSE);
85  virtual void setDefaultOnNonWritingFields(void);
86 
87  static void fieldSensorCB(void * f, SoSensor * s);
88  static void valueChangedCB(void * f, SoDragger * d);
89  static void kidStartCB(void * f, SoDragger * d);
90  static void kidFinishCB(void * f, SoDragger * d);
91 
92  virtual void getBoundingBox(SoGetBoundingBoxAction * action);
93  virtual void getMatrix(SoGetMatrixAction * action);
94 
97 
98 private:
99  SbVec3f savedtransl;
100  SbVec3f savedcenter;
101  void addChildDragger(SoDragger *child);
102  void removeChildDragger(const char *childname);
103 
104 private:
105  SbLazyPimplPtr<SoCenterballDraggerP> pimpl;
106 
107  // NOT IMPLEMENTED:
109  SoCenterballDragger & operator & (const SoCenterballDragger & rhs);
110 }; // SoCenterballDragger
111 
112 #endif // !COIN_SOCENTERBALLDRAGGER_H
static void fieldSensorCB(void *, SoSensor *)
Definition: SoInteractionKit.cpp:751
virtual void getMatrix(SoGetMatrixAction *action)
Definition: SoDragger.cpp:531
The SoGetMatrixAction class is an action for accumulating the transformation matrix of a subgraph...
Definition: SoGetMatrixAction.h:46
The SoSFRotation class is a container for an SbRotation.This field is used where nodes, engines or other field containers needs to store a single rotation definition.
Definition: SoSFRotation.h:40
SoFieldSensor * centerFieldSensor
Definition: SoCenterballDragger.h:96
SoSFVec3f center
Definition: SoCenterballDragger.h:78
The SoCenterballDragger class is a dragger you can rotate and translate.Here&#39;s how the dragger looks ...
Definition: SoCenterballDragger.h:45
virtual void saveStartParameters(void)
Definition: SoDragger.cpp:988
virtual void getBoundingBox(SoGetBoundingBoxAction *action)
Definition: SoDragger.cpp:1779
The SoDragger class is the base class for all draggers.Draggers is a mechanism used for letting the e...
Definition: SoDragger.h:64
The SoSensor class is the abstract base class for all sensors.Sensors is a mechanism in Coin for sche...
Definition: SoSensor.h:43
SoSFRotation rotation
Definition: SoCenterballDragger.h:77
static void initClass(void)
Definition: SoDragger.cpp:407
The SbVec3f class is a 3 dimensional vector with floating point coordinates.This vector class is used...
Definition: SbVec3f.h:51
The SoFieldSensor class detects changes to a field.Attach a field to a sensor of this type to put it ...
Definition: SoFieldSensor.h:38
The SoGetBoundingBoxAction class calculates bounding boxes for nodes and subgraphs.If this action is applied to a path or scene graph root, it will calculate the bounding box and the center point of the geometry contained within the scene.
Definition: SoGetBoundingBoxAction.h:45
The SoSFVec3f class is a container for an SbVec3f vector.This field is used where nodes...
Definition: SoSFVec3f.h:40
SoFieldSensor * rotFieldSensor
Definition: SoCenterballDragger.h:95
virtual SbBool setUpConnections(SbBool onoff, SbBool doitalways=FALSE)
Definition: SoInteractionKit.cpp:674
virtual void setDefaultOnNonWritingFields(void)
Definition: SoDragger.cpp:1807

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

Generated for Coin by Doxygen