// ils.hxx -- navaid class // // Written by Curtis Olson, started April 2000. // // Copyright (C) 2000 Curtis L. Olson - curt@flightgear.org // // 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., 675 Mass Ave, Cambridge, MA 02139, USA. // // $Id$ #ifndef _FG_ILS_HXX #define _FG_ILS_HXX #include #include #include #ifdef FG_HAVE_STD_INCLUDES # include #elif defined( FG_HAVE_NATIVE_SGI_COMPILERS ) # include #elif defined( __BORLANDC__ ) # include #else # include #endif #if ! defined( FG_HAVE_NATIVE_SGI_COMPILERS ) FG_USING_STD(istream); #endif #define FG_ILS_DEFAULT_RANGE 30 class FGILS { char ilstype; char ilstypename[6]; char aptcode[5]; char rwyno[4]; int locfreq; char locident[5]; double locheading; double loclat; double loclon; double x, y, z; bool has_gs; double gselev; double gsangle; double gslat; double gslon; double gs_x, gs_y, gs_z; bool has_dme; double dmelat; double dmelon; double dme_x, dme_y, dme_z; double omlat; double omlon; double mmlat; double mmlon; double imlat; double imlon; public: inline FGILS(void) {} inline ~FGILS(void) {} inline char get_ilstype() const { return ilstype; } inline char *get_ilstypename() { return ilstypename; } inline char *get_aptcode() { return aptcode; } inline char *get_rwyno() { return rwyno; } inline int get_locfreq() const { return locfreq; } inline char *get_locident() { return locident; } inline double get_locheading() const { return locheading; } inline double get_loclat() const { return loclat; } inline double get_loclon() const { return loclon; } inline double get_x() const { return x; } inline double get_y() const { return y; } inline double get_z() const { return z; } inline bool get_has_gs() const { return has_gs; } inline double get_gselev() const { return gselev; } inline double get_gsangle() const { return gsangle; } inline double get_gslat() const { return gslat; } inline double get_gslon() const { return gslon; } inline double get_gs_x() const { return gs_x; } inline double get_gs_y() const { return gs_y; } inline double get_gs_z() const { return gs_z; } inline bool get_has_dme() const { return has_dme; } inline double get_dmelat() const { return dmelat; } inline double get_dmelon() const { return dmelon; } inline double get_dme_x() const { return dme_x; } inline double get_dme_y() const { return dme_y; } inline double get_dme_z() const { return dme_z; } inline double get_omlat() const { return omlat; } inline double get_omlon() const { return omlon; } inline double get_mmlat() const { return mmlat; } inline double get_mmlon() const { return mmlon; } inline double get_imlat() const { return imlat; } inline double get_imlon() const { return imlon; } friend istream& operator>> ( istream&, FGILS& ); }; inline istream& operator >> ( istream& in, FGILS& i ) { double f; in >> i.ilstype >> i.ilstypename >> i.aptcode >> i.rwyno >> f >> i.locident >> i.locheading >> i.loclat >> i.loclon >> i.gselev >> i.gsangle >> i.gslat >> i.gslon >> i.dmelat >> i.dmelon >> i.omlat >> i.omlon >> i.mmlat >> i.mmlon >> i.imlat >> i.imlon; i.locfreq = (int)(f*100.0 + 0.5); // generate cartesian coordinates Point3D geod, cart; geod = Point3D( i.loclon * DEG_TO_RAD, i.loclat * DEG_TO_RAD, i.gselev ); cart = sgGeodToCart( geod ); i.x = cart.x(); i.y = cart.y(); i.z = cart.z(); if ( i.gslon < FG_EPSILON && i.gslat < FG_EPSILON ) { i.has_gs = false; } else { i.has_gs = true; geod = Point3D( i.gslon * DEG_TO_RAD, i.gslat * DEG_TO_RAD, i.gselev ); cart = sgGeodToCart( geod ); i.gs_x = cart.x(); i.gs_y = cart.y(); i.gs_z = cart.z(); // cout << "gs = " << cart << endl; } if ( i.dmelon < FG_EPSILON && i.dmelat < FG_EPSILON ) { i.has_dme = false; } else { i.has_dme = true; geod = Point3D( i.dmelon * DEG_TO_RAD, i.dmelat * DEG_TO_RAD, i.gselev); cart = sgGeodToCart( geod ); i.dme_x = cart.x(); i.dme_y = cart.y(); i.dme_z = cart.z(); // cout << "dme = " << cart << endl; } // return in >> skipeol; return in; } #endif // _FG_ILS_HXX