X-Git-Url: https://git.mxchange.org/?a=blobdiff_plain;f=src%2FEnvironment%2Fenvironment_mgr.hxx;h=cc99ff8c194cb2120fe153dc4e686a2d0e524c50;hb=a1031b052dd40ca3a4ea68dcd7f572b7d9e4bb24;hp=ffd75346345067f9d22c353614bea1f1694e8a8e;hpb=4aacda239089a7ef694ffd6d6acb35fe4ecc47a5;p=flightgear.git diff --git a/src/Environment/environment_mgr.hxx b/src/Environment/environment_mgr.hxx index ffd753463..cc99ff8c1 100644 --- a/src/Environment/environment_mgr.hxx +++ b/src/Environment/environment_mgr.hxx @@ -18,14 +18,13 @@ // along with this program; if not, write to the Free Software // Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. // -// $Id$ #ifndef _ENVIRONMENT_MGR_HXX #define _ENVIRONMENT_MGR_HXX #include #include -#include +#include #ifdef SG_HAVE_STD_INCLUDES # include @@ -34,11 +33,9 @@ #endif class FGEnvironment; -class FGEnvironmentCtrl; -class FGMetarCtrl; -class FGMetarFetcher; class FGClouds; class FGPrecipitationMgr; +class SGSky; /** * Manage environment information. @@ -55,8 +52,9 @@ public: FGEnvironmentMgr (); virtual ~FGEnvironmentMgr (); - virtual void init (); + virtual InitStatus incrementalInit (); virtual void reinit (); + virtual void shutdown (); virtual void bind (); virtual void unbind (); virtual void update (double dt); @@ -75,9 +73,8 @@ public: virtual FGEnvironment getEnvironment(const SGGeod& aPos) const; private: - - void _update_fdm () const; - + void updateClosestAirport(); + 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; @@ -88,14 +85,22 @@ private: 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 - FGEnvironmentCtrl * _controller; // always the same, for now - FGMetarCtrl * _metarcontroller; - FGMetarFetcher * _metarfetcher; - FGPrecipitationMgr* _precipitationManager; - FGClouds *fgClouds; + bool _cloudLayersDirty; + SGPropertyNode_ptr _altitude_n; + SGPropertyNode_ptr _longitude_n; + SGPropertyNode_ptr _latitude_n; + simgear::TiedPropertyList _tiedProperties; + SGPropertyChangeListener * _3dCloudsEnableListener; + SGSky* _sky; }; #endif // _ENVIRONMENT_MGR_HXX