1 #ifndef COIN_SODRAGPOINTDRAGGER_H
2 #define COIN_SODRAGPOINTDRAGGER_H
27 #include <Inventor/draggers/SoDragger.h>
28 #include <Inventor/fields/SoSFVec3f.h>
39 SO_KIT_CATALOG_ENTRY_HEADER(noRotSep);
40 SO_KIT_CATALOG_ENTRY_HEADER(planeFeedbackSep);
41 SO_KIT_CATALOG_ENTRY_HEADER(planeFeedbackSwitch);
42 SO_KIT_CATALOG_ENTRY_HEADER(planeFeedbackTranslation);
43 SO_KIT_CATALOG_ENTRY_HEADER(rotX);
44 SO_KIT_CATALOG_ENTRY_HEADER(rotXSep);
45 SO_KIT_CATALOG_ENTRY_HEADER(rotY);
46 SO_KIT_CATALOG_ENTRY_HEADER(rotYSep);
47 SO_KIT_CATALOG_ENTRY_HEADER(rotZ);
48 SO_KIT_CATALOG_ENTRY_HEADER(rotZSep);
49 SO_KIT_CATALOG_ENTRY_HEADER(xFeedback);
50 SO_KIT_CATALOG_ENTRY_HEADER(xFeedbackSep);
51 SO_KIT_CATALOG_ENTRY_HEADER(xFeedbackSwitch);
52 SO_KIT_CATALOG_ENTRY_HEADER(xFeedbackTranslation);
53 SO_KIT_CATALOG_ENTRY_HEADER(xTranslator);
54 SO_KIT_CATALOG_ENTRY_HEADER(xTranslatorSwitch);
55 SO_KIT_CATALOG_ENTRY_HEADER(xyFeedback);
56 SO_KIT_CATALOG_ENTRY_HEADER(xyTranslator);
57 SO_KIT_CATALOG_ENTRY_HEADER(xyTranslatorSwitch);
58 SO_KIT_CATALOG_ENTRY_HEADER(xzFeedback);
59 SO_KIT_CATALOG_ENTRY_HEADER(xzTranslator);
60 SO_KIT_CATALOG_ENTRY_HEADER(xzTranslatorSwitch);
61 SO_KIT_CATALOG_ENTRY_HEADER(yFeedback);
62 SO_KIT_CATALOG_ENTRY_HEADER(yFeedbackSep);
63 SO_KIT_CATALOG_ENTRY_HEADER(yFeedbackSwitch);
64 SO_KIT_CATALOG_ENTRY_HEADER(yFeedbackTranslation);
65 SO_KIT_CATALOG_ENTRY_HEADER(yTranslator);
66 SO_KIT_CATALOG_ENTRY_HEADER(yTranslatorSwitch);
67 SO_KIT_CATALOG_ENTRY_HEADER(yzFeedback);
68 SO_KIT_CATALOG_ENTRY_HEADER(yzTranslator);
69 SO_KIT_CATALOG_ENTRY_HEADER(yzTranslatorSwitch);
70 SO_KIT_CATALOG_ENTRY_HEADER(zFeedback);
71 SO_KIT_CATALOG_ENTRY_HEADER(zFeedbackSep);
72 SO_KIT_CATALOG_ENTRY_HEADER(zFeedbackSwitch);
73 SO_KIT_CATALOG_ENTRY_HEADER(zFeedbackTranslation);
74 SO_KIT_CATALOG_ENTRY_HEADER(zTranslator);
75 SO_KIT_CATALOG_ENTRY_HEADER(zTranslatorSwitch);
82 void setJumpLimit(
const float limit);
83 float getJumpLimit(
void)
const;
84 void showNextDraggerSet(
void);
95 void dragFinish(
void);
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);
107 void registerDragger(
SoDragger *dragger);
108 void unregisterDragger(
const char *name);
109 void updateSwitchNodes();
114 #endif // !COIN_SODRAGPOINTDRAGGER_H
The SoSFVec3f class is a container for an SbVec3f vector.
Definition: SoSFVec3f.h:31
The SbRotation class represents a rotation in 3D space.
Definition: SbRotation.h:33
void workFieldsIntoTransform(SbMatrix &mtx)
Definition: SoDragger.cpp:1123
virtual SbBool setUpConnections(SbBool onoff, SbBool doitalways=0)
Definition: SoDragPointDragger.cpp:323
void registerChildDragger(SoDragger *child)
Definition: SoDragger.cpp:722
The SoRotation class specifies a rotation transformation.
Definition: SoRotation.h:31
~SoDragPointDragger()
Definition: SoDragPointDragger.cpp:316
void drag(void)
Definition: SoDragPointDragger.cpp:512
The SbMatrix class is a 4x4 dimensional representation of a matrix.
Definition: SbMatrix.h:37
The SoTranslate1Dragger class provides a mechanism for the end-user to translate along an axis.
Definition: SoTranslate1Dragger.h:35
virtual SoNode * getAnyPart(const SbName &partname, SbBool makeifneeded, SbBool leafcheck=0, SbBool publiccheck=0)
Definition: SoBaseKit.cpp:1722
The SoSensor class is the abstract base class for all sensors.
Definition: SoSensor.h:34
static void startCB(void *f, SoDragger *d)
Definition: SoDragPointDragger.cpp:537
SoDragger * getActiveChildDragger(void) const
Definition: SoDragger.cpp:1734
const SoEvent * getEvent(void) const
Definition: SoDragger.cpp:962
void setJumpLimit(const float limit)
Definition: SoDragPointDragger.cpp:438
The SoDragPointDragger class provides mechanisms for moving a point in 3D.
Definition: SoDragPointDragger.h:34
SoField * getAttachedField(void) const
Definition: SoFieldSensor.cpp:107
void addOtherEventCallback(SoDraggerCB *func, void *data=NULL)
Definition: SoDragger.cpp:702
The SoSwitch class is a group node which selects one child subgraph for traversal.
Definition: SoSwitch.h:37
static void setSwitchValue(SoNode *node, const int newVal)
Definition: SoInteractionKit.cpp:358
void setPriority(uint32_t pri)
Definition: SoDelayQueueSensor.cpp:108
The SoDragger class is the base class for all draggers.
Definition: SoDragger.h:53
static void readDefaultParts(const char *fileName, const char defaultBuffer[], int defBufSize)
Definition: SoInteractionKit.cpp:433
void addFinishCallback(SoDraggerCB *func, void *data=NULL)
Definition: SoDragger.cpp:611
void detach(void)
Definition: SoFieldSensor.cpp:92
virtual SbBool setUpConnections(SbBool onoff, SbBool doitalways=0)
Definition: SoInteractionKit.cpp:648
static void fieldSensorCB(void *f, SoSensor *s)
Definition: SoDragPointDragger.cpp:403
void addValueChangedCallback(SoDraggerCB *func, void *data=NULL)
Definition: SoDragger.cpp:634
void setMotionMatrix(const SbMatrix &newmatrix)
Definition: SoDragger.cpp:905
SoSFRotation rotation
Definition: SoRotation.h:40
void setDefault(SbBool def)
Definition: SoField.cpp:650
void showNextDraggerSet(void)
Definition: SoDragPointDragger.cpp:468
The SoTranslate2Dragger class provides a mechanism for the end-user to translate in a plane.
Definition: SoTranslate2Dragger.h:35
The SbVec3f class is a 3 dimensional vector with floating point coordinates.
Definition: SbVec3f.h:37
static void valueChangedCB(void *f, SoDragger *d)
Definition: SoDragPointDragger.cpp:413
static void finishCB(void *f, SoDragger *d)
Definition: SoDragPointDragger.cpp:553
void dragStart(void)
Definition: SoDragPointDragger.cpp:478
virtual void setDefaultOnNonWritingFields(void)
Definition: SoDragger.cpp:1743
SbBool connectionsSetUp
Definition: SoBaseKit.h:142
void attach(SoField *field)
Definition: SoFieldSensor.cpp:77
const SbMatrix & getMotionMatrix(void)
Definition: SoDragger.cpp:688
The SoFieldSensor class detects changes to a field.
Definition: SoFieldSensor.h:29
The SoSeparator class is a state-preserving group node.
Definition: SoSeparator.h:34
void unregisterChildDragger(SoDragger *child)
Definition: SoDragger.cpp:735
void dragFinish(void)
Definition: SoDragPointDragger.cpp:522
static void metaKeyChangeCB(void *f, SoDragger *d)
Definition: SoDragPointDragger.cpp:561
SoFieldSensor * fieldSensor
Definition: SoDragPointDragger.h:104
SbBool isOfType(SoType type) const
Definition: SoBase.cpp:710
The SoTranslation class is a node type for specifying geometry translations.
Definition: SoTranslation.h:31
void addStartCallback(SoDraggerCB *func, void *data=NULL)
Definition: SoDragger.cpp:570
virtual void setDefaultOnNonWritingFields(void)
Definition: SoDragPointDragger.cpp:383
float getJumpLimit(void) const
Definition: SoDragPointDragger.cpp:453
static void fieldSensorCB(void *, SoSensor *)
Definition: SoInteractionKit.cpp:725
static void motionCB(void *f, SoDragger *d)
Definition: SoDragPointDragger.cpp:545
The SoEvent class is the base class for all Coin events.
Definition: SoEvent.h:34
virtual SbBool setAnyPartAsDefault(const SbName &partname, SoNode *node, SbBool anypart=1, SbBool onlyifdefault=1)
Definition: SoInteractionKit.cpp:496
void addMotionCallback(SoDraggerCB *func, void *data=NULL)
Definition: SoDragger.cpp:591
static void initClass(void)
Definition: SoDragger.cpp:388
SoSFVec3f translation
Definition: SoDragPointDragger.h:86
virtual SbBool setPartAsDefault(const SbName &partname, SoNode *node, SbBool onlyifdefault=1)
Definition: SoInteractionKit.cpp:271
SoDragPointDragger(void)
Definition: SoDragPointDragger.cpp:203
Copyright © 1998-2007 by Systems in Motion AS. All rights reserved.
Generated on Wed Jul 24 2019 for Coin by Doxygen. 1.8.17