1#ifndef COIN_SOTRACKBALLDRAGGER_H
2#define COIN_SOTRACKBALLDRAGGER_H
27#include <Inventor/draggers/SoDragger.h>
28#include <Inventor/fields/SoSFRotation.h>
29#include <Inventor/fields/SoSFVec3f.h>
30#include <Inventor/SbVec2f.h>
31#include <Inventor/SbTime.h>
45 SO_KIT_CATALOG_ENTRY_HEADER(XRotator);
46 SO_KIT_CATALOG_ENTRY_HEADER(XRotatorActive);
47 SO_KIT_CATALOG_ENTRY_HEADER(XRotatorSwitch);
48 SO_KIT_CATALOG_ENTRY_HEADER(YRotator);
49 SO_KIT_CATALOG_ENTRY_HEADER(YRotatorActive);
50 SO_KIT_CATALOG_ENTRY_HEADER(YRotatorSwitch);
51 SO_KIT_CATALOG_ENTRY_HEADER(ZRotator);
52 SO_KIT_CATALOG_ENTRY_HEADER(ZRotatorActive);
53 SO_KIT_CATALOG_ENTRY_HEADER(ZRotatorSwitch);
54 SO_KIT_CATALOG_ENTRY_HEADER(antiSquish);
55 SO_KIT_CATALOG_ENTRY_HEADER(rotator);
56 SO_KIT_CATALOG_ENTRY_HEADER(rotatorActive);
57 SO_KIT_CATALOG_ENTRY_HEADER(rotatorSwitch);
58 SO_KIT_CATALOG_ENTRY_HEADER(surroundScale);
59 SO_KIT_CATALOG_ENTRY_HEADER(userAxis);
60 SO_KIT_CATALOG_ENTRY_HEADER(userAxisActive);
61 SO_KIT_CATALOG_ENTRY_HEADER(userAxisRotation);
62 SO_KIT_CATALOG_ENTRY_HEADER(userAxisSwitch);
63 SO_KIT_CATALOG_ENTRY_HEADER(userRotator);
64 SO_KIT_CATALOG_ENTRY_HEADER(userRotatorActive);
65 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 *);
103 class SoTrackballDraggerP * pimpl;
104 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:53
static void initClass(void)
Definition SoDragger.cpp:388
virtual void setDefaultOnNonWritingFields(void)
Definition SoDragger.cpp:1743
The SoFieldSensor class detects changes to a field.
Definition SoFieldSensor.h:29
virtual SbBool setUpConnections(SbBool onoff, SbBool doitalways=0)
Definition SoInteractionKit.cpp:648
static void fieldSensorCB(void *, SoSensor *)
Definition SoInteractionKit.cpp:725
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:40
SoSFRotation rotation
Definition SoTrackballDragger.h:72
SoFieldSensor * scaleFieldSensor
Definition SoTrackballDragger.h:96
SoFieldSensor * rotFieldSensor
Definition SoTrackballDragger.h:95
SoSFVec3f scaleFactor
Definition SoTrackballDragger.h:73