X-Git-Url: https://git.mxchange.org/?a=blobdiff_plain;f=src%2FInstrumentation%2Fnavradio.hxx;h=c731f1d2b7a3c896c2efce7c7035a1831d92931e;hb=52fd6986f88051ccc00fc2d01529568d79d5a56c;hp=92f80bc37bdb727a6e16f9401ff1186f0c86e392;hpb=12c5a631f6be4c945da88ac7ba1c3e1c6f992904;p=flightgear.git diff --git a/src/Instrumentation/navradio.hxx b/src/Instrumentation/navradio.hxx index 92f80bc37..c731f1d2b 100644 --- a/src/Instrumentation/navradio.hxx +++ b/src/Instrumentation/navradio.hxx @@ -24,28 +24,18 @@ #ifndef _FG_NAVRADIO_HXX #define _FG_NAVRADIO_HXX - +#include #include
#include #include -#include #include -#include -#include +class SGSampleGroup; -class FGNavRadio : public SGSubsystem +class FGNavRadio : public SGSubsystem, public SGPropertyChangeListener { - FGMorse morse; - - SGInterpTable *term_tbl; - SGInterpTable *low_tbl; - SGInterpTable *high_tbl; - - SGPropertyNode_ptr lon_node; - SGPropertyNode_ptr lat_node; - SGPropertyNode_ptr alt_node; + SGPropertyNode_ptr _radio_node; SGPropertyNode_ptr bus_power_node; // property inputs @@ -54,6 +44,7 @@ class FGNavRadio : public SGSubsystem SGPropertyNode_ptr power_btn_node; SGPropertyNode_ptr freq_node; // primary freq SGPropertyNode_ptr alt_freq_node; // standby freq + SGPropertyNode_ptr is_loc_freq_node;// is the primary freq a loc/gs (paired) freq? SGPropertyNode_ptr sel_radial_node; // selected radial SGPropertyNode_ptr vol_btn_node; SGPropertyNode_ptr ident_btn_node; @@ -63,7 +54,7 @@ class FGNavRadio : public SGSubsystem SGPropertyNode_ptr cdi_serviceable_node; SGPropertyNode_ptr gs_serviceable_node; SGPropertyNode_ptr tofrom_serviceable_node; - + // property outputs SGPropertyNode_ptr fmt_freq_node; // formated frequency SGPropertyNode_ptr fmt_alt_freq_node; // formated alternate frequency @@ -87,14 +78,20 @@ class FGNavRadio : public SGSubsystem SGPropertyNode_ptr inrange_node; SGPropertyNode_ptr signal_quality_norm_node; SGPropertyNode_ptr cdi_deflection_node; + SGPropertyNode_ptr cdi_deflection_norm_node; SGPropertyNode_ptr cdi_xtrack_error_node; SGPropertyNode_ptr cdi_xtrack_hdg_err_node; SGPropertyNode_ptr has_gs_node; SGPropertyNode_ptr loc_node; SGPropertyNode_ptr loc_dist_node; SGPropertyNode_ptr gs_deflection_node; + SGPropertyNode_ptr gs_deflection_deg_node; + SGPropertyNode_ptr gs_deflection_norm_node; + SGPropertyNode_ptr gs_direct_node; SGPropertyNode_ptr gs_rate_of_climb_node; + SGPropertyNode_ptr gs_rate_of_climb_fpm_node; SGPropertyNode_ptr gs_dist_node; + SGPropertyNode_ptr gs_inrange_node; SGPropertyNode_ptr nav_id_node; SGPropertyNode_ptr id_c1_node; SGPropertyNode_ptr id_c2_node; @@ -107,49 +104,52 @@ class FGNavRadio : public SGSubsystem SGPropertyNode_ptr gps_to_flag_node; SGPropertyNode_ptr gps_from_flag_node; SGPropertyNode_ptr gps_has_gs_node; + SGPropertyNode_ptr gps_course_node; + SGPropertyNode_ptr gps_xtrack_error_nm_node; + SGPropertyNode_ptr _magvarNode; + + // realism setting, are false courses and GS lobes enabled? + SGPropertyNode_ptr falseCoursesEnabledNode; // internal (private) values - string last_nav_id; - bool last_nav_vor; + bool _operable; ///< is the unit serviceable, on, powered, etc int play_count; - time_t last_time; - - int index; // used for property binding - string nav_fx_name; - string dme_fx_name; - - string trans_ident; - bool is_valid; - bool has_dme; - double radial; + bool _nav_search; + double _last_freq; + FGNavRecordRef _navaid; + FGNavRecordRef _gs; + double target_radial; - double loc_lon; - double loc_lat; - SGVec3d nav_xyz; - double gs_lon; - double gs_lat; - double nav_elev; // use gs elev if available - SGVec3d gs_xyz; - SGVec3d gs_base_vec; - double gs_dist_signed; - SGTimeStamp prev_time; - SGTimeStamp curr_time; - double range; double effective_range; double target_gs; double twist; double horiz_vel; double last_x; - double last_loc_dist; double last_xtrack_error; - - string _name; + double xrate_ms; + double _localizerWidth; // cached localizer width in degrees + + std::string _name; int _num; // internal periodic station search timer double _time_before_search_sec; + SGVec3d _gsCart, _gsAxis, _gsVertical, _gsBaseline; + + // CDI properties + bool _toFlag, _fromFlag; + double _cdiDeflection; + double _cdiCrossTrackErrorM; + double _gsNeedleDeflection; + double _gsNeedleDeflectionNorm; + double _gsDirect; + + class AudioIdent * _audioIdent; + + bool updateWithPower(double aDt); + // model standard VOR/DME/TACAN service volumes as per AIM 1-1-8 double adjustNavRange( double stationElev, double aircraftElev, double nominalRange ); @@ -158,18 +158,37 @@ class FGNavRadio : public SGSubsystem double adjustILSRange( double stationElev, double aircraftElev, double offsetDegrees, double distance ); + void updateAudio( double dt ); + + void updateReceiver(double dt); + void updateGlideSlope(double dt, const SGVec3d& aircraft, double signal_quality_norm); + void updateGPSSlaved(); + void updateCDI(double dt); + + void clearOutputs(); + + FGNavRecord* findPrimaryNavaid(const SGGeod& aPos, double aFreqMHz); + + /// accessor for tied, read-only 'operable' property + bool isOperable() const + { return _operable; } + + // implement SGPropertyChangeListener + virtual void valueChanged (SGPropertyNode * prop); public: FGNavRadio(SGPropertyNode *node); ~FGNavRadio(); void init (); + void reinit (); void bind (); void unbind (); void update (double dt); // Update nav/adf radios based on current postition void search (); + void updateNav(); };