2005-11-30 00:18:42 +00:00
|
|
|
// kln89_page_*.[ch]xx - this file is one of the "pages" that
|
|
|
|
// are used in the KLN89 GPS unit simulation.
|
|
|
|
//
|
|
|
|
// Written by David Luff, started 2005.
|
|
|
|
//
|
2010-11-21 17:14:15 +00:00
|
|
|
// Copyright (C) 2005 - David C Luff - daveluff AT ntlworld.com
|
2005-11-30 00:18:42 +00:00
|
|
|
//
|
|
|
|
// 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
|
2006-02-21 01:16:04 +00:00
|
|
|
// Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
|
2005-11-30 00:18:42 +00:00
|
|
|
//
|
|
|
|
// $Id$
|
|
|
|
|
|
|
|
#ifndef _KLN89_PAGE_APT
|
|
|
|
#define _KLN89_PAGE_APT
|
|
|
|
|
|
|
|
#include "kln89.hxx"
|
|
|
|
|
James Turner:
Convert FGRunway to be heap-based, and inherit FGPositioned. This is a large, ugly change, since FGRunway was essentially a plain struct, with no accessors or abstraction. This change adds various helpers and accessors to FGRunway, but doesn't change many places to use them - that will be a follow up series of patches. It's still a large patch, but outside of FGAirport and FGRunway, mostly mechanical search-and-replace.
An interesting part of this change is that reciprocal runways now exist as independent objects, rather than being created on the fly by the search methods. This simplifies some pieces of code that search for and iterate runways. For users who only want one 'end' of a runway, the new 'isReciprocal' predicate allows them to ignore the 'other' end. Current the only user of this is the 'ground-radar' ATC feature. If we had data on which runways are truly 'single-ended', it would now be trivial to use this in the airport loader to *not* create the reciprocal.
2008-09-11 08:38:09 +00:00
|
|
|
class FGRunway;
|
2005-11-30 00:18:42 +00:00
|
|
|
|
|
|
|
struct AptFreq {
|
2011-10-17 17:41:59 +01:00
|
|
|
std::string service;
|
2005-11-30 00:18:42 +00:00
|
|
|
unsigned short int freq;
|
|
|
|
};
|
|
|
|
|
|
|
|
class KLN89AptPage : public KLN89Page {
|
|
|
|
|
|
|
|
public:
|
|
|
|
KLN89AptPage(KLN89* parent);
|
|
|
|
~KLN89AptPage();
|
|
|
|
|
|
|
|
void Update(double dt);
|
|
|
|
|
|
|
|
void CrsrPressed();
|
|
|
|
void ClrPressed();
|
|
|
|
void EntPressed();
|
|
|
|
void Knob1Left1();
|
|
|
|
void Knob1Right1();
|
|
|
|
void Knob2Left1();
|
|
|
|
void Knob2Right1();
|
|
|
|
|
2011-10-17 17:41:59 +01:00
|
|
|
void SetId(const std::string& s);
|
2005-11-30 00:18:42 +00:00
|
|
|
|
|
|
|
private:
|
|
|
|
// Update the cached airport details
|
2011-10-17 17:41:59 +01:00
|
|
|
void UpdateAirport(const std::string& id);
|
2005-11-30 00:18:42 +00:00
|
|
|
|
2011-10-17 17:41:59 +01:00
|
|
|
std::string _apt_id;
|
|
|
|
std::string _last_apt_id;
|
|
|
|
std::string _save_apt_id;
|
2005-11-30 00:18:42 +00:00
|
|
|
const FGAirport* ap;
|
|
|
|
|
James Turner:
Convert FGRunway to be heap-based, and inherit FGPositioned. This is a large, ugly change, since FGRunway was essentially a plain struct, with no accessors or abstraction. This change adds various helpers and accessors to FGRunway, but doesn't change many places to use them - that will be a follow up series of patches. It's still a large patch, but outside of FGAirport and FGRunway, mostly mechanical search-and-replace.
An interesting part of this change is that reciprocal runways now exist as independent objects, rather than being created on the fly by the search methods. This simplifies some pieces of code that search for and iterate runways. For users who only want one 'end' of a runway, the new 'isReciprocal' predicate allows them to ignore the 'other' end. Current the only user of this is the 'ground-radar' ATC feature. If we had data on which runways are truly 'single-ended', it would now be trivial to use this in the airport loader to *not* create the reciprocal.
2008-09-11 08:38:09 +00:00
|
|
|
vector<FGRunway*> _aptRwys;
|
2005-11-30 00:18:42 +00:00
|
|
|
vector<AptFreq> _aptFreqs;
|
|
|
|
|
|
|
|
iap_list_type _iaps;
|
|
|
|
unsigned int _curIap; // The index into _iaps of the IAP we are currently selecting
|
2009-10-17 13:04:21 +00:00
|
|
|
vector<GPSFlightPlan*> _approachRoutes; // The approach route(s) from the IAF(s) to the IF.
|
2005-11-30 00:18:42 +00:00
|
|
|
vector<GPSWaypoint*> _IAP; // The compulsory waypoints of the approach procedure (may duplicate one of the above).
|
|
|
|
// _IAP includes the FAF and MAF.
|
|
|
|
vector<GPSWaypoint*> _MAP; // The missed approach procedure (doesn't include the MAF).
|
2009-10-17 13:04:21 +00:00
|
|
|
unsigned int _curIaf; // The index into _approachRoutes of the IAF we are currently selecting, and then remembered as the one we selected
|
2005-11-30 00:18:42 +00:00
|
|
|
|
|
|
|
// Position in rwy pages
|
|
|
|
unsigned int _curRwyPage;
|
|
|
|
unsigned int _nRwyPages;
|
|
|
|
|
|
|
|
// Position in freq pages
|
|
|
|
unsigned int _curFreqPage;
|
|
|
|
unsigned int _nFreqPages;
|
|
|
|
|
|
|
|
// Position in IAP list (0-based number of first IAP displayed)
|
|
|
|
unsigned int _iapStart;
|
|
|
|
// ditto for IAF list (can't test this since can't find an approach with > 3 IAF at the moment!)
|
|
|
|
unsigned int _iafStart;
|
|
|
|
// ditto for list of approach fixes when asking load confirmation
|
|
|
|
unsigned int _fStart;
|
|
|
|
|
|
|
|
// Various IAP related dialog states that we might need to remember
|
|
|
|
bool _iafDialog;
|
|
|
|
bool _addDialog;
|
|
|
|
bool _replaceDialog;
|
|
|
|
};
|
|
|
|
|
|
|
|
#endif // _KLN89_PAGE_APT
|