#include <string.h>
#include <Aircraft/aircraft.hxx>
-#include <Debug/fg_debug.h>
+#include <Debug/logstream.hxx>
#include <Include/fg_constants.h>
#include <Include/general.h>
#include <Main/options.hxx>
double get_latitude( void )
{
- fgFLIGHT *f;
- f = current_aircraft.flight;
+ FGState *f;
+ f = current_aircraft.fdm_state;
// return( toDM(FG_Latitude * RAD_TO_DEG) );
- return((double)((int)( FG_Latitude * RAD_TO_DEG)) );
+ return((double)((int)( f->get_Latitude() * RAD_TO_DEG)) );
}
+
double get_lat_min( void )
{
- fgFLIGHT *f;
+ FGState *f;
double a, d;
- f = current_aircraft.flight;
+ f = current_aircraft.fdm_state;
- a = FG_Latitude * RAD_TO_DEG;
+ a = f->get_Latitude() * RAD_TO_DEG;
if (a < 0.0) {
a = -a;
}
double get_longitude( void )
{
- fgFLIGHT *f;
- f = current_aircraft.flight;
+ FGState *f;
+ f = current_aircraft.fdm_state;
// return( toDM(FG_Longitude * RAD_TO_DEG) );
- return((double)((int) (FG_Longitude * RAD_TO_DEG)) );
+ return((double)((int) (f->get_Longitude() * RAD_TO_DEG)) );
}
double get_long_min( void )
{
- fgFLIGHT *f;
+ FGState *f;
double a, d;
- f = current_aircraft.flight;
+ f = current_aircraft.fdm_state;
- a = FG_Longitude * RAD_TO_DEG;
+ a = f->get_Longitude() * RAD_TO_DEG;
if (a < 0.0) {
a = -a;
}
double get_throttleval( void )
{
- fgCONTROLS *pcontrols;
-
- pcontrols = current_aircraft.controls;
- return pcontrols->throttle[0]; // Hack limiting to one engine
+ return controls.get_throttle( 0 ); // Hack limiting to one engine
}
double get_aileronval( void )
{
- fgCONTROLS *pcontrols;
-
- pcontrols = current_aircraft.controls;
- return pcontrols->aileron;
+ return controls.get_aileron();
}
double get_elevatorval( void )
{
- fgCONTROLS *pcontrols;
-
- pcontrols = current_aircraft.controls;
- return pcontrols->elevator;
+ return controls.get_elevator();
}
double get_elev_trimval( void )
{
- fgCONTROLS *pcontrols;
-
- pcontrols = current_aircraft.controls;
- return pcontrols->elevator_trim;
+ return controls.get_elevator_trim();
}
double get_rudderval( void )
{
- fgCONTROLS *pcontrols;
-
- pcontrols = current_aircraft.controls;
- return pcontrols->rudder;
+ return controls.get_rudder();
}
double get_speed( void )
{
- fgFLIGHT *f;
+ FGState *f;
- f = current_aircraft.flight;
- return( FG_V_equiv_kts ); // Make an explicit function call.
+ f = current_aircraft.fdm_state;
+ return( f->get_V_equiv_kts() ); // Make an explicit function call.
}
double get_aoa( void )
{
- fgFLIGHT *f;
+ FGState *f;
- f = current_aircraft.flight;
- return( FG_Gamma_vert_rad * RAD_TO_DEG );
+ f = current_aircraft.fdm_state;
+ return( f->get_Gamma_vert_rad() * RAD_TO_DEG );
}
double get_roll( void )
{
- fgFLIGHT *f;
+ FGState *f;
- f = current_aircraft.flight;
- return( FG_Phi );
+ f = current_aircraft.fdm_state;
+ return( f->get_Phi() );
}
double get_pitch( void )
{
- fgFLIGHT *f;
+ FGState *f;
- f = current_aircraft.flight;
- return( FG_Theta );
+ f = current_aircraft.fdm_state;
+ return( f->get_Theta() );
}
double get_heading( void )
{
- fgFLIGHT *f;
+ FGState *f;
- f = current_aircraft.flight;
- return( FG_Psi * RAD_TO_DEG );
+ f = current_aircraft.fdm_state;
+ return( f->get_Psi() * RAD_TO_DEG );
}
double get_altitude( void )
{
- fgFLIGHT *f;
+ FGState *f;
// double rough_elev;
- f = current_aircraft.flight;
- // rough_elev = mesh_altitude(FG_Longitude * RAD_TO_ARCSEC,
- // FG_Latitude * RAD_TO_ARCSEC);
+ f = current_aircraft.fdm_state;
+ // rough_elev = mesh_altitude(f->get_Longitude() * RAD_TO_ARCSEC,
+ // f->get_Latitude() * RAD_TO_ARCSEC);
- return( FG_Altitude * FEET_TO_METER /* -rough_elev */ );
+ if ( current_options.get_units() == fgOPTIONS::FG_UNITS_FEET ) {
+ return f->get_Altitude();
+ } else {
+ return f->get_Altitude() * FEET_TO_METER;
+ }
}
double get_agl( void )
{
- fgFLIGHT *f;
- double agl;
+ FGState *f;
- f = current_aircraft.flight;
- agl = FG_Altitude * FEET_TO_METER - scenery.cur_elev;
+ f = current_aircraft.fdm_state;
- return( agl );
+ if ( current_options.get_units() == fgOPTIONS::FG_UNITS_FEET ) {
+ return f->get_Altitude() - scenery.cur_elev * METER_TO_FEET;
+ } else {
+ return f->get_Altitude() * FEET_TO_METER - scenery.cur_elev;
+ }
}
double get_sideslip( void )
{
- fgFLIGHT *f;
+ FGState *f;
- f = current_aircraft.flight;
+ f = current_aircraft.fdm_state;
- return( FG_Beta );
+ return( f->get_Beta() );
}
double get_frame_rate( void )
double get_climb_rate( void )
{
- fgFLIGHT *f;
+ FGState *f;
- f = current_aircraft.flight;
+ f = current_aircraft.fdm_state;
- return( FG_Climb_Rate * FEET_TO_METER * 60.0 );
+ if ( current_options.get_units() == fgOPTIONS::FG_UNITS_FEET ) {
+ return f->get_Climb_Rate() * 60.0;
+ } else {
+ return f->get_Climb_Rate() * FEET_TO_METER * 60.0;
+ }
}
bool fgCockpitInit( fgAIRCRAFT *cur_aircraft )
{
- fgPrintf( FG_COCKPIT, FG_INFO, "Initializing cockpit subsystem\n");
+ FG_LOG( FG_COCKPIT, FG_INFO, "Initializing cockpit subsystem" );
// cockpit->code = 1; /* It will be aircraft dependent */
// cockpit->status = 0;
fgPanelInit();
}
- fgPrintf( FG_COCKPIT, FG_INFO,
- " Code %d Status %d\n",
- ac_cockpit->code(), ac_cockpit->status() );
+ FG_LOG( FG_COCKPIT, FG_INFO,
+ " Code " << ac_cockpit->code() << " Status "
+ << ac_cockpit->status() );
return true;
}
pview = ¤t_view;
- fgPrintf( FG_COCKPIT, FG_DEBUG,
- "Cockpit: code %d status %d\n",
- ac_cockpit->code(), ac_cockpit->status() );
+ FG_LOG( FG_COCKPIT, FG_DEBUG,
+ "Cockpit: code " << ac_cockpit->code() << " status "
+ << ac_cockpit->status() );
if ( current_options.get_hud_status() ) {
// This will check the global hud linked list pointer.
if ( current_options.get_panel_status() &&
(fabs(pview->view_offset) < 0.2) ) {
+ xglViewport(0, 0, pview->winWidth, pview->winHeight);
fgPanelUpdate();
}
}
// $Log$
+// Revision 1.25 1998/12/05 15:54:07 curt
+// Renamed class fgFLIGHT to class FGState as per request by JSB.
+//
+// Revision 1.24 1998/12/03 01:16:00 curt
+// Converted fgFLIGHT to a class.
+//
+// Revision 1.23 1998/11/09 23:38:50 curt
+// Panel updates from Friedemann.
+//
+// Revision 1.22 1998/11/06 21:17:45 curt
+// Converted to new logstream debugging facility. This allows release
+// builds with no messages at all (and no performance impact) by using
+// the -DFG_NDEBUG flag.
+//
+// Revision 1.21 1998/11/02 23:04:02 curt
+// HUD units now display in feet by default with meters being a command line
+// option.
+//
+// Revision 1.20 1998/10/25 14:08:40 curt
+// Turned "struct fgCONTROLS" into a class, with inlined accessor functions.
+//
// Revision 1.19 1998/10/17 01:33:56 curt
// C++ ifying ...
//