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>
40class 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;
The SbCylinderProjector class is the abstract base class for mapping to cylindrical surfaces.
Definition SbCylinderProjector.h:30
The SbLineProjector class projects 2D points to 3D points along a line.
Definition SbLineProjector.h:32
The SbSphereProjector class is the abstract base class for mapping to spherical surfaces.
Definition SbSphereProjector.h:31
The SoDragger class is the base class for all draggers.
Definition SoDragger.h:55
static void initClass(void)
Definition SoDragger.cpp:399
virtual void setDefaultOnNonWritingFields(void)
Definition SoDragger.cpp:1791
The SoFieldSensor class detects changes to a field.
Definition SoFieldSensor.h:29
static void fieldSensorCB(void *, SoSensor *)
Definition SoInteractionKit.cpp:742
virtual SbBool setUpConnections(SbBool onoff, SbBool doitalways=FALSE)
Definition SoInteractionKit.cpp:665
The SoNode class is the base class for nodes used in scene graphs.
Definition SoNode.h:47
The SoSFRotation class is a container for an SbRotation.
Definition SoSFRotation.h:31
The SoSFVec3f class is a container for an SbVec3f vector.
Definition SoSFVec3f.h:31
The SoSensor class is the abstract base class for all sensors.
Definition SoSensor.h:34
The SoTimerSensor class is a sensor which will trigger at given intervals.
Definition SoTimerSensor.h:29
The SoTrackballDragger provides the end-user with rotation and scaling interaction possibilities.
Definition SoTrackballDragger.h:42
SoSFRotation rotation
Definition SoTrackballDragger.h:72
SoFieldSensor * scaleFieldSensor
Definition SoTrackballDragger.h:96
SoFieldSensor * rotFieldSensor
Definition SoTrackballDragger.h:95
SoSFVec3f scaleFactor
Definition SoTrackballDragger.h:73