2002-04-12 12:45:49 +00:00
|
|
|
// model-mgr.hxx - manage user-specified 3D models.
|
|
|
|
// Written by David Megginson, started 2002.
|
|
|
|
//
|
|
|
|
// This file is in the Public Domain, and comes with no warranty.
|
|
|
|
|
|
|
|
#ifndef __MODELMGR_HXX
|
|
|
|
#define __MODELMGR_HXX 1
|
|
|
|
|
|
|
|
#ifndef __cplusplus
|
|
|
|
# error This library requires C++
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#include <vector>
|
|
|
|
|
2002-04-20 14:07:03 +00:00
|
|
|
#include <simgear/compiler.h> // for SG_USING_STD
|
2002-04-12 12:45:49 +00:00
|
|
|
|
2002-04-20 14:07:03 +00:00
|
|
|
#include <Main/fgfs.hxx> // for FGSubsystem
|
2002-04-12 12:45:49 +00:00
|
|
|
|
|
|
|
SG_USING_STD(vector);
|
|
|
|
|
2002-04-20 14:07:03 +00:00
|
|
|
// Don't pull in headers, since we don't need them here.
|
|
|
|
class ssgSelector;
|
|
|
|
class SGPropertyNode;
|
2002-06-10 13:20:26 +00:00
|
|
|
class FGModelPlacement;
|
2002-04-20 14:07:03 +00:00
|
|
|
|
2002-04-12 12:45:49 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Manage a list of user-specified models.
|
|
|
|
*/
|
|
|
|
class FGModelMgr : public FGSubsystem
|
|
|
|
{
|
|
|
|
public:
|
|
|
|
|
2002-12-30 15:44:11 +00:00
|
|
|
/**
|
|
|
|
* A dynamically-placed model using properties.
|
|
|
|
*
|
|
|
|
* The model manager uses the property nodes to update the model's
|
|
|
|
* position and orientation; any of the property node pointers may
|
|
|
|
* be set to zero to avoid update. Normally, a caller should
|
|
|
|
* load the model by instantiating FGModelPlacement with the path
|
|
|
|
* to the model or its XML wrapper, then assign any relevant
|
|
|
|
* property node pointers.
|
|
|
|
*
|
|
|
|
* @see FGModelPlacement
|
|
|
|
* @see FGModelMgr#add_instance
|
|
|
|
*/
|
2002-04-12 12:45:49 +00:00
|
|
|
struct Instance
|
|
|
|
{
|
|
|
|
Instance ();
|
|
|
|
virtual ~Instance ();
|
2002-06-10 13:20:26 +00:00
|
|
|
FGModelPlacement * model;
|
2002-04-12 12:45:49 +00:00
|
|
|
SGPropertyNode * lon_deg_node;
|
|
|
|
SGPropertyNode * lat_deg_node;
|
|
|
|
SGPropertyNode * elev_ft_node;
|
|
|
|
SGPropertyNode * roll_deg_node;
|
|
|
|
SGPropertyNode * pitch_deg_node;
|
|
|
|
SGPropertyNode * heading_deg_node;
|
|
|
|
};
|
|
|
|
|
2002-12-30 15:44:11 +00:00
|
|
|
FGModelMgr ();
|
|
|
|
virtual ~FGModelMgr ();
|
|
|
|
|
|
|
|
virtual void init ();
|
|
|
|
virtual void bind ();
|
|
|
|
virtual void unbind ();
|
|
|
|
virtual void update (double dt);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Add an instance of a dynamic model to the manager.
|
|
|
|
*
|
|
|
|
* NOTE: pointer ownership is transferred to the model manager!
|
|
|
|
*
|
|
|
|
* The caller is responsible for setting up the Instance structure
|
|
|
|
* as required. The model manager will continuously update the
|
|
|
|
* location and orientation of the model based on the current
|
|
|
|
* values of the properties.
|
|
|
|
*/
|
|
|
|
virtual void add_instance (Instance * instance);
|
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Remove an instance of a dynamic model from the manager.
|
|
|
|
*
|
|
|
|
* NOTE: the manager will delete the instance as well.
|
|
|
|
*/
|
|
|
|
virtual void remove_instance (Instance * instance);
|
|
|
|
|
|
|
|
virtual void draw ();
|
|
|
|
|
|
|
|
private:
|
|
|
|
|
2002-04-12 12:45:49 +00:00
|
|
|
vector<Instance *> _instances;
|
|
|
|
|
2002-04-13 21:36:22 +00:00
|
|
|
ssgSelector * _selector;
|
2002-04-12 12:45:49 +00:00
|
|
|
|
|
|
|
};
|
|
|
|
|
|
|
|
#endif // __MODELMGR_HXX
|