Provided by: inventor-doc_2.1.6+ds-2_all bug

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)()