1 #ifndef COIN_SOTRANSFORMERDRAGGER_H
2 #define COIN_SOTRANSFORMERDRAGGER_H
27 #include <Inventor/draggers/SoDragger.h>
28 #include <Inventor/fields/SoSFRotation.h>
29 #include <Inventor/fields/SoSFVec3f.h>
30 #include <Inventor/fields/SoSFFloat.h>
31 #include <Inventor/lists/SoNodeList.h>
42 SO_KIT_CATALOG_ENTRY_HEADER(axisFeedbackLocation);
43 SO_KIT_CATALOG_ENTRY_HEADER(axisFeedbackSep);
44 SO_KIT_CATALOG_ENTRY_HEADER(circleFeedbackAntiSquish);
45 SO_KIT_CATALOG_ENTRY_HEADER(circleFeedbackSep);
46 SO_KIT_CATALOG_ENTRY_HEADER(circleFeedbackTransform);
47 SO_KIT_CATALOG_ENTRY_HEADER(circleFeedbackTransformSwitch);
48 SO_KIT_CATALOG_ENTRY_HEADER(negXRoundWallFeedback);
49 SO_KIT_CATALOG_ENTRY_HEADER(negXWallFeedback);
50 SO_KIT_CATALOG_ENTRY_HEADER(negXWallFeedbackSwitch);
51 SO_KIT_CATALOG_ENTRY_HEADER(negYRoundWallFeedback);
52 SO_KIT_CATALOG_ENTRY_HEADER(negYWallFeedback);
53 SO_KIT_CATALOG_ENTRY_HEADER(negYWallFeedbackSwitch);
54 SO_KIT_CATALOG_ENTRY_HEADER(negZRoundWallFeedback);
55 SO_KIT_CATALOG_ENTRY_HEADER(negZWallFeedback);
56 SO_KIT_CATALOG_ENTRY_HEADER(negZWallFeedbackSwitch);
57 SO_KIT_CATALOG_ENTRY_HEADER(overallStyle);
58 SO_KIT_CATALOG_ENTRY_HEADER(posXRoundWallFeedback);
59 SO_KIT_CATALOG_ENTRY_HEADER(posXWallFeedback);
60 SO_KIT_CATALOG_ENTRY_HEADER(posXWallFeedbackSwitch);
61 SO_KIT_CATALOG_ENTRY_HEADER(posYRoundWallFeedback);
62 SO_KIT_CATALOG_ENTRY_HEADER(posYWallFeedback);
63 SO_KIT_CATALOG_ENTRY_HEADER(posYWallFeedbackSwitch);
64 SO_KIT_CATALOG_ENTRY_HEADER(posZRoundWallFeedback);
65 SO_KIT_CATALOG_ENTRY_HEADER(posZWallFeedback);
66 SO_KIT_CATALOG_ENTRY_HEADER(posZWallFeedbackSwitch);
67 SO_KIT_CATALOG_ENTRY_HEADER(radialFeedback);
68 SO_KIT_CATALOG_ENTRY_HEADER(radialFeedbackSwitch);
69 SO_KIT_CATALOG_ENTRY_HEADER(rotator1);
70 SO_KIT_CATALOG_ENTRY_HEADER(rotator1Active);
71 SO_KIT_CATALOG_ENTRY_HEADER(rotator1LocateGroup);
72 SO_KIT_CATALOG_ENTRY_HEADER(rotator1Switch);
73 SO_KIT_CATALOG_ENTRY_HEADER(rotator2);
74 SO_KIT_CATALOG_ENTRY_HEADER(rotator2Active);
75 SO_KIT_CATALOG_ENTRY_HEADER(rotator2LocateGroup);
76 SO_KIT_CATALOG_ENTRY_HEADER(rotator2Switch);
77 SO_KIT_CATALOG_ENTRY_HEADER(rotator3);
78 SO_KIT_CATALOG_ENTRY_HEADER(rotator3Active);
79 SO_KIT_CATALOG_ENTRY_HEADER(rotator3LocateGroup);
80 SO_KIT_CATALOG_ENTRY_HEADER(rotator3Switch);
81 SO_KIT_CATALOG_ENTRY_HEADER(rotator4);
82 SO_KIT_CATALOG_ENTRY_HEADER(rotator4Active);
83 SO_KIT_CATALOG_ENTRY_HEADER(rotator4LocateGroup);
84 SO_KIT_CATALOG_ENTRY_HEADER(rotator4Switch);
85 SO_KIT_CATALOG_ENTRY_HEADER(rotator5);
86 SO_KIT_CATALOG_ENTRY_HEADER(rotator5Active);
87 SO_KIT_CATALOG_ENTRY_HEADER(rotator5LocateGroup);
88 SO_KIT_CATALOG_ENTRY_HEADER(rotator5Switch);
89 SO_KIT_CATALOG_ENTRY_HEADER(rotator6);
90 SO_KIT_CATALOG_ENTRY_HEADER(rotator6Active);
91 SO_KIT_CATALOG_ENTRY_HEADER(rotator6LocateGroup);
92 SO_KIT_CATALOG_ENTRY_HEADER(rotator6Switch);
93 SO_KIT_CATALOG_ENTRY_HEADER(rotatorSep);
94 SO_KIT_CATALOG_ENTRY_HEADER(scale1);
95 SO_KIT_CATALOG_ENTRY_HEADER(scale1Active);
96 SO_KIT_CATALOG_ENTRY_HEADER(scale1LocateGroup);
97 SO_KIT_CATALOG_ENTRY_HEADER(scale1Switch);
98 SO_KIT_CATALOG_ENTRY_HEADER(scale2);
99 SO_KIT_CATALOG_ENTRY_HEADER(scale2Active);
100 SO_KIT_CATALOG_ENTRY_HEADER(scale2LocateGroup);
101 SO_KIT_CATALOG_ENTRY_HEADER(scale2Switch);
102 SO_KIT_CATALOG_ENTRY_HEADER(scale3);
103 SO_KIT_CATALOG_ENTRY_HEADER(scale3Active);
104 SO_KIT_CATALOG_ENTRY_HEADER(scale3LocateGroup);
105 SO_KIT_CATALOG_ENTRY_HEADER(scale3Switch);
106 SO_KIT_CATALOG_ENTRY_HEADER(scale4);
107 SO_KIT_CATALOG_ENTRY_HEADER(scale4Active);
108 SO_KIT_CATALOG_ENTRY_HEADER(scale4LocateGroup);
109 SO_KIT_CATALOG_ENTRY_HEADER(scale4Switch);
110 SO_KIT_CATALOG_ENTRY_HEADER(scale5);
111 SO_KIT_CATALOG_ENTRY_HEADER(scale5Active);
112 SO_KIT_CATALOG_ENTRY_HEADER(scale5LocateGroup);
113 SO_KIT_CATALOG_ENTRY_HEADER(scale5Switch);
114 SO_KIT_CATALOG_ENTRY_HEADER(scale6);
115 SO_KIT_CATALOG_ENTRY_HEADER(scale6Active);
116 SO_KIT_CATALOG_ENTRY_HEADER(scale6LocateGroup);
117 SO_KIT_CATALOG_ENTRY_HEADER(scale6Switch);
118 SO_KIT_CATALOG_ENTRY_HEADER(scale7);
119 SO_KIT_CATALOG_ENTRY_HEADER(scale7Active);
120 SO_KIT_CATALOG_ENTRY_HEADER(scale7LocateGroup);
121 SO_KIT_CATALOG_ENTRY_HEADER(scale7Switch);
122 SO_KIT_CATALOG_ENTRY_HEADER(scale8);
123 SO_KIT_CATALOG_ENTRY_HEADER(scale8Active);
124 SO_KIT_CATALOG_ENTRY_HEADER(scale8LocateGroup);
125 SO_KIT_CATALOG_ENTRY_HEADER(scale8Switch);
126 SO_KIT_CATALOG_ENTRY_HEADER(scaleBoxFeedback);
127 SO_KIT_CATALOG_ENTRY_HEADER(scaleBoxFeedbackSwitch);
128 SO_KIT_CATALOG_ENTRY_HEADER(scaleSep);
129 SO_KIT_CATALOG_ENTRY_HEADER(surroundScale);
130 SO_KIT_CATALOG_ENTRY_HEADER(translateBoxFeedback);
131 SO_KIT_CATALOG_ENTRY_HEADER(translateBoxFeedbackRotation);
132 SO_KIT_CATALOG_ENTRY_HEADER(translateBoxFeedbackSep);
133 SO_KIT_CATALOG_ENTRY_HEADER(translateBoxFeedbackSwitch);
134 SO_KIT_CATALOG_ENTRY_HEADER(translator1);
135 SO_KIT_CATALOG_ENTRY_HEADER(translator1Active);
136 SO_KIT_CATALOG_ENTRY_HEADER(translator1LocateGroup);
137 SO_KIT_CATALOG_ENTRY_HEADER(translator1Switch);
138 SO_KIT_CATALOG_ENTRY_HEADER(translator2);
139 SO_KIT_CATALOG_ENTRY_HEADER(translator2Active);
140 SO_KIT_CATALOG_ENTRY_HEADER(translator2LocateGroup);
141 SO_KIT_CATALOG_ENTRY_HEADER(translator2Switch);
142 SO_KIT_CATALOG_ENTRY_HEADER(translator3);
143 SO_KIT_CATALOG_ENTRY_HEADER(translator3Active);
144 SO_KIT_CATALOG_ENTRY_HEADER(translator3LocateGroup);
145 SO_KIT_CATALOG_ENTRY_HEADER(translator3Switch);
146 SO_KIT_CATALOG_ENTRY_HEADER(translator4);
147 SO_KIT_CATALOG_ENTRY_HEADER(translator4Active);
148 SO_KIT_CATALOG_ENTRY_HEADER(translator4LocateGroup);
149 SO_KIT_CATALOG_ENTRY_HEADER(translator4Switch);
150 SO_KIT_CATALOG_ENTRY_HEADER(translator5);
151 SO_KIT_CATALOG_ENTRY_HEADER(translator5Active);
152 SO_KIT_CATALOG_ENTRY_HEADER(translator5LocateGroup);
153 SO_KIT_CATALOG_ENTRY_HEADER(translator5Switch);
154 SO_KIT_CATALOG_ENTRY_HEADER(translator6);
155 SO_KIT_CATALOG_ENTRY_HEADER(translator6Active);
156 SO_KIT_CATALOG_ENTRY_HEADER(translator6LocateGroup);
157 SO_KIT_CATALOG_ENTRY_HEADER(translator6Switch);
158 SO_KIT_CATALOG_ENTRY_HEADER(translatorSep);
159 SO_KIT_CATALOG_ENTRY_HEADER(xAxisFeedbackActive);
160 SO_KIT_CATALOG_ENTRY_HEADER(xAxisFeedbackSelect);
161 SO_KIT_CATALOG_ENTRY_HEADER(xAxisFeedbackSwitch);
162 SO_KIT_CATALOG_ENTRY_HEADER(xCircleFeedback);
163 SO_KIT_CATALOG_ENTRY_HEADER(xCircleFeedbackSwitch);
164 SO_KIT_CATALOG_ENTRY_HEADER(xCrosshairFeedback);
165 SO_KIT_CATALOG_ENTRY_HEADER(yAxisFeedbackActive);
166 SO_KIT_CATALOG_ENTRY_HEADER(yAxisFeedbackSelect);
167 SO_KIT_CATALOG_ENTRY_HEADER(yAxisFeedbackSwitch);
168 SO_KIT_CATALOG_ENTRY_HEADER(yCircleFeedback);
169 SO_KIT_CATALOG_ENTRY_HEADER(yCircleFeedbackSwitch);
170 SO_KIT_CATALOG_ENTRY_HEADER(yCrosshairFeedback);
171 SO_KIT_CATALOG_ENTRY_HEADER(zAxisFeedbackActive);
172 SO_KIT_CATALOG_ENTRY_HEADER(zAxisFeedbackSelect);
173 SO_KIT_CATALOG_ENTRY_HEADER(zAxisFeedbackSwitch);
174 SO_KIT_CATALOG_ENTRY_HEADER(zCircleFeedback);
175 SO_KIT_CATALOG_ENTRY_HEADER(zCircleFeedbackSwitch);
176 SO_KIT_CATALOG_ENTRY_HEADER(zCrosshairFeedback);
215 State getCurrentState(
void);
217 void unsquishKnobs(
void);
219 SbBool isLocateHighlighting(
void);
220 void setLocateHighlighting(SbBool onoff);
222 static void setColinearThreshold(
int newval);
223 static int getColinearThreshold(
void);
227 SbVec3f getWorldPointInBoxSpace(
const SbVec3f & pointinworldspace);
230 SbVec3f getInteractiveCenterInBoxSpace(
void);
237 static void startCB(
void * f,
SoDragger * d);
238 static void motionCB(
void * f,
SoDragger * d);
239 static void finishCB(
void * f,
SoDragger * d);
240 static void metaKeyChangeCB(
void *,
SoDragger *);
242 static void valueChangedCB(
void * f,
SoDragger * d);
244 void dragStart(
void);
246 void dragFinish(
void);
248 void updateAntiSquishList(
void);
249 void setAllPartSwitches(
int scalewhich,
int rotatewhich,
int translatewhich);
250 int getMouseGestureDirection(SbBool x_ok, SbBool y_ok, SbBool z_ok);
251 static int getIgnoreAxis(
SbVec2f axis[3][2],
252 SbBool x_ok, SbBool y_ok, SbBool z_ok);
253 static void makeMinorAxisPerpendicularIfColinear(
SbVec2f origin,
SbVec2f axisends[3][2],
int index_a,
int index_b);
254 static SbBool isColinear(
SbVec2f a1[2],
SbVec2f a2[2],
int pixels);
263 SoNode *getNodeFieldNode(
const char *fieldname);
265 void build_catalog1(
void);
266 void build_catalog2(
void);
267 void build_catalog3(
void);
268 void build_catalog4(
void);
269 void build_catalog5(
void);
270 void build_catalog6(
void);
272 SbMatrix getWorkingToWorldMatrix(
void);
273 SbMatrix getWorldToWorkingMatrix(
void);
279 SbBool setDynamicTranslatorSwitches(
const SoEvent *event);
280 SbBool setDynamicRotatorSwitches(
const SoEvent *event);
281 SbBool setDynamicScaleSwitches(
const SoEvent *event);
283 void dragTranslate();
294 class SoTransformerDraggerP * pimpl;
295 friend class SoTransformerDraggerP;
298 #endif // !COIN_SOTRANSFORMERDRAGGER_H
The SoSFVec3f class is a container for an SbVec3f vector.
Definition: SoSFVec3f.h:31
int getLength(void) const
Definition: SbPList.h:94
const float * getValue(void) const
Definition: SbRotation.cpp:179
SbVec3f getPlanePoint(const float distFromEye, const SbVec2f &normPoint) const
Definition: SbViewVolume.cpp:319
The SbRotation class represents a rotation in 3D space.
Definition: SbRotation.h:33
void setType(const SoType type, const SbBool chkderived=1)
Definition: SoSearchAction.cpp:175
void workFieldsIntoTransform(SbMatrix &mtx)
Definition: SoDragger.cpp:1123
The SoRotation class specifies a rotation transformation.
Definition: SoRotation.h:31
SbBool wasShiftDown(void) const
Definition: SoEvent.cpp:236
const SbVec2s & getViewportSizePixels(void) const
Definition: SbViewportRegion.cpp:425
virtual SoField * getField(const SbName &name) const
Definition: SoFieldContainer.cpp:364
static SbMatrix appendTranslation(const SbMatrix &mtx, const SbVec3f &translation, const SbMatrix *conversion=NULL)
Definition: SoDragger.cpp:1252
The SbVec2f class is a 2 dimensional vector with floating point coordinates.
Definition: SbVec2f.h:36
virtual void apply(SoNode *root)
Definition: SoAction.cpp:476
virtual void setWorkingSpace(const SbMatrix &space)
Definition: SbSphereProjector.cpp:220
static SbRotation identity(void)
Definition: SbRotation.cpp:674
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 SoSFRotation class is a container for an SbRotation.
Definition: SoSFRotation.h:31
The SbPlaneProjector class projects 2D points to 3D points in a plane.
Definition: SbPlaneProjector.h:31
void print(FILE *fp) const
Definition: SbMatrix.cpp:1448
The SbCylinderPlaneProjector class projects 2D points to a half-cylinder and a plane.
Definition: SbCylinderPlaneProjector.h:29
void append(SoNode *const ptr)
Definition: SoNodeList.cpp:80
virtual SoNode * getAnyPart(const SbName &partname, SbBool makeifneeded, SbBool leafcheck=0, SbBool publiccheck=0)
Definition: SoBaseKit.cpp:1722
The SbSphereProjector class is the abstract base class for mapping to spherical surfaces.
Definition: SbSphereProjector.h:31
The SoSensor class is the abstract base class for all sensors.
Definition: SoSensor.h:34
SbBool isPointInFront(const SbVec3f &point) const
Definition: SbSphereProjector.cpp:182
SbBool isAdequateConstraintMotion(void)
Definition: SoDragger.cpp:1462
virtual SoNode * getPart(const SbName &partname, SbBool makeifneeded)
Definition: SoBaseKit.cpp:699
SbVec2s getLocaterPosition(void)
Definition: SoDragger.cpp:1424
const SbPlane & getPlane(void) const
Definition: SbPlaneProjector.cpp:193
ProjectorFrontSetting getFrontOnProjector(void) const
Definition: SoDragger.cpp:1165
const SoEvent * getEvent(void) const
Definition: SoDragger.cpp:962
void multVecMatrix(const SbVec3f &src, SbVec3f &dst) const
Definition: SbMatrix.cpp:1357
float getDistance(const SbVec3f &point) const
Definition: SbPlane.cpp:242
SoField * getAttachedField(void) const
Definition: SoFieldSensor.cpp:107
void setFront(const SbBool infront)
Definition: SbSphereProjector.cpp:161
void addOtherEventCallback(SoDraggerCB *func, void *data=NULL)
Definition: SoDragger.cpp:702
The SoSearchAction class provides methods for searching through scene graphs.
Definition: SoSearchAction.h:32
SbMatrix & multLeft(const SbMatrix &m)
Definition: SbMatrix.cpp:1280
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 SoFullPath class allows examination of hidden children in paths.
Definition: SoFullPath.h:29
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 transform(const SbMatrix &matrix)
Definition: SbPlane.cpp:203
virtual SbVec3f project(const SbVec2f &point)=0
The SoPathList class is a container for pointers to SoPath objects.
Definition: SoPathList.h:31
SbMatrix & multRight(const SbMatrix &m)
Definition: SbMatrix.cpp:1240
The SoDragger class is the base class for all draggers.
Definition: SoDragger.h:53
The SbString class is a string class with convenience functions for string operations.
Definition: SbString.h:42
SoNode * getTail(void) const
Definition: SoFullPath.cpp:74
float getNearDist(void) const
Definition: SbViewVolume.cpp:620
static void readDefaultParts(const char *fileName, const char defaultBuffer[], int defBufSize)
Definition: SoInteractionKit.cpp:433
@ FRONT
Definition: SoDragger.h:63
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
float length(void) const
Definition: SbVec3f.cpp:356
static SbMatrix appendRotation(const SbMatrix &mtx, const SbRotation &rot, const SbVec3f &rotcenter, const SbMatrix *conversion=NULL)
Definition: SoDragger.cpp:1388
@ USE_PICK
Definition: SoDragger.h:63
void invalidate(void)
Definition: SoSurroundScale.cpp:270
The SbVec2s class is a 2 dimensional vector with short integer coordinates.
Definition: SbVec2s.h:37
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
SoSFRotation rotation
Definition: SoRotation.h:40
void setDefault(SbBool def)
Definition: SoField.cpp:650
The SoLocateHighlight class highlights geometry under the cursor.
Definition: SoLocateHighlight.h:35
void recalc(void)
Definition: SoAntiSquish.cpp:151
const SbVec3f & getNormal(void) const
Definition: SbPlane.cpp:254
void setLine(const SbLine &line)
Definition: SbLineProjector.cpp:131
The SbSphere class is a representation of a sphere.
Definition: SbSphere.h:33
SoSFEnum sizing
Definition: SoAntiSquish.h:47
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
Sizing
Definition: SoAntiSquish.h:42
SbMatrix getWorldToLocalMatrix(void)
Definition: SoDragger.cpp:791
void multDirMatrix(const SbVec3f &src, SbVec3f &dst) const
Definition: SbMatrix.cpp:1411
void setSphere(const SbSphere &sph)
Definition: SbSphereProjector.cpp:121
static SbMatrix appendScale(const SbMatrix &mtx, const SbVec3f &scale, const SbVec3f &scalecenter, const SbMatrix *conversion=NULL)
Definition: SoDragger.cpp:1271
The SbSphereSectionProjector projects 2D points to a sliced sphere.
Definition: SbSphereSectionProjector.h:30
SoSFBool isActive
Definition: SoDragger.h:61
virtual void saveStartParameters(void)
Definition: SoDragger.cpp:944
SoSFVec3f translation
Definition: SoTranslation.h:40
void setInterest(const Interest interest)
Definition: SoSearchAction.cpp:249
The SbVec3f class is a 3 dimensional vector with floating point coordinates.
Definition: SbVec3f.h:37
float dot(const SbVec3f &v) const
Definition: SbVec3f.cpp:282
virtual void setDefaultOnNonWritingFields(void)
Definition: SoDragger.cpp:1743
SbString & sprintf(const char *formatstr,...)
Definition: SbString.h:105
SbBool connectionsSetUp
Definition: SoBaseKit.h:142
SoPathList & getPaths(void)
Definition: SoSearchAction.cpp:331
SbVec2s getStartLocaterPosition(void) const
Definition: SoDragger.cpp:1440
void attach(SoField *field)
Definition: SoFieldSensor.cpp:77
The SbViewportRegion class is a viewport within a full window.
Definition: SbViewportRegion.h:31
void projectToScreen(const SbVec3f &src, SbVec3f &dst) const
Definition: SbViewVolume.cpp:277
const SbMatrix & getMotionMatrix(void)
Definition: SoDragger.cpp:688
void getPartToLocalMatrix(const SbName &partname, SbMatrix &parttolocalmatrix, SbMatrix &localtopartmatrix)
Definition: SoDragger.cpp:826
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
float normalize(void)
Definition: SbVec3f.cpp:436
const SbViewportRegion & getViewportRegion(void)
Definition: SoDragger.cpp:1050
The SbViewVolume class is a viewing volume in 3D space.
Definition: SbViewVolume.h:41
SbVec2f getNormalizedLocaterPosition(void)
Definition: SoDragger.cpp:1408
void setStartingPoint(const SoPickedPoint *newpoint)
Definition: SoDragger.cpp:1014
const SoPath * getPickPath(void) const
Definition: SoDragger.cpp:953
virtual SbVec3f project(const SbVec2f &point)
Definition: SbLineProjector.cpp:67
The SoAntiSquish class is used to reset to uniform scaling.
Definition: SoAntiSquish.h:33
The SoNodeList class is a container for pointers to SoNode objects.
Definition: SoNodeList.h:31
const SbMatrix & getStartMotionMatrix(void)
Definition: SoDragger.cpp:930
The SbCylinderProjector class is the abstract base class for mapping to cylindrical surfaces.
Definition: SbCylinderProjector.h:30
The SoSFFloat class is a container for a floating point value.
Definition: SoSFFloat.h:30
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
void addStartCallback(SoDraggerCB *func, void *data=NULL)
Definition: SoDragger.cpp:570
const SbName & getSurrogatePartPickedName(void) const
Definition: SoDragger.cpp:995
The SoGroup class is a node which managed other node instances.
Definition: SoGroup.h:31
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
float sqrLength() const
Definition: SbVec3f.cpp:367
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
virtual SbBool setPartAsDefault(const SbName &partname, SoNode *node, SbBool onlyifdefault=1)
Definition: SoInteractionKit.cpp:271
void setSearchingAll(const SbBool searchall)
Definition: SoSearchAction.cpp:278
virtual SbVec3f project(const SbVec2f &point)
Definition: SbPlaneProjector.cpp:101
@ BACK
Definition: SoDragger.h:63
SbMatrix getLocalToWorldMatrix(void)
Definition: SoDragger.cpp:776
Copyright © 1998-2007 by Systems in Motion AS. All rights reserved.
Generated on Wed Jul 24 2019 for Coin by Doxygen. 1.8.17