]> git.mxchange.org Git - flightgear.git/blob - src/Cockpit/radiostack.hxx
Replaced Durk's mymath.* with plib/sg.h (contributed by Durk).
[flightgear.git] / src / Cockpit / radiostack.hxx
1 // radiostack.hxx -- class to manage an instance of the radio stack
2 //
3 // Written by Curtis Olson, started April 2000.
4 //
5 // Copyright (C) 2000  Curtis L. Olson - curt@flightgear.org
6 //
7 // This program is free software; you can redistribute it and/or
8 // modify it under the terms of the GNU General Public License as
9 // published by the Free Software Foundation; either version 2 of the
10 // License, or (at your option) any later version.
11 //
12 // This program is distributed in the hope that it will be useful, but
13 // WITHOUT ANY WARRANTY; without even the implied warranty of
14 // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
15 // General Public License for more details.
16 //
17 // You should have received a copy of the GNU General Public License
18 // along with this program; if not, write to the Free Software
19 // Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
20 //
21 // $Id$
22
23
24 #ifndef _FG_RADIOSTACK_HXX
25 #define _FG_RADIOSTACK_HXX
26
27
28 #include <simgear/compiler.h>
29
30 #include <Navaids/ilslist.hxx>
31 #include <Navaids/navlist.hxx>
32
33
34 class FGRadioStack {
35
36     bool need_update;
37
38     bool nav1_valid;
39     bool nav1_inrange;
40     bool nav1_has_dme;
41     bool nav1_has_gs;
42     bool nav1_loc;
43     double nav1_freq;
44     double nav1_alt_freq;
45     double nav1_radial;
46     double nav1_sel_radial;
47     double nav1_loclon;
48     double nav1_loclat;
49     double nav1_x;
50     double nav1_y;
51     double nav1_z;
52     double nav1_loc_dist;
53     double nav1_gslon;
54     double nav1_gslat;
55     double nav1_gs_x;
56     double nav1_gs_y;
57     double nav1_gs_z;
58     double nav1_gs_dist;
59     double nav1_dmelon;
60     double nav1_dmelat;
61     double nav1_dme_x;
62     double nav1_dme_y;
63     double nav1_dme_z;
64     double nav1_dme_dist;
65     double nav1_elev;
66     double nav1_effective_range;
67     double nav1_heading;
68     double nav1_target_gs;
69
70     bool nav2_valid;
71     bool nav2_inrange;
72     bool nav2_has_dme;
73     bool nav2_has_gs;
74     bool nav2_loc;
75     double nav2_freq;
76     double nav2_alt_freq;
77     double nav2_radial;
78     double nav2_sel_radial;
79     double nav2_loclon;
80     double nav2_loclat;
81     double nav2_x;
82     double nav2_y;
83     double nav2_z;
84     double nav2_loc_dist;
85     double nav2_gslon;
86     double nav2_gslat;
87     double nav2_gs_x;
88     double nav2_gs_y;
89     double nav2_gs_z;
90     double nav2_gs_dist;
91     double nav2_dmelon;
92     double nav2_dmelat;
93     double nav2_dme_x;
94     double nav2_dme_y;
95     double nav2_dme_z;
96     double nav2_dme_dist;
97     double nav2_elev;
98     double nav2_effective_range;
99     double nav2_heading;
100     double nav2_target_gs;
101
102     bool adf_valid;
103     bool adf_inrange;
104     double adf_freq;
105     double adf_alt_freq;
106     double adf_rotation;
107     double adf_lon;
108     double adf_lat;
109     double adf_elev;
110     double adf_effective_range;
111     double adf_dist;
112     double adf_heading;
113     double adf_x;
114     double adf_y;
115     double adf_z;
116
117 public:
118
119     FGRadioStack();
120     ~FGRadioStack();
121
122     // Update nav/adf radios based on current postition
123     void search( double lon, double lat, double elev );
124
125     // Update nav/adf radios based on current postition
126     void update( double lon, double lat, double elev );
127
128     // NAV1 Setters
129     inline void set_nav1_freq( double freq ) {
130         nav1_freq = freq; need_update = true;
131     }
132     inline void set_nav1_alt_freq( double freq ) { nav1_alt_freq = freq; }
133     inline void set_nav1_sel_radial( double radial ) {
134         nav1_sel_radial = radial; need_update = true;
135     }
136
137     // NAV2 Setters
138     inline void set_nav2_freq( double freq ) {
139         nav2_freq = freq; need_update = true;
140     }
141     inline void set_nav2_alt_freq( double freq ) { nav2_alt_freq = freq; }
142     inline void set_nav2_sel_radial( double radial ) {
143         nav2_sel_radial = radial; need_update = true;
144     }
145
146     // ADF Setters
147     inline void set_adf_freq( double freq ) {
148         adf_freq = freq; need_update = true;
149     }
150     inline void set_adf_alt_freq( double freq ) { adf_alt_freq = freq; }
151     inline void set_adf_rotation( double rot ) { adf_rotation = rot; }
152
153
154     // NAV1 Accessors
155     inline double get_nav1_freq () const { return nav1_freq; }
156     inline double get_nav1_alt_freq () const { return nav1_alt_freq; }
157     inline double get_nav1_sel_radial() const { return nav1_sel_radial; }
158
159     // NAV2 Accessors
160     inline double get_nav2_freq () const { return nav2_freq; }
161     inline double get_nav2_alt_freq () const { return nav2_alt_freq; }
162     inline double get_nav2_sel_radial() const { return nav2_sel_radial; }
163
164     // ADF Accessors
165     inline double get_adf_freq () const { return adf_freq; }
166     inline double get_adf_alt_freq () const { return adf_alt_freq; }
167     inline double get_adf_rotation () const { return adf_rotation; }
168
169     // Calculated values.
170     inline bool get_nav1_inrange() const { return nav1_inrange; }
171     inline bool get_nav1_has_dme() const { return nav1_has_dme; }
172     inline bool get_nav1_has_gs() const { return nav1_has_gs; }
173     inline bool get_nav1_loc() const { return nav1_loc; }
174     inline double get_nav1_loclon() const { return nav1_loclon; }
175     inline double get_nav1_loclat() const { return nav1_loclat; }
176     inline double get_nav1_loc_dist() const { return nav1_loc_dist; }
177     inline double get_nav1_gslon() const { return nav1_gslon; }
178     inline double get_nav1_gslat() const { return nav1_gslat; }
179     inline double get_nav1_gs_dist() const { return nav1_gs_dist; }
180     inline double get_nav1_dmelon() const { return nav1_dmelon; }
181     inline double get_nav1_dmelat() const { return nav1_dmelat; }
182     inline double get_nav1_dme_dist() const { return nav1_dme_dist; }
183     inline double get_nav1_elev() const { return nav1_elev; }
184     inline double get_nav1_heading() const { return nav1_heading; }
185     inline double get_nav1_radial() const { return nav1_radial; }
186     inline double get_nav1_target_gs() const { return nav1_target_gs; }
187
188     inline bool get_nav2_inrange() const { return nav2_inrange; }
189     inline bool get_nav2_has_dme() const { return nav2_has_dme; }
190     inline bool get_nav2_has_gs() const { return nav2_has_gs; }
191     inline bool get_nav2_loc() const { return nav2_loc; }
192     inline double get_nav2_loclon() const { return nav2_loclon; }
193     inline double get_nav2_loclat() const { return nav2_loclat; }
194     inline double get_nav2_loc_dist() const { return nav2_loc_dist; }
195     inline double get_nav2_gslon() const { return nav2_gslon; }
196     inline double get_nav2_gslat() const { return nav2_gslat; }
197     inline double get_nav2_gs_dist() const { return nav2_gs_dist; }
198     inline double get_nav2_dmelon() const { return nav2_dmelon; }
199     inline double get_nav2_dmelat() const { return nav2_dmelat; }
200     inline double get_nav2_dme_dist() const { return nav2_dme_dist; }
201     inline double get_nav2_elev() const { return nav2_elev; }
202     inline double get_nav2_heading() const { return nav2_heading; }
203     inline double get_nav2_radial() const { return nav2_radial; }
204     inline double get_nav2_target_gs() const { return nav2_target_gs; }
205
206     inline bool get_adf_inrange() const { return adf_inrange; }
207     inline double get_adf_lon() const { return adf_lon; }
208     inline double get_adf_lat() const { return adf_lat; }
209     inline double get_adf_heading() const { return adf_heading; }
210 };
211
212
213 extern FGRadioStack *current_radiostack;
214
215
216 // periodic radio station search wrapper
217 void fgRadioSearch( void );
218
219
220 #endif // _FG_RADIOSTACK_HXX