1
0
Fork 0

start adding backward-compatibility to newnavradio

This commit is contained in:
Torsten Dreyer 2011-10-09 21:17:33 +02:00
parent 8b05d7b211
commit 9a21896a33
2 changed files with 48 additions and 3 deletions

View file

@ -3,7 +3,7 @@
// Written by Curtis Olson, started April 2000. // Written by Curtis Olson, started April 2000.
// Rewritten by Torsten Dreyer, August 2011 // Rewritten by Torsten Dreyer, August 2011
// //
// Copyright (C) 2000 - 2002 Curtis L. Olson - http://www.flightgear.org/~curt // Copyright (C) 2000 - 2011 Curtis L. Olson - http://www.flightgear.org/~curt
// //
// This program is free software; you can redistribute it and/or // This program is free software; you can redistribute it and/or
// modify it under the terms of the GNU General Public License as // modify it under the terms of the GNU General Public License as
@ -33,6 +33,7 @@
#include <simgear/math/interpolater.hxx> #include <simgear/math/interpolater.hxx>
#include <simgear/sg_inlines.h> #include <simgear/sg_inlines.h>
#include <simgear/props/propertyObject.hxx> #include <simgear/props/propertyObject.hxx>
#include <simgear/misc/strutils.hxx>
#include <Main/fg_props.hxx> #include <Main/fg_props.hxx>
#include <Navaids/navlist.hxx> #include <Navaids/navlist.hxx>
@ -144,6 +145,7 @@ public:
virtual double getRange_nm( const SGGeod & aircraftPosition ); virtual double getRange_nm( const SGGeod & aircraftPosition );
virtual void display( NavIndicator & navIndicator ) = 0; virtual void display( NavIndicator & navIndicator ) = 0;
virtual bool valid() const { return NULL != _navRecord && true == _serviceable; } virtual bool valid() const { return NULL != _navRecord && true == _serviceable; }
virtual const std::string getIdent() const { return _ident; }
protected: protected:
virtual double computeSignalQuality_norm( const SGGeod & aircraftPosition ); virtual double computeSignalQuality_norm( const SGGeod & aircraftPosition );
@ -220,7 +222,7 @@ void NavRadioComponentWithIdent::update( double dt, const SGGeod & aircraftPosit
_audioIdent->setIdent("", 0.0 ); _audioIdent->setIdent("", 0.0 );
return; return;
} }
_audioIdent->setIdent( _navRecord->get_trans_ident(), SGMiscd::clip(_identVolume, 0.0, 1.0) ); _audioIdent->setIdent( _ident, SGMiscd::clip(_identVolume, 0.0, 1.0) );
} }
NavRadioComponent::NavRadioComponent( const std::string & name, SGPropertyNode_ptr rootNode ) : NavRadioComponent::NavRadioComponent( const std::string & name, SGPropertyNode_ptr rootNode ) :
@ -851,6 +853,11 @@ private:
NavRadioImpl * _navRadioImpl; NavRadioImpl * _navRadioImpl;
SGPropertyNode_ptr is_valid_node; SGPropertyNode_ptr is_valid_node;
SGPropertyNode_ptr nav_serviceable_node; SGPropertyNode_ptr nav_serviceable_node;
SGPropertyNode_ptr nav_id_node;
SGPropertyNode_ptr id_c1_node;
SGPropertyNode_ptr id_c2_node;
SGPropertyNode_ptr id_c3_node;
SGPropertyNode_ptr id_c4_node;
} _legacy; } _legacy;
const static int VOR_COMPONENT = 0; const static int VOR_COMPONENT = 0;
@ -937,7 +944,7 @@ void NavRadioImpl::update( double dt )
if( _stationTTL <= 0.0 ) if( _stationTTL <= 0.0 )
_stationTTL = 30.0; _stationTTL = 30.0;
_legacy.init(); _legacy.update( dt );
} }
void NavRadioImpl::Legacy::init() void NavRadioImpl::Legacy::init()
@ -945,6 +952,12 @@ void NavRadioImpl::Legacy::init()
is_valid_node = _navRadioImpl->_rootNode->getChild("data-is-valid", 0, true); is_valid_node = _navRadioImpl->_rootNode->getChild("data-is-valid", 0, true);
nav_serviceable_node = _navRadioImpl->_rootNode->getChild("serviceable", 0, true); nav_serviceable_node = _navRadioImpl->_rootNode->getChild("serviceable", 0, true);
nav_id_node = _navRadioImpl->_rootNode->getChild("nav-id", 0, true );
id_c1_node = _navRadioImpl->_rootNode->getChild("nav-id_asc1", 0, true );
id_c2_node = _navRadioImpl->_rootNode->getChild("nav-id_asc2", 0, true );
id_c3_node = _navRadioImpl->_rootNode->getChild("nav-id_asc3", 0, true );
id_c4_node = _navRadioImpl->_rootNode->getChild("nav-id_asc4", 0, true );
} }
void NavRadioImpl::Legacy::update( double dt ) void NavRadioImpl::Legacy::update( double dt )
@ -952,6 +965,18 @@ void NavRadioImpl::Legacy::update( double dt )
is_valid_node->setBoolValue( is_valid_node->setBoolValue(
_navRadioImpl->_components[VOR_COMPONENT]->valid() || _navRadioImpl->_components[LOC_COMPONENT]->valid() _navRadioImpl->_components[VOR_COMPONENT]->valid() || _navRadioImpl->_components[LOC_COMPONENT]->valid()
); );
string ident = _navRadioImpl->_components[VOR_COMPONENT]->getIdent();
if( ident.empty() )
ident = _navRadioImpl->_components[LOC_COMPONENT]->getIdent();
nav_id_node->setStringValue( ident );
ident = simgear::strutils::rpad( ident, 4, ' ' );
id_c1_node->setIntValue( (int)ident[0] );
id_c2_node->setIntValue( (int)ident[1] );
id_c3_node->setIntValue( (int)ident[2] );
id_c4_node->setIntValue( (int)ident[3] );
} }

View file

@ -1,3 +1,23 @@
// navradio.hxx -- class to manage a nav radio instance
//
// Written by Torsten Dreyer, started August 2011
//
// Copyright (C) 2000 - 2011 Curtis L. Olson - http://www.flightgear.org/~curt
//
// This program is free software; you can redistribute it and/or
// modify it under the terms of the GNU General Public License as
// published by the Free Software Foundation; either version 2 of the
// License, or (at your option) any later version.
//
// This program is distributed in the hope that it will be useful, but
// WITHOUT ANY WARRANTY; without even the implied warranty of
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
// General Public License for more details.
//
// 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., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
//
#ifndef _FG_INSTRUMENTATION_NAVRADIO_HXX #ifndef _FG_INSTRUMENTATION_NAVRADIO_HXX