OpenSceneGraph  3.0.1
Classes | Public Types | Public Member Functions | Protected Member Functions | Protected Attributes
osgSim::ScalarBar Class Reference

A ScalarBar is an osg::Geode to render a colored bar representing a range of scalars. More...

Inheritance diagram for osgSim::ScalarBar:
Inheritance graph
[legend]

List of all members.

Classes

struct  ScalarPrinter
 Users may provide their own ScalarPrinter by deriving from this base class and overriding the printScalar() method. More...
struct  TextProperties
 TextProperties allows users to specify a number of properties for the text used to display the labels & title on the ScalarBar. More...

Public Types

enum  Orientation { HORIZONTAL, VERTICAL }
 ScalarBar orientation specification. More...
- Public Types inherited from osg::Geode
typedef std::vector< ref_ptr
< Drawable > > 
DrawableList
- Public Types inherited from osg::Node
typedef std::vector< Group * > ParentList
 A vector of osg::Group pointers which is used to store the parent(s) of node.
typedef unsigned int NodeMask
 This is a set of bits (flags) that represent the Node.
typedef std::vector< std::string > DescriptionList
 A vector of std::string's which are used to describe the object.
- Public Types inherited from osg::Object
enum  DataVariance { DYNAMIC, STATIC, UNSPECIFIED }

Public Member Functions

 ScalarBar ()
 Default constructor.
 ScalarBar (int numColors, int numLabels, ScalarsToColors *stc, const std::string &title, Orientation orientation=HORIZONTAL, float aspectRatio=0.25, ScalarPrinter *sp=new ScalarPrinter)
 Construct a ScalarBar with the supplied parameters.
 ScalarBar (const ScalarBar &rhs, const osg::CopyOp &co)
 Copy constructor.
 META_Node (osgSim, ScalarBar)
void setNumColors (int numColors)
 Set the number of distinct colours on the ScalarBar.
int getNumColors () const
 Get the number of distinct colours on the ScalarBar.
void setNumLabels (int numLabels)
 Set the number of labels to display along the ScalarBar.
int getNumLabels () const
 Get the number of labels displayed along the ScalarBar.
void setScalarsToColors (ScalarsToColors *stc)
 Set the ScalarsToColors mapping object for the ScalarBar.
const ScalarsToColorsgetScalarsToColors () const
 Get the ScalarsToColors mapping object from the ScalarBar.
void setTitle (const std::string &title)
 Set the title for the ScalarBar, set "" for no title.
const std::string & getTitle () const
 Get the title for the ScalarBar.
void setPosition (const osg::Vec3 &pos)
 Set the position of scalar bar's lower left corner.
const osg::Vec3getPosition () const
 Get the position of scalar bar.
void setWidth (float width)
 Set the width of the scalar bar.
float getWidth () const
 Get the width of the scalar bar.
void setAspectRatio (float aspectRatio)
 Set the aspect ration (y/x) for the displayed bar.
float getAspectRatio () const
 Get the aspect ration (y/x) for the displayed bar.
void setOrientation (ScalarBar::Orientation orientation)
 Set the orientation of the ScalarBar.
ScalarBar::Orientation getOrientation () const
 Get the orientation of the ScalarBar.
void setScalarPrinter (ScalarPrinter *sp)
 Set a ScalarPrinter object for the ScalarBar.
const ScalarPrintergetScalarPrinter () const
 Get the ScalarPrinter object.
void setTextProperties (const TextProperties &tp)
 Set the TextProperties for the labels & title.
const TextPropertiesgetTextProperties () const
 Get the TextProperties for the labels & title.
void update ()
 force update the drawables used to render the scalar bar.
- Public Member Functions inherited from osg::Geode
 Geode ()
 Geode (const Geode &, const CopyOp &copyop=CopyOp::SHALLOW_COPY)
 Copy constructor using CopyOp to manage deep vs shallow copy.
 META_Node (osg, Geode)
virtual GeodeasGeode ()
 Convert 'this' into a Geode pointer if Node is a Geode, otherwise return 0.
virtual const GeodeasGeode () const
 convert 'const this' into a const Geode pointer if Node is a Geode, otherwise return 0.
virtual bool addDrawable (Drawable *drawable)
 Add a Drawable to the Geode.
virtual bool removeDrawable (Drawable *drawable)
 Remove a Drawable from the Geode.
virtual bool removeDrawables (unsigned int i, unsigned int numDrawablesToRemove=1)
 Remove Drawable(s) from the specified position in Geode's drawable list.
virtual bool replaceDrawable (Drawable *origDraw, Drawable *newDraw)
 Replace specified Drawable with another Drawable.
virtual bool setDrawable (unsigned int i, Drawable *drawable)
 Set Drawable at position i.
unsigned int getNumDrawables () const
 Return the number of Drawables currently attached to the Geode.
DrawablegetDrawable (unsigned int i)
 Return the Drawable at position i.
const DrawablegetDrawable (unsigned int i) const
 Return the Drawable at position i.
bool containsDrawable (const Drawable *gset) const
 Return true if a given Drawable is contained within Geode.
unsigned int getDrawableIndex (const Drawable *drawable) const
 Get the index number of drawable.
const DrawableListgetDrawableList () const
 Get the list of drawables.
void compileDrawables (RenderInfo &renderInfo)
 Compile OpenGL Display List for each drawable.
const BoundingBoxgetBoundingBox () const
 Return the Geode's bounding box, which is the union of all the bounding boxes of the geode's drawables.
virtual BoundingSphere computeBound () const
 Compute the bounding sphere around Node's geometry or children.
virtual void setThreadSafeRefUnref (bool threadSafe)
 Set whether to use a mutex to ensure ref() and unref() are thread safe.
virtual void resizeGLObjectBuffers (unsigned int maxSize)
 Resize any per context GLObject buffers to specified size.
virtual void releaseGLObjects (osg::State *=0) const
 If State is non-zero, this function releases any associated OpenGL objects for the specified graphics context.
- Public Member Functions inherited from osg::Node
 Node ()
 Construct a node.
 Node (const Node &, const CopyOp &copyop=CopyOp::SHALLOW_COPY)
 Copy constructor using CopyOp to manage deep vs shallow copy.
virtual ObjectcloneType () const
 clone an object of the same type as the node.
virtual Objectclone (const CopyOp &copyop) const
 return a clone of a node, with Object* return type.
virtual bool isSameKindAs (const Object *obj) const
 return true if this and obj are of the same kind of object.
virtual const char * libraryName () const
 return the name of the node's library.
virtual const char * className () const
 return the name of the node's class type.
virtual GroupasGroup ()
 convert 'this' into a Group pointer if Node is a Group, otherwise return 0.
virtual const GroupasGroup () const
 convert 'const this' into a const Group pointer if Node is a Group, otherwise return 0.
virtual TransformasTransform ()
 Convert 'this' into a Transform pointer if Node is a Transform, otherwise return 0.
virtual const TransformasTransform () const
 convert 'const this' into a const Transform pointer if Node is a Transform, otherwise return 0.
virtual SwitchasSwitch ()
 Convert 'this' into a Switch pointer if Node is a Switch, otherwise return 0.
virtual const SwitchasSwitch () const
 convert 'const this' into a const Switch pointer if Node is a Switch, otherwise return 0.
virtual osgTerrain::TerrainasTerrain ()
 Convert 'this' into a Transform pointer if Node is a Terrain, otherwise return 0.
virtual const osgTerrain::TerrainasTerrain () const
 convert 'const this' into a const Terrain pointer if Node is a Terrain, otherwise return 0.
virtual void accept (NodeVisitor &nv)
 Visitor Pattern : calls the apply method of a NodeVisitor with this node's type.
virtual void ascend (NodeVisitor &nv)
 Traverse upwards : calls parents' accept method with NodeVisitor.
virtual void traverse (NodeVisitor &)
 Traverse downwards : calls children's accept method with NodeVisitor.
const ParentListgetParents () const
 Get the parent list of node.
ParentList getParents ()
 Get the a copy of parent list of node.
GroupgetParent (unsigned int i)
const GroupgetParent (unsigned int i) const
 Get a single const parent of node.
unsigned int getNumParents () const
 Get the number of parents of node.
NodePathList getParentalNodePaths (osg::Node *haltTraversalAtNode=0) const
 Get the list of node paths parent paths.
MatrixList getWorldMatrices (const osg::Node *haltTraversalAtNode=0) const
 Get the list of matrices that transform this node from local coordinates to world coordinates.
void setUpdateCallback (NodeCallback *nc)
 Set update node callback, called during update traversal.
NodeCallbackgetUpdateCallback ()
 Get update node callback, called during update traversal.
const NodeCallbackgetUpdateCallback () const
 Get const update node callback, called during update traversal.
void addUpdateCallback (NodeCallback *nc)
 Convenience method that sets the update callback of the node if it doesn't exist, or nest it into the existing one.
void removeUpdateCallback (NodeCallback *nc)
 Convenience method that removes a given callback from a node, even if that callback is nested.
unsigned int getNumChildrenRequiringUpdateTraversal () const
 Get the number of Children of this node which require Update traversal, since they have an Update Callback attached to them or their children.
void setEventCallback (NodeCallback *nc)
 Set event node callback, called during event traversal.
NodeCallbackgetEventCallback ()
 Get event node callback, called during event traversal.
const NodeCallbackgetEventCallback () const
 Get const event node callback, called during event traversal.
void addEventCallback (NodeCallback *nc)
 Convenience method that sets the event callback of the node if it doesn't exist, or nest it into the existing one.
void removeEventCallback (NodeCallback *nc)
 Convenience method that removes a given callback from a node, even if that callback is nested.
unsigned int getNumChildrenRequiringEventTraversal () const
 Get the number of Children of this node which require Event traversal, since they have an Event Callback attached to them or their children.
void setCullCallback (NodeCallback *nc)
 Set cull node callback, called during cull traversal.
NodeCallbackgetCullCallback ()
 Get cull node callback, called during cull traversal.
const NodeCallbackgetCullCallback () const
 Get const cull node callback, called during cull traversal.
void addCullCallback (NodeCallback *nc)
 Convenience method that sets the cull callback of the node if it doesn't exist, or nest it into the existing one.
void removeCullCallback (NodeCallback *nc)
 Convenience method that removes a given callback from a node, even if that callback is nested.
void setCullingActive (bool active)
 Set the view frustum/small feature culling of this node to be active or inactive.
bool getCullingActive () const
 Get the view frustum/small feature _cullingActive flag for this node.
unsigned int getNumChildrenWithCullingDisabled () const
 Get the number of Children of this node which have culling disabled.
bool isCullingActive () const
 Return true if this node can be culled by view frustum, occlusion or small feature culling during the cull traversal.
unsigned int getNumChildrenWithOccluderNodes () const
 Get the number of Children of this node which are or have OccluderNode's.
bool containsOccluderNodes () const
 return true if this node is an OccluderNode or the subgraph below this node are OccluderNodes.
void setNodeMask (NodeMask nm)
 Set the node mask.
NodeMask getNodeMask () const
 Get the node Mask.
void setStateSet (osg::StateSet *stateset)
 Set the node's StateSet.
osg::StateSetgetOrCreateStateSet ()
 return the node's StateSet, if one does not already exist create it set the node and return the newly created StateSet.
osg::StateSetgetStateSet ()
 Return the node's StateSet.
const osg::StateSetgetStateSet () const
 Return the node's const StateSet.
void setDescriptions (const DescriptionList &descriptions)
 Set the list of string descriptions.
DescriptionListgetDescriptions ()
 Get the description list of the node.
const DescriptionListgetDescriptions () const
 Get the const description list of the const node.
const std::string & getDescription (unsigned int i) const
 Get a single const description of the const node.
std::string & getDescription (unsigned int i)
 Get a single description of the node.
unsigned int getNumDescriptions () const
 Get the number of descriptions of the node.
void addDescription (const std::string &desc)
 Add a description string to the node.
void setInitialBound (const osg::BoundingSphere &bsphere)
 Set the initial bounding volume to use when computing the overall bounding volume.
const BoundingSpheregetInitialBound () const
 Set the initial bounding volume to use when computing the overall bounding volume.
void dirtyBound ()
 Mark this node's bounding sphere dirty.
const BoundingSpheregetBound () const
 Get the bounding sphere of node.
void setComputeBoundingSphereCallback (ComputeBoundingSphereCallback *callback)
 Set the compute bound callback to override the default computeBound.
ComputeBoundingSphereCallbackgetComputeBoundingSphereCallback ()
 Get the compute bound callback.
const
ComputeBoundingSphereCallback
getComputeBoundingSphereCallback () const
 Get the const compute bound callback.
- Public Member Functions inherited from osg::Object
 Object ()
 Construct an object.
 Object (bool threadSafeRefUnref)
 Object (const Object &, const CopyOp &copyop=CopyOp::SHALLOW_COPY)
 Copy constructor, optional CopyOp object can be used to control shallow vs deep copying of dynamic data.
virtual void setName (const std::string &name)
 Set the name of object using C++ style string.
void setName (const char *name)
 Set the name of object using a C style string.
const std::string & getName () const
 Get the name of object.
void setDataVariance (DataVariance dv)
 Set the data variance of this object.
DataVariance getDataVariance () const
 Get the data variance of this object.
virtual void computeDataVariance ()
 Compute the DataVariance based on an assessment of callback etc.
void setUserDataContainer (osg::UserDataContainer *udc)
 set the UserDataContainer object.
osg::UserDataContainergetUserDataContainer ()
 get the UserDataContainer attached to this object.
const osg::UserDataContainergetUserDataContainer () const
 get the const UserDataContainer attached to this object.
osg::UserDataContainergetOrCreateUserDataContainer ()
 Convinience method that returns the UserDataContainer, and if one doesn't already exist creates and assigns a DefaultUserDataContainer to the Object and then return this new UserDataContainer.
virtual void setUserData (Referenced *obj)
 Set user data, data must be subclassed from Referenced to allow automatic memory handling.
virtual ReferencedgetUserData ()
 Get user data.
virtual const ReferencedgetUserData () const
 Get const user data.
template<typename T >
bool getUserValue (const std::string &name, T &value) const
 Convinience method that casts the named UserObject to osg::TemplateValueObject<T> and gets the value.
template<typename T >
void setUserValue (const std::string &name, const T &value)
 Convinience method that creates the osg::TemplateValueObject<T> to store the specified value and adds it as a named UserObject.
- Public Member Functions inherited from osg::Referenced
 Referenced ()
 Referenced (bool threadSafeRefUnref)
 Referenced (const Referenced &)
Referencedoperator= (const Referenced &)
bool getThreadSafeRefUnref () const
 Get whether a mutex is used to ensure ref() and unref() are thread safe.
OpenThreads::Mutex * getRefMutex () const
 Get the mutex used to ensure thread safety of ref()/unref().
int ref () const
 Increment the reference count by one, indicating that this object has another pointer which is referencing it.
int unref () const
 Decrement the reference count by one, indicating that a pointer to this object is referencing it.
int unref_nodelete () const
 Decrement the reference count by one, indicating that a pointer to this object is referencing it.
int referenceCount () const
 Return the number of pointers currently referencing this object.
ObserverSetgetObserverSet () const
 Get the ObserverSet if one is attached, otherwise return NULL.
ObserverSetgetOrCreateObserverSet () const
 Get the ObserverSet if one is attached, otherwise create an ObserverSet, attach it, then return this newly created ObserverSet.
void addObserver (Observer *observer) const
 Add a Observer that is observing this object, notify the Observer when this object gets deleted.
void removeObserver (Observer *observer) const
 Remove Observer that is observing this object.

Protected Member Functions

virtual ~ScalarBar ()
void createDrawables ()
- Protected Member Functions inherited from osg::Geode
virtual ~Geode ()
- Protected Member Functions inherited from osg::Node
virtual ~Node ()
 Node destructor.
void addParent (osg::Group *node)
void removeParent (osg::Group *node)
void setNumChildrenRequiringUpdateTraversal (unsigned int num)
void setNumChildrenRequiringEventTraversal (unsigned int num)
void setNumChildrenWithCullingDisabled (unsigned int num)
void setNumChildrenWithOccluderNodes (unsigned int num)
- Protected Member Functions inherited from osg::Object
virtual ~Object ()
 Object destructor.
- Protected Member Functions inherited from osg::Referenced
virtual ~Referenced ()
void signalObserversAndDelete (bool signalDelete, bool doDelete) const
void deleteUsingDeleteHandler () const

Protected Attributes

int _numColors
int _numLabels
osg::ref_ptr< ScalarsToColors_stc
std::string _title
osg::Vec3 _position
float _width
float _aspectRatio
Orientation _orientation
osg::ref_ptr< ScalarPrinter_sp
TextProperties _textProperties
- Protected Attributes inherited from osg::Geode
osg::BoundingBox _bbox
DrawableList _drawables
- Protected Attributes inherited from osg::Node
BoundingSphere _initialBound
ref_ptr
< ComputeBoundingSphereCallback
_computeBoundCallback
BoundingSphere _boundingSphere
bool _boundingSphereComputed
ParentList _parents
ref_ptr< NodeCallback_updateCallback
unsigned int _numChildrenRequiringUpdateTraversal
ref_ptr< NodeCallback_eventCallback
unsigned int _numChildrenRequiringEventTraversal
ref_ptr< NodeCallback_cullCallback
bool _cullingActive
unsigned int _numChildrenWithCullingDisabled
unsigned int _numChildrenWithOccluderNodes
NodeMask _nodeMask
ref_ptr< StateSet_stateset
- Protected Attributes inherited from osg::Object
std::string _name
DataVariance _dataVariance
osg::UserDataContainer_userDataContainer
- Protected Attributes inherited from osg::Referenced
OpenThreads::AtomicPtr _observerSet
OpenThreads::Atomic _refCount

Detailed Description

A ScalarBar is an osg::Geode to render a colored bar representing a range of scalars.

The scalar/color ranges are specified by an instance of ScalarsToColors. There are a number of configurable properties on the ScalarBar, such as the orientation, the number of labels to be displayed across the range, the number of distinct colors to use when rendering the bar, text details etc.

In summary, the main configurables on the ScalarBar are:

  1. The range of scalars represented by the bar, and the colors corresponding to this range - these are specified by the ScalarsToColors object.
  2. The number of colors used when rendering the bar geometry - this may be thought of as the bar 'density'.
  3. The number of text labels to be used when displaying the bar.

The other configurables should be self-explanatory.


Member Enumeration Documentation

ScalarBar orientation specification.

Enumerator:
HORIZONTAL 

a horizontally ascending scalar bar (x-axis)

VERTICAL 

a vertically ascending scalar bar (y-axis)


Constructor & Destructor Documentation

osgSim::ScalarBar::ScalarBar ( )
inline

Default constructor.

osgSim::ScalarBar::ScalarBar ( int  numColors,
int  numLabels,
ScalarsToColors stc,
const std::string &  title,
Orientation  orientation = HORIZONTAL,
float  aspectRatio = 0.25,
ScalarPrinter sp = new ScalarPrinter 
)
inline

Construct a ScalarBar with the supplied parameters.

Parameters:
numColorsSpecify the number of colors in the scalar bar. Color interpolation occurs where necessary.
numLabelsSpecify the number of labels in the scalar bar.
stcThe ScalarsToColors defining the range of scalars and the colors they map to.
titleThe title to be used when displaying the ScalarBar. Specify "" for no title.
orientationThe orientation of the ScalarBar.
See also:
Orientation.
Parameters:
aspectRatioThe aspect ration (y/x) for the displayed bar. Bear in mind you may want to change this if you change the orientation.
spA ScalarPrinter object for the ScalarBar. For every displayed ScalarBar label, the scalar value will be passed to the ScalarPrinter object to turn it into a string. Users may override the default ScalarPrinter object to map scalars to whatever strings they wish.
See also:
ScalarPrinter
osgSim::ScalarBar::ScalarBar ( const ScalarBar rhs,
const osg::CopyOp co 
)
inline

Copy constructor.

virtual osgSim::ScalarBar::~ScalarBar ( )
protectedvirtual

Member Function Documentation

void osgSim::ScalarBar::createDrawables ( )
protected
float osgSim::ScalarBar::getAspectRatio ( ) const

Get the aspect ration (y/x) for the displayed bar.

int osgSim::ScalarBar::getNumColors ( ) const

Get the number of distinct colours on the ScalarBar.

int osgSim::ScalarBar::getNumLabels ( ) const

Get the number of labels displayed along the ScalarBar.

ScalarBar::Orientation osgSim::ScalarBar::getOrientation ( ) const

Get the orientation of the ScalarBar.

See also:
Orientation
const osg::Vec3& osgSim::ScalarBar::getPosition ( ) const
inline

Get the position of scalar bar.

const ScalarPrinter* osgSim::ScalarBar::getScalarPrinter ( ) const

Get the ScalarPrinter object.

const ScalarsToColors* osgSim::ScalarBar::getScalarsToColors ( ) const

Get the ScalarsToColors mapping object from the ScalarBar.

const TextProperties& osgSim::ScalarBar::getTextProperties ( ) const

Get the TextProperties for the labels & title.

See also:
TextProperties
const std::string& osgSim::ScalarBar::getTitle ( ) const

Get the title for the ScalarBar.

float osgSim::ScalarBar::getWidth ( ) const
inline

Get the width of the scalar bar.

osgSim::ScalarBar::META_Node ( osgSim  ,
ScalarBar   
)
void osgSim::ScalarBar::setAspectRatio ( float  aspectRatio)

Set the aspect ration (y/x) for the displayed bar.

Bear in mind you may want to change this if you change the orientation.

void osgSim::ScalarBar::setNumColors ( int  numColors)

Set the number of distinct colours on the ScalarBar.

void osgSim::ScalarBar::setNumLabels ( int  numLabels)

Set the number of labels to display along the ScalarBar.

There will be one label at each end point, and evenly distributed labels in between.

void osgSim::ScalarBar::setOrientation ( ScalarBar::Orientation  orientation)

Set the orientation of the ScalarBar.

See also:
Orientation
void osgSim::ScalarBar::setPosition ( const osg::Vec3 pos)

Set the position of scalar bar's lower left corner.

void osgSim::ScalarBar::setScalarPrinter ( ScalarPrinter sp)

Set a ScalarPrinter object for the ScalarBar.

For every displayed ScalarBar label, the scalar value will be passed to the ScalarPrinter object to turn it into a string. Users may override the default ScalarPrinter object to map scalars to whatever strings they wish.

See also:
ScalarPrinter
void osgSim::ScalarBar::setScalarsToColors ( ScalarsToColors stc)

Set the ScalarsToColors mapping object for the ScalarBar.

void osgSim::ScalarBar::setTextProperties ( const TextProperties tp)

Set the TextProperties for the labels & title.

See also:
TextProperties
void osgSim::ScalarBar::setTitle ( const std::string &  title)

Set the title for the ScalarBar, set "" for no title.

void osgSim::ScalarBar::setWidth ( float  width)

Set the width of the scalar bar.

void osgSim::ScalarBar::update ( )
inline

force update the drawables used to render the scalar bar.


Member Data Documentation

float osgSim::ScalarBar::_aspectRatio
protected
int osgSim::ScalarBar::_numColors
protected
int osgSim::ScalarBar::_numLabels
protected
Orientation osgSim::ScalarBar::_orientation
protected
osg::Vec3 osgSim::ScalarBar::_position
protected
osg::ref_ptr<ScalarPrinter> osgSim::ScalarBar::_sp
protected
osg::ref_ptr<ScalarsToColors> osgSim::ScalarBar::_stc
protected
TextProperties osgSim::ScalarBar::_textProperties
protected
std::string osgSim::ScalarBar::_title
protected
float osgSim::ScalarBar::_width
protected

The documentation for this class was generated from the following file:

osg logo
Generated at Thu Oct 4 2012 13:46:15 for the OpenSceneGraph by doxygen 1.8.1.1.