// route_mgr.hxx - manage a route (i.e. a collection of waypoints) // // Written by Curtis Olson, started January 2004. // // Copyright (C) 2004 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. // // $Id$ #ifndef _ROUTE_MGR_HXX #define _ROUTE_MGR_HXX 1 #include #include #include // forward decls class SGRoute; class SGPath; /** * Top level route manager class * */ class FGRouteMgr : public SGSubsystem { private: SGRoute* _route; time_t _takeoffTime; time_t _touchdownTime; bool _autoSequence; // true if we are doing internal sequencing // false if other code (FMS/GPS) is managing sequencing // automatic inputs SGPropertyNode_ptr lon; SGPropertyNode_ptr lat; SGPropertyNode_ptr alt; SGPropertyNode_ptr magvar; // automatic outputs bool _driveAutopilot; SGPropertyNode_ptr _apTargetAltitudeFt; SGPropertyNode_ptr _apAltitudeLock; SGPropertyNode_ptr _apTrueHeading; SGPropertyNode_ptr departure; ///< departure airport information SGPropertyNode_ptr destination; ///< destination airport information SGPropertyNode_ptr alternate; ///< alternate airport information SGPropertyNode_ptr cruise; ///< cruise information SGPropertyNode_ptr totalDistance; SGPropertyNode_ptr ete; SGPropertyNode_ptr elapsedFlightTime; SGPropertyNode_ptr active; SGPropertyNode_ptr airborne; SGPropertyNode_ptr currentWp; SGPropertyNode_ptr wp0; SGPropertyNode_ptr wp1; SGPropertyNode_ptr wpn; SGPropertyNode_ptr _pathNode; void setETAPropertyFromDistance(SGPropertyNode_ptr aProp, double aDistance); class InputListener : public SGPropertyChangeListener { public: InputListener(FGRouteMgr *m) : mgr(m) {} virtual void valueChanged (SGPropertyNode * prop); private: FGRouteMgr *mgr; }; SGPropertyNode_ptr input; SGPropertyNode_ptr weightOnWheels; InputListener *listener; SGPropertyNode_ptr mirror; bool altitude_set; /** * Create a SGWayPoint from a string in the following format: * - simple identifier * - decimal-lon,decimal-lat * - airport-id/runway-id * - navaid/radial-deg/offset-nm */ SGWayPoint* make_waypoint(const string& target); void update_mirror(); bool near_ground(); void currentWaypointChanged(); /** * Helper to update the target_altitude_ft and altitude_set flag when wp0 * changes */ void updateTargetAltitude(); /** * Parse a route/wp node (from a saved, property-lsit formatted route) */ void parseRouteWaypoint(SGPropertyNode* aWP); public: FGRouteMgr(); ~FGRouteMgr(); void init (); void postinit (); void bind (); void unbind (); void update (double dt); bool build (); void new_waypoint( const string& tgt_alt, int n = -1 ); void add_waypoint( const SGWayPoint& wp, int n = -1 ); SGWayPoint pop_waypoint( int i = 0 ); SGWayPoint get_waypoint( int i ) const; int size() const; bool isRouteActive() const; int currentWaypoint() const; /** * Find a waypoint in the route, by position, and return its index, or * -1 if no matching waypoint was found in the route. */ int findWaypoint(const SGGeod& aPos) const; /** * Activate a built route. This checks for various mandatory pieces of * data, such as departure and destination airports, and creates waypoints * for them on the route structure. * * returns true if the route was activated successfully, or false if the * route could not be activated for some reason */ bool activate(); /** * Step to the next waypoint on the active route */ void sequence(); /** * */ void jumpToIndex(int index); void saveRoute(); void loadRoute(); }; #endif // _ROUTE_MGR_HXX