// dynamics.hxx - a class to manage the higher order airport ground activities // Written by Durk Talsma, started December 2004. // // // 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. // // $Id$ #ifndef _AIRPORT_DYNAMICS_HXX_ #define _AIRPORT_DYNAMICS_HXX_ #ifndef __cplusplus # error This library requires C++ #endif #include #include #include "parking.hxx" #include "groundnetwork.hxx" #include "runwayprefs.hxx" //typedef vector DoubleVec; //typedef vector::iterator DoubleVecIterator; class FGAirport; class FGAirportDynamics { private: FGAirport* _ap; FGParkingVec parkings; FGRunwayPreference rwyPrefs; FGStartupController startupController; FGGroundNetwork groundNetwork; FGTowerController towerController; time_t lastUpdate; string prevTrafficType; stringVec landing; stringVec takeoff; stringVec milActive, comActive, genActive, ulActive; stringVec *currentlyActive; intVec freqAwos; // intVec freqUnicom; // intVec freqClearance;// intVec freqGround; // intVec freqTower; // intVec freqApproach; // // Experimental keep a running average of wind dir and speed to prevent // Erratic runway changes. // Note: I should add these to the copy constructor and assigment operator to be // constistent //double avWindHeading [10]; //double avWindSpeed [10]; string chooseRunwayFallback(); public: FGAirportDynamics(FGAirport* ap); FGAirportDynamics(const FGAirportDynamics &other); ~FGAirportDynamics(); void addAwosFreq (int val) { freqAwos.push_back(val); }; void addUnicomFreq (int val) { freqUnicom.push_back(val); }; void addClearanceFreq(int val) { freqClearance.push_back(val); }; void addGroundFreq (int val) { freqGround.push_back(val); }; void addTowerFreq (int val) { freqTower.push_back(val); }; void addApproachFreq (int val) { freqApproach.push_back(val); }; void init(); double getLongitude() const; // Returns degrees double getLatitude() const; // Returns ft double getElevation() const; const string& getId() const; void getActiveRunway(const string& trafficType, int action, string& runway); void addParking(FGParking& park); bool getAvailableParking(double *lat, double *lon, double *heading, int *gate, double rad, const string& fltype, const string& acType, const string& airline); void getParking (int id, double *lat, double* lon, double *heading); FGParking *getParking(int i); void releaseParking(int id); string getParkingName(int i); int getNrOfParkings() { return parkings.size(); }; //FGAirport *getAddress() { return this; }; //const string &getName() const { return _name;}; // Returns degrees int getGroundFrequency() { return freqGround.size() ? freqGround[0] : 0; }; FGStartupController *getStartupController() { return &startupController; }; FGGroundNetwork *getGroundNetwork() { return &groundNetwork; }; FGTowerController *getTowerController() { return &towerController; }; void setRwyUse(const FGRunwayPreference& ref); }; #endif