X-Git-Url: https://git.mxchange.org/?a=blobdiff_plain;f=src%2FInstrumentation%2Fadf.cxx;h=bfde62385875806c35ea7e3d2cc2bdc7cc56dbe6;hb=fe0a703a192a37b96aa4f6048c8e542c24671705;hp=94171731d4c10b996173caebfe176366d78a3a94;hpb=67611bb6b08a31964569f181edd276dd33625db7;p=flightgear.git diff --git a/src/Instrumentation/adf.cxx b/src/Instrumentation/adf.cxx index 94171731d..bfde62385 100644 --- a/src/Instrumentation/adf.cxx +++ b/src/Instrumentation/adf.cxx @@ -17,6 +17,8 @@ #include #include "adf.hxx" +#include + #include #include @@ -103,12 +105,13 @@ ADF::init () _ident_audible_node = node->getChild("ident-audible", 0, true); _power_btn_node = node->getChild("power-btn", 0, true); + if (_power_btn_node->getType() == simgear::props::NONE) + _power_btn_node->setBoolValue(true); // front end didn't implement a power button + SGSoundMgr *smgr = globals->get_soundmgr(); _sgr = smgr->find("avionics", true); _sgr->tie_to_listener(); - morse.init(); - std::ostringstream temp; temp << _name << _num; _adf_ident = temp.str(); @@ -121,6 +124,7 @@ ADF::update (double delta_time_sec) if (_electrical_node->getDoubleValue() < 8.0 || !_serviceable_node->getBoolValue() || !_power_btn_node->getBoolValue() ) { + _in_range_node->setBoolValue(false); _ident_node->setStringValue(""); return; } @@ -128,6 +132,7 @@ ADF::update (double delta_time_sec) string mode = _mode_node->getStringValue(); if (mode == "ant" || mode == "test") set_bearing(delta_time_sec, 90); if (mode != "bfo" && mode != "adf") { + _in_range_node->setBoolValue(false); _ident_node->setStringValue(""); return; } @@ -152,6 +157,7 @@ ADF::update (double delta_time_sec) search(frequency_khz, longitude_rad, latitude_rad, altitude_m); if (!_transmitter_valid) { + _in_range_node->setBoolValue(false); _ident_node->setStringValue(""); return; } @@ -194,7 +200,7 @@ ADF::update (double delta_time_sec) if ( sound != NULL ) sound->set_volume( volume ); else - SG_LOG( SG_GENERAL, SG_ALERT, "Can't find adf-ident sound" ); + SG_LOG( SG_INSTR, SG_ALERT, "Can't find adf-ident sound" ); } time_t cur_time = globals->get_time_params()->get_cur_time(); @@ -249,7 +255,7 @@ ADF::search (double frequency_khz, double longitude_rad, } SGSoundSample *sound; - sound = morse.make_ident( ident, LO_FREQUENCY ); + sound = FGMorse::instance()->make_ident( ident, FGMorse::LO_FREQUENCY ); sound->set_volume(_last_volume = 0); _sgr->add( sound, _adf_ident );