]> git.mxchange.org Git - flightgear.git/blob - src/Cockpit/radiostack.hxx
ADF needle doesn't zero when it goes out of range.
[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 <Main/fgfs.hxx>
29 #include <Main/fg_props.hxx>
30
31 #include <simgear/compiler.h>
32
33 #include <simgear/math/interpolater.hxx>
34
35 #include <Navaids/ilslist.hxx>
36 #include <Navaids/navlist.hxx>
37 #include <Sound/morse.hxx>
38
39
40 class FGRadioStack : public FGSubsystem
41 {
42     FGMorse morse;
43
44     SGInterpTable *term_tbl;
45     SGInterpTable *low_tbl;
46     SGInterpTable *high_tbl;
47
48     SGValue * latitudeVal;
49     SGValue * longitudeVal;
50     SGValue * altitudeVal;
51
52     bool need_update;
53
54     string nav1_ident;
55     string nav1_trans_ident;
56     bool nav1_valid;
57     bool nav1_inrange;
58     bool nav1_has_dme;
59     bool nav1_has_gs;
60     bool nav1_loc;
61     double nav1_freq;
62     double nav1_alt_freq;
63     double nav1_radial;
64     double nav1_sel_radial;
65     double nav1_loclon;
66     double nav1_loclat;
67     double nav1_x;
68     double nav1_y;
69     double nav1_z;
70     double nav1_loc_dist;
71     double nav1_gslon;
72     double nav1_gslat;
73     double nav1_gs_x;
74     double nav1_gs_y;
75     double nav1_gs_z;
76     double nav1_gs_dist;
77     double nav1_dmelon;
78     double nav1_dmelat;
79     double nav1_dme_x;
80     double nav1_dme_y;
81     double nav1_dme_z;
82     double nav1_dme_dist;
83     double nav1_elev;
84     double nav1_range;
85     double nav1_effective_range;
86     double nav1_heading;
87     double nav1_target_gs;
88     double nav1_magvar;
89     bool nav1_on_btn;
90     bool nav1_ident_btn;
91
92     string nav2_ident;
93     string nav2_trans_ident;
94     bool nav2_valid;
95     bool nav2_inrange;
96     bool nav2_has_dme;
97     bool nav2_has_gs;
98     bool nav2_loc;
99     double nav2_freq;
100     double nav2_alt_freq;
101     double nav2_radial;
102     double nav2_sel_radial;
103     double nav2_loclon;
104     double nav2_loclat;
105     double nav2_x;
106     double nav2_y;
107     double nav2_z;
108     double nav2_loc_dist;
109     double nav2_gslon;
110     double nav2_gslat;
111     double nav2_gs_x;
112     double nav2_gs_y;
113     double nav2_gs_z;
114     double nav2_gs_dist;
115     double nav2_dmelon;
116     double nav2_dmelat;
117     double nav2_dme_x;
118     double nav2_dme_y;
119     double nav2_dme_z;
120     double nav2_dme_dist;
121     double nav2_elev;
122     double nav2_range;
123     double nav2_effective_range;
124     double nav2_heading;
125     double nav2_target_gs;
126     double nav2_magvar;
127     bool nav2_on_btn;
128     bool nav2_ident_btn;
129
130     bool adf_valid;
131     bool adf_inrange;
132     double adf_freq;
133     double adf_alt_freq;
134     double adf_rotation;
135     double adf_lon;
136     double adf_lat;
137     double adf_elev;
138     double adf_range;
139     double adf_effective_range;
140     double adf_dist;
141     double adf_heading;
142     double adf_x;
143     double adf_y;
144     double adf_z;
145
146     // model standard VOR/DME/TACAN service volumes as per AIM 1-1-8
147     double adjustNavRange( double stationElev, double aircraftElev,
148                            double nominalRange );
149
150     // model standard ILS service volumes as per AIM 1-1-9
151     double adjustILSRange( double stationElev, double aircraftElev,
152                            double offsetDegrees, double distance );
153
154 public:
155
156     FGRadioStack();
157     ~FGRadioStack();
158
159     void init ();
160     void bind ();
161     void unbind ();
162     void update ();
163
164     // Update nav/adf radios based on current postition
165     void search ();
166
167     // NAV1 Setters
168     inline void set_nav1_freq( double freq ) {
169         nav1_freq = freq; need_update = true;
170     }
171     inline void set_nav1_alt_freq( double freq ) { nav1_alt_freq = freq; }
172     inline void set_nav1_sel_radial( double radial ) {
173         nav1_sel_radial = radial; need_update = true;
174     }
175     inline void set_nav1_on_btn( bool val ) { nav1_on_btn = val; }
176     inline void set_nav1_ident_btn( bool val ) { nav1_ident_btn = val; }
177
178     // NAV2 Setters
179     inline void set_nav2_freq( double freq ) {
180         nav2_freq = freq; need_update = true;
181     }
182     inline void set_nav2_alt_freq( double freq ) { nav2_alt_freq = freq; }
183     inline void set_nav2_sel_radial( double radial ) {
184         nav2_sel_radial = radial; need_update = true;
185     }
186     inline void set_nav2_on_btn( bool val ) { nav2_on_btn = val; }
187     inline void set_nav2_ident_btn( bool val ) { nav2_ident_btn = val; }
188
189     // ADF Setters
190     inline void set_adf_freq( double freq ) {
191         adf_freq = freq; need_update = true;
192     }
193     inline void set_adf_alt_freq( double freq ) { adf_alt_freq = freq; }
194     inline void set_adf_rotation( double rot ) { adf_rotation = rot; }
195
196
197     // NAV1 Accessors
198     inline double get_nav1_freq () const { return nav1_freq; }
199     inline double get_nav1_alt_freq () const { return nav1_alt_freq; }
200     inline double get_nav1_sel_radial() const { return nav1_sel_radial; }
201
202     // NAV2 Accessors
203     inline double get_nav2_freq () const { return nav2_freq; }
204     inline double get_nav2_alt_freq () const { return nav2_alt_freq; }
205     inline double get_nav2_sel_radial() const { return nav2_sel_radial; }
206
207     // ADF Accessors
208     inline double get_adf_freq () const { return adf_freq; }
209     inline double get_adf_alt_freq () const { return adf_alt_freq; }
210     inline double get_adf_rotation () const { return adf_rotation; }
211
212     // Calculated values.
213     inline bool get_nav1_inrange() const { return nav1_inrange; }
214     bool get_nav1_to_flag () const;
215     bool get_nav1_from_flag () const;
216     inline bool get_nav1_has_dme() const { return nav1_has_dme; }
217     inline bool get_nav1_dme_inrange () const {
218         return nav1_inrange && nav1_has_dme;
219     }
220     inline bool get_nav1_has_gs() const { return nav1_has_gs; }
221     inline bool get_nav1_loc() const { return nav1_loc; }
222     inline double get_nav1_loclon() const { return nav1_loclon; }
223     inline double get_nav1_loclat() const { return nav1_loclat; }
224     inline double get_nav1_loc_dist() const { return nav1_loc_dist; }
225     inline double get_nav1_gslon() const { return nav1_gslon; }
226     inline double get_nav1_gslat() const { return nav1_gslat; }
227     inline double get_nav1_gs_dist() const { return nav1_gs_dist; }
228     inline double get_nav1_dmelon() const { return nav1_dmelon; }
229     inline double get_nav1_dmelat() const { return nav1_dmelat; }
230     inline double get_nav1_dme_dist() const { return nav1_dme_dist; }
231     inline double get_nav1_elev() const { return nav1_elev; }
232     inline double get_nav1_heading() const { return nav1_heading; }
233     inline double get_nav1_radial() const { return nav1_radial; }
234     inline double get_nav1_target_gs() const { return nav1_target_gs; }
235     inline double get_nav1_magvar() const { return nav1_magvar; }
236     double get_nav1_heading_needle_deflection() const;
237     double get_nav1_gs_needle_deflection() const;
238     inline bool get_nav1_on_btn() const { return nav1_on_btn; }
239     inline bool get_nav1_ident_btn() const { return nav1_ident_btn; }
240
241     inline bool get_nav2_inrange() const { return nav2_inrange; }
242     bool get_nav2_to_flag () const;
243     bool get_nav2_from_flag () const;
244     inline bool get_nav2_has_dme() const { return nav2_has_dme; }
245     inline bool get_nav2_dme_inrange () const {
246         return nav2_inrange && nav2_has_dme;
247     }
248     inline bool get_nav2_has_gs() const { return nav2_has_gs; }
249     inline bool get_nav2_loc() const { return nav2_loc; }
250     inline double get_nav2_loclon() const { return nav2_loclon; }
251     inline double get_nav2_loclat() const { return nav2_loclat; }
252     inline double get_nav2_loc_dist() const { return nav2_loc_dist; }
253     inline double get_nav2_gslon() const { return nav2_gslon; }
254     inline double get_nav2_gslat() const { return nav2_gslat; }
255     inline double get_nav2_gs_dist() const { return nav2_gs_dist; }
256     inline double get_nav2_dmelon() const { return nav2_dmelon; }
257     inline double get_nav2_dmelat() const { return nav2_dmelat; }
258     inline double get_nav2_dme_dist() const { return nav2_dme_dist; }
259     inline double get_nav2_elev() const { return nav2_elev; }
260     inline double get_nav2_heading() const { return nav2_heading; }
261     inline double get_nav2_radial() const { return nav2_radial; }
262     inline double get_nav2_target_gs() const { return nav2_target_gs; }
263     inline double get_nav2_magvar() const { return nav2_magvar; }
264     double get_nav2_heading_needle_deflection() const;
265     double get_nav2_gs_needle_deflection() const;
266     inline bool get_nav2_on_btn() const { return nav2_on_btn; }
267     inline bool get_nav2_ident_btn() const { return nav2_ident_btn; }
268
269     inline bool get_adf_inrange() const { return adf_inrange; }
270     inline double get_adf_lon() const { return adf_lon; }
271     inline double get_adf_lat() const { return adf_lat; }
272     inline double get_adf_heading() const { return adf_heading; }
273 };
274
275
276 extern FGRadioStack *current_radiostack;
277
278 #endif // _FG_RADIOSTACK_HXX