2001-01-11 00:32:10 +08:00
|
|
|
#ifndef OSG_GROUP
|
|
|
|
#define OSG_GROUP 1
|
|
|
|
|
|
|
|
#include <osg/Node>
|
|
|
|
#include <osg/NodeVisitor>
|
|
|
|
|
|
|
|
namespace osg {
|
|
|
|
|
|
|
|
/** General group node which maintains a list of children.
|
2001-09-20 05:08:56 +08:00
|
|
|
Children are reference counted. This allows children to be shared
|
2001-01-11 00:32:10 +08:00
|
|
|
with memory management handled automatically via osg::Referenced.
|
|
|
|
*/
|
|
|
|
class SG_EXPORT Group : public Node
|
|
|
|
{
|
|
|
|
public :
|
|
|
|
|
|
|
|
typedef std::vector<ref_ptr<Node> > ChildList;
|
|
|
|
|
|
|
|
Group();
|
|
|
|
|
|
|
|
virtual Object* clone() const { return new Group(); }
|
2001-09-20 05:08:56 +08:00
|
|
|
virtual bool isSameKindAs(const Object* obj) const { return dynamic_cast<const Group*>(obj)!=NULL; }
|
2001-01-11 00:32:10 +08:00
|
|
|
virtual const char* className() const { return "Group"; }
|
|
|
|
virtual void accept(NodeVisitor& nv) { nv.apply(*this); }
|
|
|
|
|
|
|
|
virtual void traverse(NodeVisitor& nv);
|
|
|
|
|
|
|
|
/** Add Node to Group.
|
|
|
|
* If node is not NULL and is not contained in Group then increment its
|
|
|
|
* reference count, add it to the child list and dirty the bounding
|
|
|
|
* sphere to force it to recompute on next getBound() and return true for success.
|
2001-09-20 05:08:56 +08:00
|
|
|
* Otherwise return false. Scene nodes can't be added as child nodes.
|
2001-01-11 00:32:10 +08:00
|
|
|
*/
|
|
|
|
virtual bool addChild( Node *child );
|
|
|
|
|
|
|
|
/** Remove Node from Group.
|
|
|
|
* If Node is contained in Group then remove it from the child
|
|
|
|
* list, decrement its reference count, and dirty the
|
|
|
|
* bounding sphere to force it to recompute on next getBound() and
|
|
|
|
* return true for success. If Node is not found then return false
|
|
|
|
* and do not change the reference count of the Node.
|
|
|
|
*/
|
|
|
|
virtual bool removeChild( Node *child );
|
|
|
|
|
|
|
|
/** Replace specified Node with another Node.
|
|
|
|
* Decrement the reference count origNode and increments the
|
|
|
|
* reference count of newNode, and dirty the bounding sphere
|
|
|
|
* to force it to recompute on next getBound() and returns true.
|
|
|
|
* If origNode is not found then return false and do not
|
|
|
|
* add newNode. If newNode is NULL then return false and do
|
2001-09-20 05:08:56 +08:00
|
|
|
* not remove origNode. Also returns false if newChild is a Scene node.
|
2001-01-11 00:32:10 +08:00
|
|
|
*/
|
|
|
|
virtual bool replaceChild( Node *origChild, Node* newChild );
|
|
|
|
|
|
|
|
/** return the number of chilren nodes.*/
|
2001-09-20 05:08:56 +08:00
|
|
|
inline const int getNumChildren() const { return _children.size(); }
|
|
|
|
|
|
|
|
/** return child node at position i.*/
|
|
|
|
inline Node *getChild( const int i ) { return _children[i].get(); }
|
2001-01-11 00:32:10 +08:00
|
|
|
|
|
|
|
/** return child node at position i.*/
|
2001-09-20 05:08:56 +08:00
|
|
|
inline const Node *getChild( const int i ) const { return _children[i].get(); }
|
2001-01-11 00:32:10 +08:00
|
|
|
|
2001-09-20 05:08:56 +08:00
|
|
|
/** return true if node is contained within Group.*/
|
|
|
|
inline bool containsNode( const Node* node ) const
|
2001-01-11 00:32:10 +08:00
|
|
|
{
|
|
|
|
|
2001-09-20 05:08:56 +08:00
|
|
|
for (ChildList::const_iterator itr=_children.begin();
|
2001-01-11 00:32:10 +08:00
|
|
|
itr!=_children.end();
|
|
|
|
++itr)
|
|
|
|
{
|
|
|
|
if (itr->get()==node) return true;
|
|
|
|
}
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
|
2001-09-20 05:08:56 +08:00
|
|
|
|
2001-01-11 00:32:10 +08:00
|
|
|
/** return the iterator postion for specified Node.
|
|
|
|
* return _chilren.end() if node is not contained in Group.
|
|
|
|
*/
|
2001-09-20 05:08:56 +08:00
|
|
|
inline ChildList::iterator findNode( const Node* node )
|
2001-01-11 00:32:10 +08:00
|
|
|
{
|
|
|
|
for (ChildList::iterator itr=_children.begin();
|
|
|
|
itr!=_children.end();
|
|
|
|
++itr)
|
|
|
|
{
|
|
|
|
if (itr->get()==node) return itr;
|
|
|
|
}
|
|
|
|
return _children.end();
|
|
|
|
}
|
|
|
|
|
2001-09-20 05:08:56 +08:00
|
|
|
/** return the const_iterator postion for specified Node.
|
|
|
|
* return _chilren.end() if node is not contained in Group.
|
|
|
|
*/
|
|
|
|
inline ChildList::const_iterator findNode( const Node* node ) const
|
|
|
|
{
|
|
|
|
for (ChildList::const_iterator itr=_children.begin();
|
|
|
|
itr!=_children.end();
|
|
|
|
++itr)
|
|
|
|
{
|
|
|
|
if (itr->get()==node) return itr;
|
|
|
|
}
|
|
|
|
return _children.end();
|
|
|
|
}
|
|
|
|
|
2001-01-11 00:32:10 +08:00
|
|
|
protected:
|
|
|
|
|
|
|
|
virtual ~Group();
|
|
|
|
|
2001-09-20 05:08:56 +08:00
|
|
|
virtual const bool computeBound() const;
|
2001-01-11 00:32:10 +08:00
|
|
|
|
|
|
|
ChildList _children;
|
|
|
|
|
|
|
|
|
|
|
|
};
|
|
|
|
|
|
|
|
};
|
|
|
|
|
|
|
|
#endif
|