1#ifndef COIN_SOTRACKBALLDRAGGER_H
2#define COIN_SOTRACKBALLDRAGGER_H
36#include <Inventor/draggers/SoDragger.h>
37#include <Inventor/tools/SbPimplPtr.h>
38#include <Inventor/fields/SoSFRotation.h>
39#include <Inventor/fields/SoSFVec3f.h>
40#include <Inventor/SbVec2f.h>
41#include <Inventor/SbTime.h>
49class SoTrackballDraggerP;
55 SO_KIT_CATALOG_ENTRY_HEADER(XRotator);
56 SO_KIT_CATALOG_ENTRY_HEADER(XRotatorActive);
57 SO_KIT_CATALOG_ENTRY_HEADER(XRotatorSwitch);
58 SO_KIT_CATALOG_ENTRY_HEADER(YRotator);
59 SO_KIT_CATALOG_ENTRY_HEADER(YRotatorActive);
60 SO_KIT_CATALOG_ENTRY_HEADER(YRotatorSwitch);
61 SO_KIT_CATALOG_ENTRY_HEADER(ZRotator);
62 SO_KIT_CATALOG_ENTRY_HEADER(ZRotatorActive);
63 SO_KIT_CATALOG_ENTRY_HEADER(ZRotatorSwitch);
64 SO_KIT_CATALOG_ENTRY_HEADER(antiSquish);
65 SO_KIT_CATALOG_ENTRY_HEADER(rotator);
66 SO_KIT_CATALOG_ENTRY_HEADER(rotatorActive);
67 SO_KIT_CATALOG_ENTRY_HEADER(rotatorSwitch);
68 SO_KIT_CATALOG_ENTRY_HEADER(surroundScale);
69 SO_KIT_CATALOG_ENTRY_HEADER(userAxis);
70 SO_KIT_CATALOG_ENTRY_HEADER(userAxisActive);
71 SO_KIT_CATALOG_ENTRY_HEADER(userAxisRotation);
72 SO_KIT_CATALOG_ENTRY_HEADER(userAxisSwitch);
73 SO_KIT_CATALOG_ENTRY_HEADER(userRotator);
74 SO_KIT_CATALOG_ENTRY_HEADER(userRotatorActive);
75 SO_KIT_CATALOG_ENTRY_HEADER(userRotatorSwitch);
84 SbBool isAnimationEnabled(
void);
85 void setAnimationEnabled(SbBool newval);
94 void dragFinish(
void);
95 void setAllPartsActive(SbBool onoroff);
97 static void startCB(
void * f,
SoDragger * d);
98 static void motionCB(
void * f,
SoDragger * d);
99 static void finishCB(
void * f,
SoDragger * d);
100 static void metaKeyChangeCB(
void * f,
SoDragger * d);
102 static void valueChangedCB(
void * f,
SoDragger * d);
108 SoNode * getNodeFieldNode(
const char *fieldname);
109 void updateUserAxisSwitches(
const SbBool setactive = FALSE);
110 static void timerSensorCB(
void *,
SoSensor *);
114 friend class SoTrackballDraggerP;
The SbCylinderProjector class is the abstract base class for mapping to cylindrical surfaces.
Definition SbCylinderProjector.h:39
The SbLineProjector class projects 2D points to 3D points along a line.
Definition SbLineProjector.h:41
Definition SbPimplPtr.h:55
The SbSphereProjector class is the abstract base class for mapping to spherical surfaces.
Definition SbSphereProjector.h:40
The SoDragger class is the base class for all draggers.
Definition SoDragger.h:62
static void initClass(void)
Definition SoDragger.cpp:408
virtual void setDefaultOnNonWritingFields(void)
Definition SoDragger.cpp:1828
The SoFieldSensor class detects changes to a field.
Definition SoFieldSensor.h:38
static void fieldSensorCB(void *, SoSensor *)
Definition SoInteractionKit.cpp:754
virtual SbBool setUpConnections(SbBool onoff, SbBool doitalways=FALSE)
Definition SoInteractionKit.cpp:677
The SoNode class is the base class for nodes used in scene graphs.
Definition SoNode.h:56
The SoSFRotation class is a container for an SbRotation.
Definition SoSFRotation.h:40
The SoSFVec3f class is a container for an SbVec3f vector.
Definition SoSFVec3f.h:40
The SoSensor class is the abstract base class for all sensors.
Definition SoSensor.h:43
The SoTimerSensor class is a sensor which will trigger at given intervals.
Definition SoTimerSensor.h:38
The SoTrackballDragger provides the end-user with rotation and scaling interaction possibilities.
Definition SoTrackballDragger.h:51
SoSFRotation rotation
Definition SoTrackballDragger.h:81
SoFieldSensor * scaleFieldSensor
Definition SoTrackballDragger.h:105
SoFieldSensor * rotFieldSensor
Definition SoTrackballDragger.h:104
SoSFVec3f scaleFactor
Definition SoTrackballDragger.h:82