1 #ifndef COIN_SOTRACKBALLDRAGGER_H 2 #define COIN_SOTRACKBALLDRAGGER_H 28 #include <Inventor/tools/SbPimplPtr.h> 29 #include <Inventor/fields/SoSFRotation.h> 30 #include <Inventor/fields/SoSFVec3f.h> 31 #include <Inventor/SbVec2f.h> 32 #include <Inventor/SbTime.h> 40 class SoTrackballDraggerP;
46 SO_KIT_CATALOG_ENTRY_HEADER(XRotator);
47 SO_KIT_CATALOG_ENTRY_HEADER(XRotatorActive);
48 SO_KIT_CATALOG_ENTRY_HEADER(XRotatorSwitch);
49 SO_KIT_CATALOG_ENTRY_HEADER(YRotator);
50 SO_KIT_CATALOG_ENTRY_HEADER(YRotatorActive);
51 SO_KIT_CATALOG_ENTRY_HEADER(YRotatorSwitch);
52 SO_KIT_CATALOG_ENTRY_HEADER(ZRotator);
53 SO_KIT_CATALOG_ENTRY_HEADER(ZRotatorActive);
54 SO_KIT_CATALOG_ENTRY_HEADER(ZRotatorSwitch);
55 SO_KIT_CATALOG_ENTRY_HEADER(antiSquish);
56 SO_KIT_CATALOG_ENTRY_HEADER(rotator);
57 SO_KIT_CATALOG_ENTRY_HEADER(rotatorActive);
58 SO_KIT_CATALOG_ENTRY_HEADER(rotatorSwitch);
59 SO_KIT_CATALOG_ENTRY_HEADER(surroundScale);
60 SO_KIT_CATALOG_ENTRY_HEADER(userAxis);
61 SO_KIT_CATALOG_ENTRY_HEADER(userAxisActive);
62 SO_KIT_CATALOG_ENTRY_HEADER(userAxisRotation);
63 SO_KIT_CATALOG_ENTRY_HEADER(userAxisSwitch);
64 SO_KIT_CATALOG_ENTRY_HEADER(userRotator);
65 SO_KIT_CATALOG_ENTRY_HEADER(userRotatorActive);
66 SO_KIT_CATALOG_ENTRY_HEADER(userRotatorSwitch);
75 SbBool isAnimationEnabled(
void);
76 void setAnimationEnabled(SbBool newval);
85 void dragFinish(
void);
86 void setAllPartsActive(SbBool onoroff);
88 static void startCB(
void * f,
SoDragger * d);
89 static void motionCB(
void * f,
SoDragger * d);
90 static void finishCB(
void * f,
SoDragger * d);
91 static void metaKeyChangeCB(
void * f,
SoDragger * d);
93 static void valueChangedCB(
void * f,
SoDragger * d);
99 SoNode * getNodeFieldNode(
const char *fieldname);
100 void updateUserAxisSwitches(
const SbBool setactive = FALSE);
101 static void timerSensorCB(
void *,
SoSensor *);
104 SbPimplPtr<SoTrackballDraggerP> pimpl;
105 friend class SoTrackballDraggerP;
112 #endif // !COIN_SOTRACKBALLDRAGGER_H static void fieldSensorCB(void *, SoSensor *)
Definition: SoInteractionKit.cpp:742
SoFieldSensor * scaleFieldSensor
Definition: SoTrackballDragger.h:96
The SoTrackballDragger provides the end-user with rotation and scaling interaction possibilities...
Definition: SoTrackballDragger.h:42
SoFieldSensor * rotFieldSensor
Definition: SoTrackballDragger.h:95
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:31
The SoTimerSensor class is a sensor which will trigger at given intervals.Use sensors of this class w...
Definition: SoTimerSensor.h:29
The SbSphereProjector class is the abstract base class for mapping to spherical surfaces.The sphere projectors map 2D points to various surface types based on spherical shapes.
Definition: SbSphereProjector.h:31
The SoNode class is the base class for nodes used in scene graphs.Coin is a retained mode 3D visualiz...
Definition: SoNode.h:47
The SoInteractionKit class is a base class for draggers.This nodekit class makes it possible to set s...
Definition: SoInteractionKit.h:41
The SoDragger class is the base class for all draggers.Draggers is a mechanism used for letting the e...
Definition: SoDragger.h:55
The SoSensor class is the abstract base class for all sensors.Sensors is a mechanism in Coin for sche...
Definition: SoSensor.h:34
static void initClass(void)
Definition: SoDragger.cpp:399
The SoFieldSensor class detects changes to a field.Attach a field to a sensor of this type to put it ...
Definition: SoFieldSensor.h:29
The SoSFVec3f class is a container for an SbVec3f vector.This field is used where nodes...
Definition: SoSFVec3f.h:31
SoSFVec3f scaleFactor
Definition: SoTrackballDragger.h:73
The SbLineProjector class projects 2D points to 3D points along a line.The 3D projection of the 2D co...
Definition: SbLineProjector.h:32
SoSFRotation rotation
Definition: SoTrackballDragger.h:72
virtual SbBool setUpConnections(SbBool onoff, SbBool doitalways=FALSE)
Definition: SoInteractionKit.cpp:665
The SbCylinderProjector class is the abstract base class for mapping to cylindrical surfaces...
Definition: SbCylinderProjector.h:30
virtual void setDefaultOnNonWritingFields(void)
Definition: SoDragger.cpp:1791