1 #ifndef COIN_SOHANDLEBOXDRAGGER_H
2 #define COIN_SOHANDLEBOXDRAGGER_H
27 #include <Inventor/draggers/SoDragger.h>
28 #include <Inventor/fields/SoSFVec3f.h>
40 SO_KIT_CATALOG_ENTRY_HEADER(arrow1);
41 SO_KIT_CATALOG_ENTRY_HEADER(arrow1Switch);
42 SO_KIT_CATALOG_ENTRY_HEADER(arrow2);
43 SO_KIT_CATALOG_ENTRY_HEADER(arrow2Switch);
44 SO_KIT_CATALOG_ENTRY_HEADER(arrow3);
45 SO_KIT_CATALOG_ENTRY_HEADER(arrow3Switch);
46 SO_KIT_CATALOG_ENTRY_HEADER(arrow4);
47 SO_KIT_CATALOG_ENTRY_HEADER(arrow4Switch);
48 SO_KIT_CATALOG_ENTRY_HEADER(arrow5);
49 SO_KIT_CATALOG_ENTRY_HEADER(arrow5Switch);
50 SO_KIT_CATALOG_ENTRY_HEADER(arrow6);
51 SO_KIT_CATALOG_ENTRY_HEADER(arrow6Switch);
52 SO_KIT_CATALOG_ENTRY_HEADER(arrowTranslation);
53 SO_KIT_CATALOG_ENTRY_HEADER(drawStyle);
54 SO_KIT_CATALOG_ENTRY_HEADER(extruder1);
55 SO_KIT_CATALOG_ENTRY_HEADER(extruder1Active);
56 SO_KIT_CATALOG_ENTRY_HEADER(extruder1Switch);
57 SO_KIT_CATALOG_ENTRY_HEADER(extruder2);
58 SO_KIT_CATALOG_ENTRY_HEADER(extruder2Active);
59 SO_KIT_CATALOG_ENTRY_HEADER(extruder2Switch);
60 SO_KIT_CATALOG_ENTRY_HEADER(extruder3);
61 SO_KIT_CATALOG_ENTRY_HEADER(extruder3Active);
62 SO_KIT_CATALOG_ENTRY_HEADER(extruder3Switch);
63 SO_KIT_CATALOG_ENTRY_HEADER(extruder4);
64 SO_KIT_CATALOG_ENTRY_HEADER(extruder4Active);
65 SO_KIT_CATALOG_ENTRY_HEADER(extruder4Switch);
66 SO_KIT_CATALOG_ENTRY_HEADER(extruder5);
67 SO_KIT_CATALOG_ENTRY_HEADER(extruder5Active);
68 SO_KIT_CATALOG_ENTRY_HEADER(extruder5Switch);
69 SO_KIT_CATALOG_ENTRY_HEADER(extruder6);
70 SO_KIT_CATALOG_ENTRY_HEADER(extruder6Active);
71 SO_KIT_CATALOG_ENTRY_HEADER(extruder6Switch);
72 SO_KIT_CATALOG_ENTRY_HEADER(surroundScale);
73 SO_KIT_CATALOG_ENTRY_HEADER(translator1);
74 SO_KIT_CATALOG_ENTRY_HEADER(translator1Active);
75 SO_KIT_CATALOG_ENTRY_HEADER(translator1Switch);
76 SO_KIT_CATALOG_ENTRY_HEADER(translator2);
77 SO_KIT_CATALOG_ENTRY_HEADER(translator2Active);
78 SO_KIT_CATALOG_ENTRY_HEADER(translator2Switch);
79 SO_KIT_CATALOG_ENTRY_HEADER(translator3);
80 SO_KIT_CATALOG_ENTRY_HEADER(translator3Active);
81 SO_KIT_CATALOG_ENTRY_HEADER(translator3Switch);
82 SO_KIT_CATALOG_ENTRY_HEADER(translator4);
83 SO_KIT_CATALOG_ENTRY_HEADER(translator4Active);
84 SO_KIT_CATALOG_ENTRY_HEADER(translator4Switch);
85 SO_KIT_CATALOG_ENTRY_HEADER(translator5);
86 SO_KIT_CATALOG_ENTRY_HEADER(translator5Active);
87 SO_KIT_CATALOG_ENTRY_HEADER(translator5Switch);
88 SO_KIT_CATALOG_ENTRY_HEADER(translator6);
89 SO_KIT_CATALOG_ENTRY_HEADER(translator6Active);
90 SO_KIT_CATALOG_ENTRY_HEADER(translator6Switch);
91 SO_KIT_CATALOG_ENTRY_HEADER(uniform1);
92 SO_KIT_CATALOG_ENTRY_HEADER(uniform1Active);
93 SO_KIT_CATALOG_ENTRY_HEADER(uniform1Switch);
94 SO_KIT_CATALOG_ENTRY_HEADER(uniform2);
95 SO_KIT_CATALOG_ENTRY_HEADER(uniform2Active);
96 SO_KIT_CATALOG_ENTRY_HEADER(uniform2Switch);
97 SO_KIT_CATALOG_ENTRY_HEADER(uniform3);
98 SO_KIT_CATALOG_ENTRY_HEADER(uniform3Active);
99 SO_KIT_CATALOG_ENTRY_HEADER(uniform3Switch);
100 SO_KIT_CATALOG_ENTRY_HEADER(uniform4);
101 SO_KIT_CATALOG_ENTRY_HEADER(uniform4Active);
102 SO_KIT_CATALOG_ENTRY_HEADER(uniform4Switch);
103 SO_KIT_CATALOG_ENTRY_HEADER(uniform5);
104 SO_KIT_CATALOG_ENTRY_HEADER(uniform5Active);
105 SO_KIT_CATALOG_ENTRY_HEADER(uniform5Switch);
106 SO_KIT_CATALOG_ENTRY_HEADER(uniform6);
107 SO_KIT_CATALOG_ENTRY_HEADER(uniform6Active);
108 SO_KIT_CATALOG_ENTRY_HEADER(uniform6Switch);
109 SO_KIT_CATALOG_ENTRY_HEADER(uniform7);
110 SO_KIT_CATALOG_ENTRY_HEADER(uniform7Active);
111 SO_KIT_CATALOG_ENTRY_HEADER(uniform7Switch);
112 SO_KIT_CATALOG_ENTRY_HEADER(uniform8);
113 SO_KIT_CATALOG_ENTRY_HEADER(uniform8Active);
114 SO_KIT_CATALOG_ENTRY_HEADER(uniform8Switch);
128 static void startCB(
void * f,
SoDragger * d);
129 static void motionCB(
void * f,
SoDragger * d);
130 static void finishCB(
void * f,
SoDragger * d);
131 static void metaKeyChangeCB(
void * f,
SoDragger * d);
133 static void valueChangedCB(
void * f,
SoDragger * d);
135 void dragStart(
void);
137 void dragFinish(
void);
138 void setAllPartsActive(SbBool onoroff);
145 void updateSwitches();
147 SoNode *getNodeFieldNode(
const char *fieldname);
162 #endif // !COIN_SOHANDLEBOXDRAGGER_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 SoField * getField(const SbName &name) const
Definition: SoFieldContainer.cpp:364
~SoHandleBoxDragger()
Definition: SoHandleBoxDragger.cpp:479
static SbMatrix appendTranslation(const SbMatrix &mtx, const SbVec3f &translation, const SbMatrix *conversion=NULL)
Definition: SoDragger.cpp:1252
SbVec3f getLocalStartingPoint(void)
Definition: SoDragger.cpp:805
SbVec3f getClosestPoint(const SbVec3f &point) const
Definition: SbLine.cpp:263
The SbMatrix class is a 4x4 dimensional representation of a matrix.
Definition: SbMatrix.h:37
The SbPlaneProjector class projects 2D points to 3D points in a plane.
Definition: SbPlaneProjector.h:31
The SoSensor class is the abstract base class for all sensors.
Definition: SoSensor.h:34
SbBool isAdequateConstraintMotion(void)
Definition: SoDragger.cpp:1462
virtual SoNode * getPart(const SbName &partname, SbBool makeifneeded)
Definition: SoBaseKit.cpp:699
SoFieldSensor * translFieldSensor
Definition: SoHandleBoxDragger.h:140
const SoEvent * getEvent(void) const
Definition: SoDragger.cpp:962
void multVecMatrix(const SbVec3f &src, SbVec3f &dst) const
Definition: SbMatrix.cpp:1357
static void metaKeyChangeCB(void *f, SoDragger *d)
Definition: SoHandleBoxDragger.cpp:586
SoField * getAttachedField(void) const
Definition: SoFieldSensor.cpp:107
void addOtherEventCallback(SoDraggerCB *func, void *data=NULL)
Definition: SoDragger.cpp:702
SbBool wasCtrlDown(void) const
Definition: SoEvent.cpp:259
The SoSurroundScale class is used to automatically scale geometry to surround other geometry.
Definition: SoSurroundScale.h:34
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
void dragFinish(void)
Definition: SoHandleBoxDragger.cpp:820
The SoDragger class is the base class for all draggers.
Definition: SoDragger.h:53
The SoDrawStyle class specificies common rendering properties for shapes.
Definition: SoDrawStyle.h:33
The SbString class is a string class with convenience functions for string operations.
Definition: SbString.h:42
virtual SbBool setUpConnections(SbBool onoff, SbBool doitalways=0)
Definition: SoHandleBoxDragger.cpp:489
static void readDefaultParts(const char *fileName, const char defaultBuffer[], int defBufSize)
Definition: SoInteractionKit.cpp:433
virtual void setDefaultOnNonWritingFields(void)
Definition: SoHandleBoxDragger.cpp:520
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
void invalidate(void)
Definition: SoSurroundScale.cpp:270
const SbViewVolume & getViewVolume(void)
Definition: SoDragger.cpp:1032
virtual void setWorkingSpace(const SbMatrix &space)
Definition: SbProjector.cpp:133
void addValueChangedCallback(SoDraggerCB *func, void *data=NULL)
Definition: SoDragger.cpp:634
void setMotionMatrix(const SbMatrix &newmatrix)
Definition: SoDragger.cpp:905
int findNode(const SoNode *const node) const
Definition: SoPath.cpp:587
The SoField class is the top-level abstract base class for fields.
Definition: SoField.h:38
The SoPath class is a container class for traversal path descriptions.
Definition: SoPath.h:43
void setDefault(SbBool def)
Definition: SoField.cpp:650
void dragStart(void)
Definition: SoHandleBoxDragger.cpp:621
SoSFVec3f scaleFactor
Definition: SoHandleBoxDragger.h:120
static void finishCB(void *f, SoDragger *d)
Definition: SoHandleBoxDragger.cpp:578
void setLine(const SbLine &line)
Definition: SbLineProjector.cpp:131
void getTransform(SbVec3f &t, SbRotation &r, SbVec3f &s, SbRotation &so) const
Definition: SbMatrix.cpp:997
virtual void setViewVolume(const SbViewVolume &vol)
Definition: SbProjector.cpp:112
static void valueChangedCB(void *f, SoDragger *d)
Definition: SoHandleBoxDragger.cpp:541
SbMatrix getWorldToLocalMatrix(void)
Definition: SoDragger.cpp:791
static SbMatrix appendScale(const SbMatrix &mtx, const SbVec3f &scale, const SbVec3f &scalecenter, const SbMatrix *conversion=NULL)
Definition: SoDragger.cpp:1271
SoSFBool isActive
Definition: SoDragger.h:61
SoSFVec3f translation
Definition: SoTranslation.h:40
The SbVec3f class is a 3 dimensional vector with floating point coordinates.
Definition: SbVec3f.h:37
SoHandleBoxDragger(void)
Definition: SoHandleBoxDragger.cpp:306
virtual void setDefaultOnNonWritingFields(void)
Definition: SoDragger.cpp:1743
void setAllPartsActive(SbBool onoroff)
Definition: SoHandleBoxDragger.cpp:833
SbString & sprintf(const char *formatstr,...)
Definition: SbString.h:105
SbBool connectionsSetUp
Definition: SoBaseKit.h:142
void drag(void)
Definition: SoHandleBoxDragger.cpp:725
void attach(SoField *field)
Definition: SoFieldSensor.cpp:77
const SbMatrix & getMotionMatrix(void)
Definition: SoDragger.cpp:688
void getPartToLocalMatrix(const SbName &partname, SbMatrix &parttolocalmatrix, SbMatrix &localtopartmatrix)
Definition: SoDragger.cpp:826
static void motionCB(void *f, SoDragger *d)
Definition: SoHandleBoxDragger.cpp:570
The SoFieldSensor class detects changes to a field.
Definition: SoFieldSensor.h:29
The SoInteractionKit class is a base class for draggers.
Definition: SoInteractionKit.h:41
The SoSFNode class is a container for a single node.
Definition: SoSFNode.h:38
The SbLine class represents a line in 3D space.
Definition: SbLine.h:32
The SoSeparator class is a state-preserving group node.
Definition: SoSeparator.h:34
SbVec2f getNormalizedLocaterPosition(void)
Definition: SoDragger.cpp:1408
const SoPath * getPickPath(void) const
Definition: SoDragger.cpp:953
static void fieldSensorCB(void *f, SoSensor *s)
Definition: SoHandleBoxDragger.cpp:531
virtual SbVec3f project(const SbVec2f &point)
Definition: SbLineProjector.cpp:67
const SbMatrix & getStartMotionMatrix(void)
Definition: SoDragger.cpp:930
static void startCB(void *f, SoDragger *d)
Definition: SoHandleBoxDragger.cpp:562
The SoBaseKit class is the toplevel superclass for nodekits.
Definition: SoBaseKit.h:57
The SoNode class is the base class for nodes used in scene graphs.
Definition: SoNode.h:47
The SoTranslation class is a node type for specifying geometry translations.
Definition: SoTranslation.h:31
The SoHandleBoxDragger class provides support for interactive scaling and translation.
Definition: SoHandleBoxDragger.h:35
void addStartCallback(SoDraggerCB *func, void *data=NULL)
Definition: SoDragger.cpp:570
void setStartLocaterPosition(SbVec2s p)
Definition: SoDragger.cpp:1450
SbBool isOfType(const SoType type) const
Definition: SoField.cpp:690
static void fieldSensorCB(void *, SoSensor *)
Definition: SoInteractionKit.cpp:725
static SbMatrix identity(void)
Definition: SbMatrix.cpp:748
The SoEvent class is the base class for all Coin events.
Definition: SoEvent.h:34
void addMotionCallback(SoDraggerCB *func, void *data=NULL)
Definition: SoDragger.cpp:591
const char * getString(void) const
Definition: SbString.h:71
void setPlane(const SbPlane &plane)
Definition: SbPlaneProjector.cpp:183
The SbPlane class represents a plane in 3D space.
Definition: SbPlane.h:34
static void initClass(void)
Definition: SoDragger.cpp:388
The SbLineProjector class projects 2D points to 3D points along a line.
Definition: SbLineProjector.h:32
SoFieldSensor * scaleFieldSensor
Definition: SoHandleBoxDragger.h:141
virtual SbBool setPartAsDefault(const SbName &partname, SoNode *node, SbBool onlyifdefault=1)
Definition: SoInteractionKit.cpp:271
virtual SbVec3f project(const SbVec2f &point)
Definition: SbPlaneProjector.cpp:101
SbMatrix getLocalToWorldMatrix(void)
Definition: SoDragger.cpp:776
SoSFVec3f translation
Definition: SoHandleBoxDragger.h:121
Copyright © 1998-2007 by Systems in Motion AS. All rights reserved.
Generated on Mon Jul 27 2020 for Coin by Doxygen. 1.8.18