1 #ifndef COIN_SOTABPLANEDRAGGER_H
2 #define COIN_SOTABPLANEDRAGGER_H
27 #include <Inventor/draggers/SoDragger.h>
28 #include <Inventor/fields/SoSFVec3f.h>
41 SO_KIT_CATALOG_ENTRY_HEADER(cornerScaleCoords);
42 SO_KIT_CATALOG_ENTRY_HEADER(cornerScaleTab0);
43 SO_KIT_CATALOG_ENTRY_HEADER(cornerScaleTab1);
44 SO_KIT_CATALOG_ENTRY_HEADER(cornerScaleTab2);
45 SO_KIT_CATALOG_ENTRY_HEADER(cornerScaleTab3);
46 SO_KIT_CATALOG_ENTRY_HEADER(edgeScaleCoords);
47 SO_KIT_CATALOG_ENTRY_HEADER(edgeScaleTab0);
48 SO_KIT_CATALOG_ENTRY_HEADER(edgeScaleTab1);
49 SO_KIT_CATALOG_ENTRY_HEADER(edgeScaleTab2);
50 SO_KIT_CATALOG_ENTRY_HEADER(edgeScaleTab3);
51 SO_KIT_CATALOG_ENTRY_HEADER(planeSwitch);
52 SO_KIT_CATALOG_ENTRY_HEADER(scaleTabHints);
53 SO_KIT_CATALOG_ENTRY_HEADER(scaleTabMaterial);
54 SO_KIT_CATALOG_ENTRY_HEADER(scaleTabMaterialBinding);
55 SO_KIT_CATALOG_ENTRY_HEADER(scaleTabNormal);
56 SO_KIT_CATALOG_ENTRY_HEADER(scaleTabNormalBinding);
57 SO_KIT_CATALOG_ENTRY_HEADER(scaleTabs);
58 SO_KIT_CATALOG_ENTRY_HEADER(translator);
68 void adjustScaleTabSize(
void);
81 void getXYScreenLengths(
SbVec2f & lengths,
const SbMatrix & localtoscreen,
86 void dragFinish(
void);
96 static void startCB(
void * f,
SoDragger * d);
97 static void motionCB(
void * f,
SoDragger * d);
98 static void finishCB(
void * f,
SoDragger * d);
99 static void metaKeyChangeCB(
void * f,
SoDragger * d);
101 static void valueChangedCB(
void * f,
SoDragger * d);
103 void createPrivateParts(
void);
104 SoNode *getNodeFieldNode(
const char *fieldname);
119 #endif // !COIN_SOTABPLANEDRAGGER_H
@ OFF
Definition: SoSeparator.h:45
The SoSFVec3f class is a container for an SbVec3f vector.
Definition: SoSFVec3f.h:31
SoMFInt32 normalIndex
Definition: SoIndexedShape.h:44
The SbRotation class represents a rotation in 3D space.
Definition: SbRotation.h:33
void workFieldsIntoTransform(SbMatrix &mtx)
Definition: SoDragger.cpp:1123
The SoState class manages the Coin scenegraph traversal state data.
Definition: SoState.h:35
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 SbName class stores strings by reference.
Definition: SbName.h:31
The SbVec2f class is a 2 dimensional vector with floating point coordinates.
Definition: SbVec2f.h:36
SbVec3f getLocalStartingPoint(void)
Definition: SoDragger.cpp:805
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 SoIndexedFaceSet class is used to handle generic indexed facesets.
Definition: SoIndexedFaceSet.h:36
virtual SoNode * getAnyPart(const SbName &partname, SbBool makeifneeded, SbBool leafcheck=0, SbBool publiccheck=0)
Definition: SoBaseKit.cpp:1722
The SoNormal class is a node for providing normals to the state.
Definition: SoNormal.h:33
The SoSensor class is the abstract base class for all sensors.
Definition: SoSensor.h:34
SbBool isAdequateConstraintMotion(void)
Definition: SoDragger.cpp:1462
SoMFInt32 coordIndex
Definition: SoIndexedShape.h:42
float getWorldToScreenScale(const SbVec3f &worldCenter, float normRadius) const
Definition: SbViewVolume.cpp:352
const SoEvent * getEvent(void) const
Definition: SoDragger.cpp:962
void multVecMatrix(const SbVec3f &src, SbVec3f &dst) const
Definition: SbMatrix.cpp:1357
@ OVERALL
Definition: SoMaterialBinding.h:41
SbBool enableNotify(const SbBool flag)
Definition: SoFieldContainer.cpp:443
SoField * getAttachedField(void) const
Definition: SoFieldSensor.cpp:107
The SoMaterialBinding class is a node for setting up how materials are mapped to shapes.
Definition: SoMaterialBinding.h:31
void addOtherEventCallback(SoDraggerCB *func, void *data=NULL)
Definition: SoDragger.cpp:702
virtual SbBool setUpConnections(SbBool onoff, SbBool doitalways=0)
Definition: SoTabPlaneDragger.cpp:277
SbMatrix & multLeft(const SbMatrix &m)
Definition: SbMatrix.cpp:1280
void dragStart(void)
Definition: SoTabPlaneDragger.cpp:496
SoMFVec3f point
Definition: SoCoordinate3.h:39
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
The SoNormalBinding class is a node for specifying normal vector bindings.
Definition: SoNormalBinding.h:31
virtual void GLRender(SoGLRenderAction *action)
Definition: SoDragger.cpp:505
void setPriority(uint32_t pri)
Definition: SoDelayQueueSensor.cpp:108
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
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
float length(void) const
Definition: SbVec3f.cpp:356
void drag(void)
Definition: SoTabPlaneDragger.cpp:562
void adjustScaleTabSize(void)
Definition: SoTabPlaneDragger.cpp:375
SoSFEnum value
Definition: SoNormalBinding.h:55
SoSFEnum renderCaching
Definition: SoSeparator.h:48
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
void reallyAdjustScaleTabSize(SoGLRenderAction *action)
Definition: SoTabPlaneDragger.cpp:386
void setDefault(SbBool def)
Definition: SoField.cpp:650
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
SbVec3f & setValue(const float v[3])
Definition: SbVec3f.cpp:461
virtual void GLRender(SoGLRenderAction *action)
Definition: SoTabPlaneDragger.cpp:348
SoState * getState(void) const
Definition: SoAction.cpp:1028
SbMatrix getWorldToLocalMatrix(void)
Definition: SoDragger.cpp:791
SoSFEnum value
Definition: SoMaterialBinding.h:55
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
virtual void saveStartParameters(void)
Definition: SoDragger.cpp:944
The SbVec3f class is a 3 dimensional vector with floating point coordinates.
Definition: SbVec3f.h:37
~SoTabPlaneDragger()
Definition: SoTabPlaneDragger.cpp:267
float dot(const SbVec3f &v) const
Definition: SbVec3f.cpp:282
The SoTabPlaneDragger class is a dragger you can translate and scale within a plane.
Definition: SoTabPlaneDragger.h:36
virtual void setDefaultOnNonWritingFields(void)
Definition: SoDragger.cpp:1743
SbString & sprintf(const char *formatstr,...)
Definition: SbString.h:105
SbBool connectionsSetUp
Definition: SoBaseKit.h:142
void attach(SoField *field)
Definition: SoFieldSensor.cpp:77
The SbViewportRegion class is a viewport within a full window.
Definition: SbViewportRegion.h:31
const SbMatrix & getMotionMatrix(void)
Definition: SoDragger.cpp:688
void dragFinish(void)
Definition: SoTabPlaneDragger.cpp:666
The SoFieldSensor class detects changes to a field.
Definition: SoFieldSensor.h:29
SoMFInt32 materialIndex
Definition: SoIndexedShape.h:43
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
void getXYScreenLengths(SbVec2f &lengths, const SbMatrix &localtoscreen, const SbVec2s &winsize)
Definition: SoTabPlaneDragger.cpp:482
The SoSeparator class is a state-preserving group node.
Definition: SoSeparator.h:34
The SbViewVolume class is a viewing volume in 3D space.
Definition: SbViewVolume.h:41
SbVec2f getNormalizedLocaterPosition(void)
Definition: SoDragger.cpp:1408
void setNum(const int num)
Definition: SoMField.cpp:615
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
const SbMatrix & getStartMotionMatrix(void)
Definition: SoDragger.cpp:930
SoTabPlaneDragger(void)
Definition: SoTabPlaneDragger.cpp:195
The SoNode class is the base class for nodes used in scene graphs.
Definition: SoNode.h:47
The SoMaterial class is a node type for setting up material values for scene geometry.
Definition: SoMaterial.h:34
void addStartCallback(SoDraggerCB *func, void *data=NULL)
Definition: SoDragger.cpp:570
virtual void setDefaultOnNonWritingFields(void)
Definition: SoTabPlaneDragger.cpp:307
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
The SoEvent class is the base class for all Coin events.
Definition: SoEvent.h:34
The SoShapeHints class is a node containing hints about how to render geometry.
Definition: SoShapeHints.h:32
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
SoSFVec3f scaleFactor
Definition: SoTabPlaneDragger.h:66
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
The SoGLRenderAction class renders the scene graph with OpenGL calls.
Definition: SoGLRenderAction.h:39
SoSFVec3f translation
Definition: SoTabPlaneDragger.h:65
The SoCoordinate3 class is a node for providing coordinates to shape nodes.
Definition: SoCoordinate3.h:30
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
SoMFVec3f vector
Definition: SoNormal.h:42
Copyright © 1998-2007 by Systems in Motion AS. All rights reserved.
Generated on Wed Jul 24 2019 for Coin by Doxygen. 1.8.17