]> git.mxchange.org Git - flightgear.git/blob - Simulator/Astro/star.hxx
Initial revision
[flightgear.git] / Simulator / Astro / star.hxx
1 /**************************************************************************
2  * star.hxx
3  * Written by Durk Talsma. Originally started October 1997, for distribution  
4  * with the FlightGear project. Version 2 was written in August and 
5  * September 1998. This code is based upon algorithms and data kindly 
6  * provided by Mr. Paul Schlyter. (pausch@saaf.se). 
7  *
8  * This program is free software; you can redistribute it and/or
9  * modify it under the terms of the GNU General Public License as
10  * published by the Free Software Foundation; either version 2 of the
11  * License, or (at your option) any later version.
12  *
13  * This program is distributed in the hope that it will be useful, but
14  * WITHOUT ANY WARRANTY; without even the implied warranty of
15  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
16  * General Public License for more details.
17  *
18  * You should have received a copy of the GNU General Public License
19  * along with this program; if not, write to the Free Software
20  * Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
21  *
22  * $Id$
23  * (Log is kept at end of this file)
24  **************************************************************************/
25 #ifndef _STAR_HXX_
26 #define _STAR_HXX_
27
28 #include <Time/fg_time.hxx>
29 #include "celestialBody.hxx"
30
31
32 class Star : public CelestialBody
33 {
34 private:
35   //double longitude;  // the sun's true longitude - this is depreciated by
36                        // CelestialBody::lonEcl 
37   double xs, ys;     // the sun's rectangular geocentric coordinates
38   double distance;   // the sun's distance to the earth
39    GLUquadricObj *SunObject;
40   GLuint sun_texid;
41   GLubyte *sun_texbuf;
42
43   void setTexture();
44 public:
45   Star (fgTIME *t);
46   ~Star();
47   void updatePosition(fgTIME *t);
48   double getM();
49   double getw();
50   //double getLon();
51   double getxs();
52   double getys();
53   double getDistance();
54   void newImage();
55 };
56
57
58
59 inline double Star::getM()
60 {
61   return M;
62 }
63
64 inline double Star::getw()
65 {
66   return w;
67 }
68
69 inline double Star::getxs()
70 {
71   return xs;
72 }
73
74 inline double Star::getys()
75 {
76   return ys;
77 }
78
79 inline double Star::getDistance()
80 {
81   return distance;
82 }
83
84
85 #endif // _STAR_HXX_
86
87
88
89
90
91
92
93
94
95
96
97
98
99