Provided by: inventor-doc_2.1.5-10-18_all
NAME
SoDirectionalLightDragger — directional icon you rotate and translate by dragging with the mouse
INHERITS FROM
SoBase > SoFieldContainer > SoNode > SoBaseKit > SoInteractionKit > SoDragger > SoDirectionalLightDragger
SYNOPSIS
#include <Inventor/draggers/SoDirectionalLightDragger.h> Fields from class SoDirectionalLightDragger: SoSFRotation rotation SoSFVec3f translation Fields from class SoDragger: SoSFBool isActive Fields from class SoInteractionKit: SoSFEnum renderCaching SoSFEnum boundingBoxCaching SoSFEnum renderCulling SoSFEnum pickCulling Parts from class SoBaseKit: (SoNodeKitListPart) callbackList Methods from class SoDirectionalLightDragger: SoDirectionalLightDragger() static const SoNodekitCatalog * getClassNodekitCatalog() const static SoType getClassTypeId() Methods from class SoDragger: void addStartCallback(SoDraggerCB *f, void *userData = NULL) void removeStartCallback(SoDraggerCB *f, void *userData = NULL) void addMotionCallback(SoDraggerCB *f, void *userData = NULL) void removeMotionCallback(SoDraggerCB *f, void *userData = NULL) void addFinishCallback(SoDraggerCB *f, void *userData = NULL) void removeFinishCallback(SoDraggerCB *f, void *userData = NULL) void addValueChangedCallback(SoDraggerCB *f, void *userData = NULL) void removeValueChangedCallback(SoDraggerCB *f, void *userData = NULL) SbBool enableValueChangedCallbacks() void setMinGesture(int pixels) int getMinGesture() const static void setMinScale(float newMinScale) static float getMinScale() Methods from class SoInteractionKit: virtual SbBool setPartAsPath(const SbName &partName, SoPath *surrogatePath ) Methods from class SoBaseKit: virtual const SoNodekitCatalog * getNodekitCatalog() const virtual SoNode * getPart(const SbName &partName, SbBool makeIfNeeded) SbString getPartString(const SoBase *part) virtual SoNodeKitPath * createPathToPart(const SbName &partName, SbBool makeIfNeeded, const SoPath *pathToExtend = NULL) virtual SbBool setPart(const SbName &partName, SoNode *newPart) SbBool set(char *partName, char *parameters) SbBool set(char *nameValuePairs) static SbBool isSearchingChildren() static void setSearchingChildren(SbBool newVal) Methods from class SoNode: void setOverride(SbBool state) SbBool isOverride() const SoNode * copy(SbBool copyConnections = FALSE) const virtual SbBool affectsState() const static SoNode * getByName(const SbName &name) static int getByName(const SbName &name, SoNodeList &list) Methods from class SoFieldContainer: void setToDefaults() SbBool hasDefaultValues() const SbBool fieldsAreEqual(const SoFieldContainer *fc) const void copyFieldValues(const SoFieldContainer *fc, SbBool copyConnections = FALSE) void get(SbString &fieldDataString) virtual int getFields(SoFieldList &resultList) const virtual SoField * getField(const SbName &fieldName) const SbBool getFieldName(const SoField *field, SbName &fieldName) const SbBool isNotifyEnabled() const SbBool enableNotify(SbBool flag) Methods from class SoBase: void ref() void unref() const void unrefNoDelete() const void touch() virtual SoType getTypeId() const SbBool isOfType(SoType type) const virtual void setName(const SbName &name) virtual SbName getName() const Macros from class SoBaseKit: SO_GET_PART(kit, partName, partClass) SO_CHECK_PART(kit, partName, partClass)
DESCRIPTION
SoDirectionalLightDragger is a composite dragger. It looks like a sun with a large arrow coming out of it. The arrow can be rotated about the sun by dragging with the mouse; its orientation is given by the rotation field. You can also drag the sun (and the arrow with it) through 3-space. The location is stored in the translation field. The dragger uses an SoRotateSphericalDragger for changing the rotation. Instead of using the default spherical geometry, this dragger uses an arrow shape. The sun is an SoDragPointDragger. Dragging it edits the translation field; conversely, if you change the translation field the sun will move to that new location, bringing the arrow with it. The sun looks and behaves just like the sun in an SoPointLightDragger, as does the material part. See the SoPointLightDragger man page for details. Remember: This is not a light source! It just looks like one. If you want to move a light with this dragger, you can either: [a] Use an SoDirectionalLightManip, which is subclassed from SoLight. It creates an SoDirectionalLightDragger and uses it as the interface to change the direction of its light source (see the SoDirectionalLightManip man page). The manipulator also edits the material part of this dragger to match the color of light the manipulator is producing. However, the directional light manipulator will ignore the translation field, because a directional light has no location or translation field. So in this case the translation dragger merely allows you to move the physical arrow to wherever you'd like it to be. [b] Put an SoTransform under an SoTransformSeparator. Add the SoDirectionalLight as the next child. Use a field-to-field connection between the rotation fields of this dragger and the transform node to synchronize the light with this dragger. [c] Use engines to connect the rotation field of this dragger to the direction field of an SoDirectionalLight. Use the rotation as input to an SoComposeMatrix engine. Then, use an SoTransformVec3f engine to apply that matrix to (0,0,-1), the default light direction. You can change the parts in any instance of this dragger using setPart(). The default part geometries are defined as resources for this SoDirectionalLightDragger class. They are detailed in the Dragger Resources section of the online reference page for this class. You can make your program use different default resources for the parts by copying the file /usr/share/data/draggerDefaults/directionalLightDragger.iv into your own directory, editing the file, and then setting the environment variable SO_DRAGGER_DIR to be a path to that directory.
FIELDS
SoSFRotation rotation Orientation of the rotating part (an arrow by default). SoSFVec3f translation Position of the origin of the directional light dragger.
METHODS
SoDirectionalLightDragger() Constructor. static const SoNodekitCatalog * getClassNodekitCatalog() const Returns an SoNodekitCatalog for this class static SoType getClassTypeId() Returns type identifier for this class.
CATALOG PARTS
┌───────────────────────────────────────────────────────────────────┐ │ All parts │ │ NULL by │ │Part Name Part Type Default Type Default │ │ │ │callbackList NodeKitListPart -- yes │ │material Material -- yes │ │translatorRotInv Rotation -- yes │ │translator DragPointDragger -- yes │ │rotator RotateSphericalDragger -- yes │ │ │ └───────────────────────────────────────────────────────────────────┘ ┌───────────────────────────────────────────────────────────────┐ │ Extra information for list parts from above table │ │ │ │Part Name Container Type Permissible Types │ │ │ │callbackList Separator Callback, EventCallback │ │ │ └───────────────────────────────────────────────────────────────┘
DRAGGER RESOURCES
.in 0n+.5i Resource: directionalLightRotatorRotator .in 0n+.5i Part: rotator.rotator Appearance: white arrow that goes through the sun Description: picking this begins rotation of the arrow about the sun-shape .in 0n+.5i Resource: directionalLightRotatorRotatorActive .in 0n+.5i Part: rotator.rotatorActive Appearance: yellow arrow that goes through the sun Description: displayed while the arrow is being rotated .in 0n+.5i Resource: directionalLightRotatorFeedback .in 0n+.5i Part: rotator.feedback Appearance: empty Separator Description: this disables display of the axes that a rotateSpherical dragger uses by default .in 0n+.5i Resource: directionalLightRotatorFeedbackActive .in 0n+.5i Part: rotator.feedbackActive Appearance: empty Separator Description: this disables display of the axes that a rotateSpherical dragger uses by default .in 0n+.5i Resource: directionalLightOverallMaterial .in 0n+.5i Part: material Appearance: white. half strength emissive, half strength diffuse Description: sets material for the sun shape when stationary. Resource for the moving sun, directionalLightTranslatorPlaneTranslatorActive, contains a yellow material for highlighting. .in 0n+.5i Resource: directionalLightTranslatorPlaneTranslator .in 0n+.5i Parts: translator.yzTranslator.translator translator.xzTranslator.translator translator.xyTranslator.translator Appearance: sun shape with no material Description: picking these parts initiates dragging by the yz, xz, and xy planar draggers respectively. .in 0n+.5i Resource: directionalLightTranslatorPlaneTranslatorActive .in 0n+.5i Parts: translator.yzTranslator.translatorActive translator.xzTranslator.translatorActive translator.xyTranslator.translatorActive Appearance: yellow sun shape Description: shown during planar dragging in the yz, xz, and xy planes respectively. .in 0n+.5i Resource: directionalLightTranslatorLineTranslator .in 0n+.5i Parts: translator.xTranslator.translator translator.yTranslator.translator translator.zTranslator.translator Appearance: white cylinder Description: picking these parts initiates dragging in the x, y, and z linear draggers respectively. .in 0n+.5i Resource: directionalLightTranslatorLineTranslatorActive .in 0n+.5i Parts: translator.xTranslator.translatorActive translator.yTranslator.translatorActive translator.zTranslator.translatorActive Appearance: yellow cylinder Description: shown during linear dragging in the x, y, and z directions respectively.
FILE FORMAT/DEFAULTS
DirectionalLightDragger { renderCaching AUTO boundingBoxCaching AUTO renderCulling AUTO pickCulling AUTO isActive FALSE translation 0 0 0 rotation 0 0 1 0 callbackList NULL material <directionalLightOverallMaterial resource> translatorRotInv NULL translator DragPointDragger { } rotator RotateSphericalDragger { } rotator.rotator <directionalLightRotatorRotator resource> rotator.rotatorActive <directionalLightRotatorRotatorActive resource> rotator.feedback <directionalLightRotatorFeedback resource> rotator.feedbackActive <directionalLightRotatorFeedbackActive resource> translator.yzTranslator.translator <directionalLightTranslatorPlaneTranslator resource> translator.xzTranslator.translator <directionalLightTranslatorPlaneTranslator resource> translator.xyTranslator.translator <directionalLightTranslatorPlaneTranslator resource> translator.yzTranslator.translatorActive <directionalLightTranslatorPlaneTranslatorActive resource> translator.xzTranslator.translatorActive <directionalLightTranslatorPlaneTranslatorActive resource> translator.xyTranslator.translatorActive <directionalLightTranslatorPlaneTranslatorActive resource> translator.xTranslator.translator <directionalLightTranslatorLineTranslator resource> translator.yTranslator.translator <directionalLightTranslatorLineTranslator resource> translator.zTranslator.translator <directionalLightTranslatorLineTranslator resource> translator.xTranslator.translatorActive <directionalLightTranslatorLineTranslatorActive resource> translator.yTranslator.translatorActive <directionalLightTranslatorLineTranslatorActive resource> translator.zTranslator.translatorActive <directionalLightTranslatorLineTranslatorActive resource> }
SEE ALSO
SoInteractionKit, SoDragger, SoCenterballDragger, SoDragPointDragger, SoHandleBoxDragger, SoJackDragger, SoPointLightDragger, SoRotateCylindricalDragger, SoRotateDiscDragger, SoRotateSphericalDragger, SoScale1Dragger, SoScale2Dragger, SoScale2UniformDragger, SoScaleUniformDragger, SoSpotLightDragger, SoTabBoxDragger, SoTabPlaneDragger, SoTrackballDragger, SoTransformBoxDragger, SoTransformerDragger, SoTranslate1Dragger, SoTranslate2Dragger SoDirectionalLightDragger(3IV)()