//
// You should have received a copy of the GNU General Public License
// along with this program; if not, write to the Free Software
-// Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
+// Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
//
-// $Id$
#ifndef _ENVIRONMENT_MGR_HXX
#define _ENVIRONMENT_MGR_HXX
#include <simgear/compiler.h>
-
-#include <Main/fgfs.hxx>
+#include <simgear/structure/subsystem_mgr.hxx>
+#include <simgear/math/SGMath.hxx>
+#include "tiedpropertylist.hxx"
#ifdef SG_HAVE_STD_INCLUDES
# include <cmath>
# include <math.h>
#endif
-#include "environment.hxx"
-
+class FGEnvironment;
+class FGMetarCtrl;
+class FGMetarFetcher;
+class FGClouds;
+class FGPrecipitationMgr;
/**
* Manage environment information.
*/
-class FGEnvironmentMgr : public FGSubsystem
+class FGEnvironmentMgr : public SGSubsystemGroup
{
public:
+ enum {
+ MAX_CLOUD_LAYERS = 5
+ };
+
FGEnvironmentMgr ();
virtual ~FGEnvironmentMgr ();
virtual void init ();
+ virtual void reinit ();
virtual void bind ();
virtual void unbind ();
- virtual void update (int dt);
+ virtual void update (double dt);
/**
* Get the environment information for the plane's current position.
*/
- virtual const FGEnvironment * getEnvironment () const;
+ virtual FGEnvironment getEnvironment () const;
/**
* Get the environment information for another location.
*/
- virtual const FGEnvironment * getEnvironment (double lat, double lon,
- double alt) const;
+ virtual FGEnvironment getEnvironment (double lat, double lon,
+ double alt) const;
+ virtual FGEnvironment getEnvironment(const SGGeod& aPos) const;
private:
- FGEnvironment * _environment; // always the same, for now
+ double get_cloud_layer_span_m (int index) const;
+ void set_cloud_layer_span_m (int index, double span_m);
+ double get_cloud_layer_elevation_ft (int index) const;
+ void set_cloud_layer_elevation_ft (int index, double elevation_ft);
+ double get_cloud_layer_thickness_ft (int index) const;
+ void set_cloud_layer_thickness_ft (int index, double thickness_ft);
+ double get_cloud_layer_transition_ft (int index) const;
+ void set_cloud_layer_transition_ft (int index, double transition_ft);
+ const char * get_cloud_layer_coverage (int index) const;
+ void set_cloud_layer_coverage (int index, const char * coverage);
+ int get_cloud_layer_coverage_type (int index) const;
+ void set_cloud_layer_coverage_type (int index, int type );
+ double get_cloud_layer_visibility_m (int index) const;
+ void set_cloud_layer_visibility_m (int index, double visibility_m);
+ double get_cloud_layer_maxalpha (int index ) const;
+ void set_cloud_layer_maxalpha (int index, double maxalpha);
+ FGEnvironment * _environment; // always the same, for now
+ FGClouds *fgClouds;
+ SGPropertyNode_ptr _altitudeNode;
+ bool _cloudLayersDirty;
+ TiedPropertyList _tiedProperties;
};
#endif // _ENVIRONMENT_MGR_HXX