X-Git-Url: https://git.mxchange.org/?a=blobdiff_plain;f=src%2FInstrumentation%2Ftacan.hxx;h=fcbc737c840de59d33bed1d55e9fc7509974d671;hb=52fd6986f88051ccc00fc2d01529568d79d5a56c;hp=573f4b111465c8918f8f0fa635e038b8cf12bdae;hpb=62a359cc4a338b2f8b720edf8183ab5b69710b14;p=flightgear.git diff --git a/src/Instrumentation/tacan.hxx b/src/Instrumentation/tacan.hxx old mode 100755 new mode 100644 index 573f4b111..fcbc737c8 --- a/src/Instrumentation/tacan.hxx +++ b/src/Instrumentation/tacan.hxx @@ -7,11 +7,6 @@ #ifndef __INSTRUMENTS_TACAN_HXX #define __INSTRUMENTS_TACAN_HXX 1 -#ifndef __cplusplus -# error This library requires C++ -#endif - -#include #include #include @@ -24,9 +19,9 @@ * /position/longitude-deg * /position/latitude-deg * /position/altitude-ft + * /heading * /systems/electrical/outputs/TACAN * /instrumentation/"name"/serviceable - * /instrumentation/"name"/frequencies/source * /instrumentation/"name"/frequencies/selected-mhz * * Output properties: @@ -36,31 +31,36 @@ * /instrumentation/"name"/indicated-ground-speed-kt * /instrumentation/"name"/indicated-time-kt */ -class TACAN : public SGSubsystem +class TACAN : public SGSubsystem, public SGPropertyChangeListener { -public: + public: - TACAN ( SGPropertyNode *node ); - TACAN (); - virtual ~TACAN (); + TACAN(SGPropertyNode *node); + virtual ~TACAN(); virtual void init (); + virtual void reinit (); virtual void update (double delta_time_sec); -private: + private: + + void disabled(bool force = false); + + void search (double frequency, const SGGeod& pos); + double searchChannel (const std::string& channel); + void valueChanged (SGPropertyNode *); - void search (double frequency, double longitude_rad, - double latitude_rad, double altitude_m); - double searchChannel (const string& _channel); + std::string _name; + unsigned int _num; - SGPropertyNode_ptr _longitude_node; - SGPropertyNode_ptr _latitude_node; - SGPropertyNode_ptr _altitude_node; + SGPropertyNode_ptr _heading_node; SGPropertyNode_ptr _serviceable_node; SGPropertyNode_ptr _electrical_node; - SGPropertyNode_ptr _source_node; SGPropertyNode_ptr _frequency_node; + SGPropertyNode_ptr _display_node; + SGPropertyNode_ptr _x_shift_node; + SGPropertyNode_ptr _y_shift_node; SGPropertyNode_ptr _in_range_node; SGPropertyNode_ptr _distance_node; @@ -69,39 +69,24 @@ private: SGPropertyNode_ptr _bearing_node; SGPropertyNode_ptr _ident_node; SGPropertyNode_ptr _name_node; - - SGPropertyNode_ptr _carrier_lat_node; - SGPropertyNode_ptr _carrier_lon_node; - SGPropertyNode_ptr _carrier_name_node; - - SGPropertyNode_ptr _channel_node; - + SGPropertyNode_ptr _channel_node; + SGPropertyNode_ptr _channel_in0_node; + SGPropertyNode_ptr _channel_in1_node; + SGPropertyNode_ptr _channel_in2_node; + SGPropertyNode_ptr _channel_in3_node; + SGPropertyNode_ptr _channel_in4_node; + + bool _was_disabled; + bool _new_frequency; + std::string _channel; double _last_distance_nm; - double _last_frequency_mhz; + double _frequency_mhz; double _time_before_search_sec; - - bool _carrier_valid; - bool _transmitter_valid; - - Point3D _transmitter; - double _transmitter_lat, _transmitter_lon; - double _transmitter_elevation_ft; - double _transmitter_range_nm; - double _transmitter_bearing_deg; - double _transmitter_bias; - string _transmitter_name; - - double _carrier_lat, _carrier_lon; - double _carrier_elevation_ft; - double _carrier_range_nm; - double _carrier_bearing_deg; - double _carrier_bias; - string _carrier_name; - - string name; - int num; + FGNavRecordRef _active_station; + + int _listener_active; };