Coin Logo http://www.coin3d.org/
http://www.kongsberg.com/kogt/

SoDirectionalLightManip.h
1 #ifndef COIN_SODIRECTIONALLIGHTMANIP_H
2 #define COIN_SODIRECTIONALLIGHTMANIP_H
3 
4 /**************************************************************************\
5  * Copyright (c) Kongsberg Oil & Gas Technologies AS
6  * All rights reserved.
7  *
8  * Redistribution and use in source and binary forms, with or without
9  * modification, are permitted provided that the following conditions are
10  * met:
11  *
12  * Redistributions of source code must retain the above copyright notice,
13  * this list of conditions and the following disclaimer.
14  *
15  * Redistributions in binary form must reproduce the above copyright
16  * notice, this list of conditions and the following disclaimer in the
17  * documentation and/or other materials provided with the distribution.
18  *
19  * Neither the name of the copyright holder nor the names of its
20  * contributors may be used to endorse or promote products derived from
21  * this software without specific prior written permission.
22  *
23  * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
24  * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
25  * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
26  * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
27  * HOLDER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
28  * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
29  * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
30  * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
31  * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
32  * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
33  * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
34 \**************************************************************************/
35 
36 #include <Inventor/nodes/SoDirectionalLight.h>
37 #include <Inventor/tools/SbLazyPimplPtr.h>
38 #ifndef COIN_INTERNAL
40 #endif
41 
42 class SoChildList;
43 class SoDragger;
44 class SoFieldSensor;
45 class SoPath;
46 class SoSensor;
47 class SbVec3f;
48 class SbMatrix;
49 class SoDirectionalLightManipP;
50 
51 class COIN_DLL_API SoDirectionalLightManip : public SoDirectionalLight {
53 
55 
56 public:
57  static void initClass(void);
59 
60  SoDragger * getDragger(void);
61  SbBool replaceNode(SoPath * path);
62  SbBool replaceManip(SoPath * path, SoDirectionalLight * newone) const;
63 
64  virtual void doAction(SoAction * action);
65  virtual void callback(SoCallbackAction * action);
66  virtual void GLRender(SoGLRenderAction * action);
67  virtual void getBoundingBox(SoGetBoundingBoxAction * action);
68  virtual void getMatrix(SoGetMatrixAction * action);
69  virtual void handleEvent(SoHandleEventAction * action);
70  virtual void pick(SoPickAction * action);
71  virtual void search(SoSearchAction * action);
72 
73  virtual SoChildList * getChildren(void) const;
74 
75 protected:
76  virtual ~SoDirectionalLightManip(void);
77 
78  void setDragger(SoDragger * newdragger);
79 
80  virtual void copyContents(const SoFieldContainer * fromfc, SbBool copyconnections);
81  static void transferFieldValues(const SoDirectionalLight * from, SoDirectionalLight * to);
82 
83  static void valueChangedCB(void * f, SoDragger * d);
84  static void fieldSensorCB(void * f, SoSensor * d);
85 
89 
90 private:
91  void attachSensors(const SbBool onoff);
92 
93 private:
94  SbLazyPimplPtr<SoDirectionalLightManipP> pimpl;
95 
97  SoDirectionalLightManip & operator = (const SoDirectionalLightManip & rhs);
98 }; // SoDirectionalLightManip
99 
100 #endif // !COIN_SODIRECTIONALLIGHTMANIP_H
The SoBase class is the top-level superclass for a number of class-hierarchies.SoBase provides the ba...
Definition: SoBase.h:45
virtual void copyContents(const SoFieldContainer *from, SbBool copyconnections)
Definition: SoNode.cpp:1420
virtual void GLRender(SoGLRenderAction *action)
Definition: SoDirectionalLight.cpp:153
The SoGetMatrixAction class is an action for accumulating the transformation matrix of a subgraph...
Definition: SoGetMatrixAction.h:46
#define SO_NODE_HEADER(classname)
The SoFieldContainer class is a base class for all classes that contain fields.The classes containing...
Definition: SoFieldContainer.h:43
The SoSearchAction class provides methods for searching through scene graphs.Nodes can be searched fo...
Definition: SoSearchAction.h:44
SoFieldSensor * colorFieldSensor
Definition: SoDirectionalLightManip.h:87
virtual void search(SoSearchAction *action)
Definition: SoNode.cpp:1158
virtual SoChildList * getChildren(void) const
Definition: SoNode.cpp:1303
The SoPickAction class is the base class for picking actions.The basis for all interaction features t...
Definition: SoPickAction.h:43
SoFieldSensor * directionFieldSensor
Definition: SoDirectionalLightManip.h:86
SoChildList * children
Definition: SoDirectionalLightManip.h:88
The SoChildList class is a container for node children.This class does automatic notification on the ...
Definition: SoChildList.h:42
The SoPath class is a container class for traversal path descriptions.SoPath objects contain a list o...
Definition: SoPath.h:52
The SoDragger class is the base class for all draggers.Draggers is a mechanism used for letting the e...
Definition: SoDragger.h:64
The SoSensor class is the abstract base class for all sensors.Sensors is a mechanism in Coin for sche...
Definition: SoSensor.h:43
virtual void getMatrix(SoGetMatrixAction *action)
Definition: SoNode.cpp:1039
The SoAction class is the base class for all traversal actions.Applying actions is the basic mechanis...
Definition: SoAction.h:77
virtual void pick(SoPickAction *action)
Definition: SoNode.cpp:1095
The SbVec3f class is a 3 dimensional vector with floating point coordinates.This vector class is used...
Definition: SbVec3f.h:51
The SoFieldSensor class detects changes to a field.Attach a field to a sensor of this type to put it ...
Definition: SoFieldSensor.h:38
The SoDirectionalLightManip class is used to manipulate SoDirectionalLight nodes. ...
Definition: SoDirectionalLightManip.h:51
virtual void doAction(SoAction *action)
Definition: SoNode.cpp:795
The SbMatrix class is a 4x4 dimensional representation of a matrix.SbMatrix is used by many other cla...
Definition: SbMatrix.h:46
The SoHandleEventAction class distributes user events to the scene.This is the action used by the GUI...
Definition: SoHandleEventAction.h:46
The SoGetBoundingBoxAction class calculates bounding boxes for nodes and subgraphs.If this action is applied to a path or scene graph root, it will calculate the bounding box and the center point of the geometry contained within the scene.
Definition: SoGetBoundingBoxAction.h:45
The SoCallbackAction class invokes callbacks at specific nodes.This action has mechanisms for trackin...
Definition: SoCallbackAction.h:80
virtual void getBoundingBox(SoGetBoundingBoxAction *action)
Definition: SoNode.cpp:851
virtual void callback(SoCallbackAction *action)
Definition: SoLight.cpp:140
virtual void handleEvent(SoHandleEventAction *action)
Definition: SoNode.cpp:1069
The SoDirectionalLight class is a node type for specifying directional light sources.A directional light source provides a model of light sources which are at infinite distance from the geometry it illuminates, thereby having no set position and consisting of an infinite volume of parallel rays.
Definition: SoDirectionalLight.h:40
The SoGLRenderAction class renders the scene graph with OpenGL calls.Applying this method at a root n...
Definition: SoGLRenderAction.h:50

Copyright © by Kongsberg Oil & Gas Technologies. All rights reserved.

Generated for Coin by Doxygen