2001-01-11 00:32:10 +08:00
|
|
|
#ifndef OSG_SWITCH
|
|
|
|
#define OSG_SWITCH 1
|
|
|
|
|
|
|
|
#include <osg/Group>
|
|
|
|
|
|
|
|
namespace osg {
|
|
|
|
|
2001-09-20 05:08:56 +08:00
|
|
|
/** Switch is a Group node which allows switching between children.
|
2001-01-11 00:32:10 +08:00
|
|
|
Typical uses would be for objects which might need to be rendered
|
|
|
|
differently at different times, for instance a switch could be used
|
|
|
|
to represent the different states of a traffic light.
|
|
|
|
*/
|
|
|
|
class SG_EXPORT Switch : public Group
|
|
|
|
{
|
|
|
|
public :
|
|
|
|
|
2001-09-20 05:08:56 +08:00
|
|
|
/**
|
|
|
|
* Special mode values for the Switch. Use these if you want to
|
|
|
|
* turn on/off all child nodes.
|
|
|
|
*/
|
2001-01-11 00:32:10 +08:00
|
|
|
enum SwitchType {
|
2001-09-20 05:08:56 +08:00
|
|
|
/** Turn on all children. */
|
|
|
|
ALL_CHILDREN_ON=-1,
|
|
|
|
/** Turn off all children. */
|
|
|
|
ALL_CHILDREN_OFF=-2
|
2001-01-11 00:32:10 +08:00
|
|
|
};
|
|
|
|
|
|
|
|
Switch();
|
|
|
|
|
|
|
|
virtual Object* clone() const { return new Switch(); }
|
2001-09-20 05:08:56 +08:00
|
|
|
virtual bool isSameKindAs(const Object* obj) const { return dynamic_cast<const Switch*>(obj)!=NULL; }
|
2001-01-11 00:32:10 +08:00
|
|
|
virtual const char* className() const { return "Switch"; }
|
|
|
|
virtual void accept(NodeVisitor& nv) { nv.apply(*this); }
|
|
|
|
virtual void traverse(NodeVisitor& nv);
|
|
|
|
|
2001-09-20 05:08:56 +08:00
|
|
|
/**
|
|
|
|
* Selects the active child Node or enables a special
|
|
|
|
* SwitchType mode.
|
|
|
|
* @param value the number of the active child
|
|
|
|
* (first child == number 0) or SwitchType. Invalid values
|
|
|
|
* will be ignored.
|
|
|
|
*/
|
|
|
|
inline void setValue(const int value) { _value = value; }
|
|
|
|
/**
|
|
|
|
* Returns the number of the active child Node or the SwitchType.
|
|
|
|
*/
|
|
|
|
inline const int getValue() const { return _value; }
|
2001-01-11 00:32:10 +08:00
|
|
|
|
|
|
|
protected :
|
|
|
|
|
|
|
|
virtual ~Switch() {}
|
|
|
|
|
2001-09-20 05:08:56 +08:00
|
|
|
/** The current Switch value. */
|
|
|
|
int _value;
|
2001-01-11 00:32:10 +08:00
|
|
|
};
|
|
|
|
|
|
|
|
};
|
|
|
|
|
|
|
|
#endif
|