2006-07-18 23:21:48 +08:00
|
|
|
/* -*-c++-*- OpenSceneGraph - Copyright (C) 1998-2006 Robert Osfield
|
2005-03-07 22:06:09 +08:00
|
|
|
*
|
|
|
|
* This library is open source and may be redistributed and/or modified under
|
|
|
|
* the terms of the OpenSceneGraph Public License (OSGPL) version 0.0 or
|
|
|
|
* (at your option) any later version. The full license is in LICENSE file
|
|
|
|
* included with this distribution, and on the openscenegraph.org website.
|
|
|
|
*
|
|
|
|
* This library is distributed in the hope that it will be useful,
|
|
|
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
|
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
|
|
* OpenSceneGraph Public License for more details.
|
|
|
|
*/
|
|
|
|
|
|
|
|
#ifndef OSG_ProxyNode
|
|
|
|
#define OSG_ProxyNode 1
|
|
|
|
|
|
|
|
#include <osg/Group>
|
|
|
|
|
|
|
|
namespace osg {
|
|
|
|
|
|
|
|
/** ProxyNode.
|
|
|
|
*/
|
2005-04-12 01:14:17 +08:00
|
|
|
class OSG_EXPORT ProxyNode : public Group
|
2005-03-07 22:06:09 +08:00
|
|
|
{
|
|
|
|
public :
|
|
|
|
|
|
|
|
ProxyNode();
|
|
|
|
|
|
|
|
/** Copy constructor using CopyOp to manage deep vs shallow copy.*/
|
|
|
|
ProxyNode(const ProxyNode&,const CopyOp& copyop=CopyOp::SHALLOW_COPY);
|
|
|
|
|
|
|
|
META_Node(osg, ProxyNode);
|
|
|
|
|
2008-04-04 02:36:50 +08:00
|
|
|
typedef osg::BoundingSphere::vec_type vec_type;
|
|
|
|
typedef osg::BoundingSphere::value_type value_type;
|
|
|
|
|
2005-03-07 22:06:09 +08:00
|
|
|
virtual void traverse(NodeVisitor& nv);
|
|
|
|
|
|
|
|
virtual bool addChild(Node *child);
|
|
|
|
virtual bool addChild(Node *child, const std::string& filename);
|
2006-05-02 17:45:31 +08:00
|
|
|
|
|
|
|
virtual bool removeChildren(unsigned int pos,unsigned int numChildrenToRemove);
|
2005-03-07 22:06:09 +08:00
|
|
|
|
2009-06-12 18:08:15 +08:00
|
|
|
|
|
|
|
/** Set the optional database osgDB::Options object to use when loaded children.*/
|
|
|
|
void setDatabaseOptions(osg::Referenced* options) { _databaseOptions = options; }
|
|
|
|
|
|
|
|
/** Get the optional database osgDB::Options object used when loaded children.*/
|
|
|
|
osg::Referenced* getDatabaseOptions() { return _databaseOptions.get(); }
|
|
|
|
|
|
|
|
/** Get the optional database osgDB::Options object used when loaded children.*/
|
|
|
|
const osg::Referenced* getDatabaseOptions() const { return _databaseOptions.get(); }
|
|
|
|
|
|
|
|
|
2005-03-07 22:06:09 +08:00
|
|
|
/** Set the database path to prepend to children's filenames.*/
|
|
|
|
void setDatabasePath(const std::string& path);
|
|
|
|
/** Get the database path used to prepend to children's filenames.*/
|
|
|
|
inline const std::string& getDatabasePath() const { return _databasePath; }
|
|
|
|
|
2008-05-22 05:09:45 +08:00
|
|
|
void setFileName(unsigned int childNo, const std::string& filename) { expandFileNameListTo(childNo); _filenameList[childNo].first=filename; }
|
|
|
|
const std::string& getFileName(unsigned int childNo) const { return _filenameList[childNo].first; }
|
2005-03-07 22:06:09 +08:00
|
|
|
unsigned int getNumFileNames() const { return _filenameList.size(); }
|
|
|
|
|
2008-05-22 05:09:45 +08:00
|
|
|
/** Return the DatabaseRequest object used by the DatabasePager to keep track of file load requests
|
|
|
|
* being carried on behalf of the DatabasePager.
|
|
|
|
* Note, in normal OSG usage you should not set this value yourself, as this will be managed by
|
|
|
|
* the osgDB::DatabasePager.*/
|
|
|
|
osg::ref_ptr<osg::Referenced>& getDatabaseRequest(unsigned int childNo) { return _filenameList[childNo].second; }
|
|
|
|
|
|
|
|
/** Return the const DatabaseRequest object.*/
|
|
|
|
const osg::ref_ptr<osg::Referenced>& getDatabaseRequest(unsigned int childNo) const { return _filenameList[childNo].second; }
|
|
|
|
|
|
|
|
|
2005-03-07 22:06:09 +08:00
|
|
|
/** Modes which control how the center of object should be determined when computed which child is active.*/
|
|
|
|
enum CenterMode
|
|
|
|
{
|
|
|
|
USE_BOUNDING_SPHERE_CENTER,
|
2011-09-19 18:34:31 +08:00
|
|
|
USER_DEFINED_CENTER,
|
|
|
|
UNION_OF_BOUNDING_SPHERE_AND_USER_DEFINED
|
2005-03-07 22:06:09 +08:00
|
|
|
};
|
|
|
|
|
|
|
|
/** Set how the center of object should be determined when computed which child is active.*/
|
|
|
|
void setCenterMode(CenterMode mode) { _centerMode=mode; }
|
|
|
|
|
|
|
|
/** Get how the center of object should be determined when computed which child is active.*/
|
|
|
|
CenterMode getCenterMode() const { return _centerMode; }
|
2008-02-25 23:07:35 +08:00
|
|
|
|
|
|
|
/** Modes which control how the proxynode external reference are loaded.*/
|
|
|
|
enum LoadingExternalReferenceMode
|
|
|
|
{
|
|
|
|
LOAD_IMMEDIATELY,
|
|
|
|
DEFER_LOADING_TO_DATABASE_PAGER,
|
|
|
|
NO_AUTOMATIC_LOADING
|
|
|
|
};
|
|
|
|
|
|
|
|
/** Set how the child loading is done.*/
|
|
|
|
void setLoadingExternalReferenceMode(LoadingExternalReferenceMode mode) { _loadingExtReference=mode; }
|
|
|
|
|
|
|
|
/** Get the setted mode of loading.*/
|
|
|
|
LoadingExternalReferenceMode getLoadingExternalReferenceMode() const { return _loadingExtReference; }
|
2005-03-07 22:06:09 +08:00
|
|
|
|
2005-04-30 23:16:05 +08:00
|
|
|
/** Sets the object-space point which defines the center of the osg::ProxyNode.
|
|
|
|
center is affected by any transforms in the hierarchy above the osg::ProxyNode.*/
|
2011-09-19 18:34:31 +08:00
|
|
|
inline void setCenter(const vec_type& center) { if (_centerMode!=UNION_OF_BOUNDING_SPHERE_AND_USER_DEFINED) { _centerMode=USER_DEFINED_CENTER; } _userDefinedCenter = center; }
|
2005-03-07 22:06:09 +08:00
|
|
|
|
2005-04-30 23:16:05 +08:00
|
|
|
/** return the ProxyNode center point. */
|
2011-09-19 18:34:31 +08:00
|
|
|
inline const vec_type& getCenter() const { if ((_centerMode==USER_DEFINED_CENTER)||(_centerMode==UNION_OF_BOUNDING_SPHERE_AND_USER_DEFINED)) return _userDefinedCenter; else return getBound().center(); }
|
2005-03-07 22:06:09 +08:00
|
|
|
|
|
|
|
|
2005-04-30 23:16:05 +08:00
|
|
|
/** Set the object-space reference radius of the volume enclosed by the ProxyNode.
|
2007-12-11 01:30:18 +08:00
|
|
|
* Used to determine the bounding sphere of the ProxyNode in the absence of any children.*/
|
2008-04-04 02:36:50 +08:00
|
|
|
inline void setRadius(value_type radius) { _radius = radius; }
|
2005-03-07 22:06:09 +08:00
|
|
|
|
2005-04-30 23:16:05 +08:00
|
|
|
/** Get the object-space radius of the volume enclosed by the ProxyNode.*/
|
2008-04-04 02:36:50 +08:00
|
|
|
inline value_type getRadius() const { return _radius; }
|
2005-03-07 22:06:09 +08:00
|
|
|
|
2005-05-12 22:03:22 +08:00
|
|
|
virtual BoundingSphere computeBound() const;
|
|
|
|
|
2005-03-07 22:06:09 +08:00
|
|
|
protected :
|
|
|
|
|
|
|
|
virtual ~ProxyNode() {}
|
|
|
|
|
|
|
|
void expandFileNameListTo(unsigned int pos);
|
|
|
|
|
2008-05-22 05:09:45 +08:00
|
|
|
typedef std::pair< std::string, osg::ref_ptr<osg::Referenced> > FileNameDatabaseRequestPair;
|
|
|
|
typedef std::vector<FileNameDatabaseRequestPair> FileNameDatabaseRequestList;
|
|
|
|
|
|
|
|
FileNameDatabaseRequestList _filenameList;
|
2009-06-12 18:08:15 +08:00
|
|
|
ref_ptr<Referenced> _databaseOptions;
|
2008-05-22 05:09:45 +08:00
|
|
|
std::string _databasePath;
|
2005-03-07 22:06:09 +08:00
|
|
|
|
2008-05-22 05:09:45 +08:00
|
|
|
LoadingExternalReferenceMode _loadingExtReference;
|
2008-02-25 23:07:35 +08:00
|
|
|
|
2008-05-22 05:09:45 +08:00
|
|
|
CenterMode _centerMode;
|
|
|
|
vec_type _userDefinedCenter;
|
|
|
|
value_type _radius;
|
2005-03-07 22:06:09 +08:00
|
|
|
|
|
|
|
};
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
#endif
|