1 #ifndef COIN_SOSPOTLIGHTDRAGGER_H
2 #define COIN_SOSPOTLIGHTDRAGGER_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>
42 SO_KIT_CATALOG_ENTRY_HEADER(beam);
43 SO_KIT_CATALOG_ENTRY_HEADER(beamActive);
44 SO_KIT_CATALOG_ENTRY_HEADER(beamPlacement);
45 SO_KIT_CATALOG_ENTRY_HEADER(beamScale);
46 SO_KIT_CATALOG_ENTRY_HEADER(beamSep);
47 SO_KIT_CATALOG_ENTRY_HEADER(beamSwitch);
48 SO_KIT_CATALOG_ENTRY_HEADER(material);
49 SO_KIT_CATALOG_ENTRY_HEADER(rotator);
50 SO_KIT_CATALOG_ENTRY_HEADER(translator);
51 SO_KIT_CATALOG_ENTRY_HEADER(translatorRotInv);
52 SO_KIT_CATALOG_ENTRY_HEADER(translatorSep);
68 static void startCB(
void * f,
SoDragger * d);
69 static void motionCB(
void * f,
SoDragger * d);
70 static void doneCB(
void * f,
SoDragger * d);
72 static void valueChangedCB(
void * f,
SoDragger * d);
76 void dragFinish(
void);
78 void setBeamScaleFromAngle(
float beamangle);
86 #endif // !COIN_SOSPOTLIGHTDRAGGER_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
static void doneCB(void *f, SoDragger *d)
Definition: SoSpotLightDragger.cpp:413
void registerChildDragger(SoDragger *child)
Definition: SoDragger.cpp:722
The SoRotation class specifies a rotation transformation.
Definition: SoRotation.h:31
SoSFRotation rotation
Definition: SoSpotLightDragger.h:59
~SoSpotLightDragger()
Definition: SoSpotLightDragger.cpp:254
SbVec3f getLocalStartingPoint(void)
Definition: SoDragger.cpp:805
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
virtual SoNode * getAnyPart(const SbName &partname, SbBool makeifneeded, SbBool leafcheck=0, SbBool publiccheck=0)
Definition: SoBaseKit.cpp:1722
SbPlaneProjector * planeProj
Definition: SoSpotLightDragger.h:83
The SoSensor class is the abstract base class for all sensors.
Definition: SoSensor.h:34
virtual void setDefaultOnNonWritingFields(void)
Definition: SoSpotLightDragger.cpp:335
virtual SbBool setUpConnections(SbBool onoff, SbBool doitalways=0)
Definition: SoSpotLightDragger.cpp:264
SoDragger * getActiveChildDragger(void) const
Definition: SoDragger.cpp:1734
The SoDragPointDragger class provides mechanisms for moving a point in 3D.
Definition: SoDragPointDragger.h:34
static void fieldSensorCB(void *f, SoSensor *s)
Definition: SoSpotLightDragger.cpp:351
The SoRotateSphericalDragger class is for rotating geometry in any direction.
Definition: SoRotateSphericalDragger.h:37
SoField * getAttachedField(void) const
Definition: SoFieldSensor.cpp:107
SoFieldSensor * rotFieldSensor
Definition: SoSpotLightDragger.h:80
The SoSwitch class is a group node which selects one child subgraph for traversal.
Definition: SoSwitch.h:37
The SoScale class is a node type for scaling scene graph geometry.
Definition: SoScale.h:31
static void setSwitchValue(SoNode *node, const int newVal)
Definition: SoInteractionKit.cpp:358
SoFieldSensor * angleFieldSensor
Definition: SoSpotLightDragger.h:82
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
void drag(void)
Definition: SoSpotLightDragger.cpp:442
virtual SbBool setUpConnections(SbBool onoff, SbBool doitalways=0)
Definition: SoInteractionKit.cpp:648
float length(void) const
Definition: SbVec3f.cpp:356
SoSFVec3f translation
Definition: SoSpotLightDragger.h:60
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
void setBeamScaleFromAngle(float beamangle)
Definition: SoSpotLightDragger.cpp:476
SoSFRotation rotation
Definition: SoRotation.h:40
void setDefault(SbBool def)
Definition: SoField.cpp:650
SbRotation inverse(void) const
Definition: SbRotation.cpp:316
SoSFVec3f scaleFactor
Definition: SoScale.h:40
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 motionCB(void *f, SoDragger *d)
Definition: SoSpotLightDragger.cpp:405
The SoSpotLightDragger class provides interactive geometry for manipulating a spotlight.
Definition: SoSpotLightDragger.h:37
SoSpotLightDragger(void)
Definition: SoSpotLightDragger.cpp:181
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
SbBool connectionsSetUp
Definition: SoBaseKit.h:142
static void startCB(void *f, SoDragger *d)
Definition: SoSpotLightDragger.cpp:397
void attach(SoField *field)
Definition: SoFieldSensor.cpp:77
SbBool isConnectionEnabled(void) const
Definition: SoField.cpp:721
const SbMatrix & getMotionMatrix(void)
Definition: SoDragger.cpp:688
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
SoSFFloat angle
Definition: SoSpotLightDragger.h:61
The SoSeparator class is a state-preserving group node.
Definition: SoSeparator.h:34
void unregisterChildDragger(SoDragger *child)
Definition: SoDragger.cpp:735
SbVec2f getNormalizedLocaterPosition(void)
Definition: SoDragger.cpp:1408
The SoSFFloat class is a container for a floating point value.
Definition: SoSFFloat.h:30
The SoMaterial class is a node type for setting up material values for scene geometry.
Definition: SoMaterial.h:34
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
static void valueChangedCB(void *f, SoDragger *d)
Definition: SoSpotLightDragger.cpp:373
static void fieldSensorCB(void *, SoSensor *)
Definition: SoInteractionKit.cpp:725
void valueChanged(void)
Definition: SoDragger.cpp:919
void addMotionCallback(SoDraggerCB *func, void *data=NULL)
Definition: SoDragger.cpp:591
void setPlane(const SbPlane &plane)
Definition: SbPlaneProjector.cpp:183
void dragFinish(void)
Definition: SoSpotLightDragger.cpp:463
SoFieldSensor * translFieldSensor
Definition: SoSpotLightDragger.h:81
The SbPlane class represents a plane in 3D space.
Definition: SbPlane.h:34
static void initClass(void)
Definition: SoDragger.cpp:388
virtual SbBool setPartAsDefault(const SbName &partname, SoNode *node, SbBool onlyifdefault=1)
Definition: SoInteractionKit.cpp:271
void dragStart(void)
Definition: SoSpotLightDragger.cpp:423
virtual SbVec3f project(const SbVec2f &point)
Definition: SbPlaneProjector.cpp:101
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