1 /* -*- Mode: C++ -*- *****************************************************
3 * Written by Durk Talsma. Started July 1999.
5 * This library is free software; you can redistribute it and/or
6 * modify it under the terms of the GNU Library General Public
7 * License as published by the Free Software Foundation; either
8 * version 2 of the License, or (at your option) any later version.
10 * This library is distributed in the hope that it will be useful,
11 * but WITHOUT ANY WARRANTY; without even the implied warranty of
12 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
13 * Library General Public License for more details.
15 * You should have received a copy of the GNU General Public License
16 * along with this program; if not, write to the Free Software
17 * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
19 **************************************************************************/
21 /*************************************************************************
23 * This file defines a small and simple class to store geocentric
24 * coordinates. Basically, class GeoCoord is intended as a base class for
25 * any kind of of object, that can be categorized according to its
26 * location on earth, be it navaids, or aircraft. This class for originally
27 * written for FlightGear, in order to store Timezone control points.
29 ************************************************************************/
35 #include <simgear/compiler.h>
41 //#include <streambuf> // looks like streambuf does not exist on linux.
42 // But it looks like it isn't used anyways -:)
45 SG_USING_NAMESPACE(std);
47 #include <simgear/constants.h>
56 SGGeoCoord() { lat = 0.0; lon = 0.0;};
57 SGGeoCoord(float la, float lo) { lat = la; lon = lo;};
58 SGGeoCoord(const SGGeoCoord& other);
59 virtual ~SGGeoCoord() {};
61 void set(float la, float lo) { lat = la; lon = lo; };
62 float getLat() const { return lat; };
63 float getLon() const { return lon; };
64 float getX() const { return cos(SGD_DEGREES_TO_RADIANS*lat) * cos(SGD_DEGREES_TO_RADIANS*lon); };
65 float getY() const { return cos(SGD_DEGREES_TO_RADIANS*lat) * sin(SGD_DEGREES_TO_RADIANS*lon); };
66 float getZ() const { return sin(SGD_DEGREES_TO_RADIANS*lat); };
69 //double getAngle(const SGGeoCoord& other) const;
70 virtual void print() {} ;
71 virtual const char * getDescription() {return 0;};
74 typedef vector<SGGeoCoord*> SGGeoCoordVector;
75 typedef vector<SGGeoCoord*>::iterator SGGeoCoordVectorIterator;
76 typedef vector<SGGeoCoord*>::const_iterator SGGeoCoordVectorConstIterator;
78 /************************************************************************
79 * SGGeoCoordContainer is a simple container class, that stores objects
80 * derived from SGGeoCoord. Basically, it is a wrapper around an STL vector,
81 * with some added functionality
82 ***********************************************************************/
84 class SGGeoCoordContainer
87 SGGeoCoordVector data;
90 SGGeoCoordContainer() {};
91 virtual ~SGGeoCoordContainer();
93 const SGGeoCoordVector& getData() const { return data; };
94 SGGeoCoord* getNearest(const SGGeoCoord& ref) const;
98 #endif // _GEO_COORD_H_