2001-07-02 22:14:09 +00:00
|
|
|
// fg_init.cxx -- Flight Gear top level initialization routines
|
1998-04-25 15:11:10 +00:00
|
|
|
//
|
|
|
|
// Written by Curtis Olson, started August 1997.
|
|
|
|
//
|
|
|
|
// Copyright (C) 1997 Curtis L. Olson - curt@infoplane.com
|
|
|
|
//
|
|
|
|
// This program is free software; you can redistribute it and/or
|
|
|
|
// modify it under the terms of the GNU General Public License as
|
|
|
|
// published by the Free Software Foundation; either version 2 of the
|
|
|
|
// License, or (at your option) any later version.
|
|
|
|
//
|
|
|
|
// This program is distributed in the hope that it will be useful, but
|
|
|
|
// WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
|
|
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
|
|
|
|
// General Public License for more details.
|
|
|
|
//
|
|
|
|
// You should have received a copy of the GNU General Public License
|
|
|
|
// along with this program; if not, write to the Free Software
|
|
|
|
// Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
|
|
|
|
//
|
|
|
|
//
|
|
|
|
// $Id$
|
1997-08-23 01:46:20 +00:00
|
|
|
|
|
|
|
|
1998-04-24 00:49:17 +00:00
|
|
|
#ifdef HAVE_CONFIG_H
|
|
|
|
# include <config.h>
|
|
|
|
#endif
|
1998-04-22 13:25:39 +00:00
|
|
|
|
1999-05-08 02:33:13 +00:00
|
|
|
// For BC 5.01 this must be included before OpenGL includes.
|
2001-03-23 22:42:49 +00:00
|
|
|
#ifdef SG_MATH_EXCEPTION_CLASH
|
1999-05-08 02:33:13 +00:00
|
|
|
# include <math.h>
|
|
|
|
#endif
|
|
|
|
|
2001-04-22 17:00:08 +00:00
|
|
|
#ifdef HAVE_WINDOWS_H
|
|
|
|
# include <windows.h>
|
|
|
|
#endif
|
|
|
|
|
1999-03-11 23:09:26 +00:00
|
|
|
#include <GL/glut.h>
|
|
|
|
|
1997-08-23 01:46:20 +00:00
|
|
|
#include <stdio.h>
|
|
|
|
#include <stdlib.h>
|
2002-03-20 22:15:22 +00:00
|
|
|
#include <string.h> // strcmp()
|
1998-07-22 21:40:43 +00:00
|
|
|
|
2001-03-22 04:02:11 +00:00
|
|
|
|
|
|
|
#if defined( unix ) || defined( __CYGWIN__ )
|
|
|
|
# include <unistd.h> // for gethostname()
|
|
|
|
#endif
|
|
|
|
|
1998-07-22 21:40:43 +00:00
|
|
|
// work around a stdc++ lib bug in some versions of linux, but doesn't
|
|
|
|
// seem to hurt to have this here for all versions of Linux.
|
|
|
|
#ifdef linux
|
|
|
|
# define _G_NO_EXTERN_TEMPLATES
|
|
|
|
#endif
|
|
|
|
|
2000-02-15 03:30:01 +00:00
|
|
|
#include <simgear/compiler.h>
|
2001-07-19 04:53:13 +00:00
|
|
|
#include <simgear/misc/exception.hxx>
|
1999-02-26 22:08:34 +00:00
|
|
|
|
|
|
|
#include STL_STRING
|
1997-08-23 01:46:20 +00:00
|
|
|
|
2000-02-15 03:30:01 +00:00
|
|
|
#include <simgear/constants.h>
|
2000-02-16 23:01:03 +00:00
|
|
|
#include <simgear/debug/logstream.hxx>
|
|
|
|
#include <simgear/math/point3d.hxx>
|
|
|
|
#include <simgear/math/polar3d.hxx>
|
2000-09-27 20:16:22 +00:00
|
|
|
#include <simgear/math/sg_geodesy.hxx>
|
2001-03-25 14:20:12 +00:00
|
|
|
#include <simgear/misc/sg_path.hxx>
|
2000-07-06 22:13:24 +00:00
|
|
|
#include <simgear/timing/sg_time.hxx>
|
2002-02-06 23:31:33 +00:00
|
|
|
#include <simgear/timing/lowleveltime.h>
|
2000-02-15 03:30:01 +00:00
|
|
|
|
1998-10-17 01:33:52 +00:00
|
|
|
#include <Aircraft/aircraft.hxx>
|
2001-03-06 19:11:28 +00:00
|
|
|
#include <FDM/UIUCModel/uiuc_aircraftdir.h>
|
2000-08-16 00:09:03 +00:00
|
|
|
#include <Airports/runways.hxx>
|
1998-08-25 16:59:08 +00:00
|
|
|
#include <Airports/simple.hxx>
|
2001-11-07 17:55:28 +00:00
|
|
|
#include <ATC/ATCdisplay.hxx>
|
2002-03-01 17:39:52 +00:00
|
|
|
#include <ATC/ATCmgr.hxx>
|
|
|
|
#include <ATC/atislist.hxx>
|
2002-04-03 23:54:44 +00:00
|
|
|
#include <ATC/towerlist.hxx>
|
|
|
|
#include <ATC/approachlist.hxx>
|
|
|
|
#include <ATC/AIMgr.hxx>
|
2000-04-30 06:51:49 +00:00
|
|
|
#include <Autopilot/auto_gui.hxx>
|
|
|
|
#include <Autopilot/newauto.hxx>
|
1998-04-24 00:49:17 +00:00
|
|
|
#include <Cockpit/cockpit.hxx>
|
2000-04-25 03:09:26 +00:00
|
|
|
#include <Cockpit/radiostack.hxx>
|
User-visible
- knobs now continue to rotate when you hold down the mouse
- the middle mouse button makes knobs rotate much faster
- there are NAV1, NAV2, and ADF radios that can be tuned using the mouse
- there are standby frequencies for NAV1 and NAV2, and buttons to swap
- there is a crude, rather silly-looking DME, hard-wired to NAV1
- there is a crude, rather silly-looking autopilot that can lock
the heading (to the bug on the gyro), can lock to NAV1, and can lock
the current altitude
- the knobs for changing the radials on NAV1 and NAV2 look much better
and are in the right place
- tuning into an ILS frequency doesn't change the displayed radial for
NAV1
Code
- I've created a new module, sp_panel.[ch]xx, that constructs the
default single-prop panel; this works entirely outside of FGPanel,
so it is possible to construct similar modules for other sorts of
panels; all code specific to the default panel has been removed from
panel.cxx
- current_panel is now a pointer
- radiostack.[ch]xx keeps track both of the actual radial and of the
selected radial (they will differ with ILS); the NAV gauges should
not spin around automatically to show the actual radial (we need to
do something similar with the autopilot)
- the panel is initialized fairly early
- make sure that standby frequencies also get initialized
- I've started combining and clipping small textures to save texture
memory; there's a lot more to do, but at least I've made a start
2000-05-02 18:26:00 +00:00
|
|
|
#include <Cockpit/panel.hxx>
|
2000-09-22 17:20:56 +00:00
|
|
|
#include <Cockpit/panel_io.hxx>
|
The following changes were made to flightgear-0.7.5 code to implement the follow
ing features:
a) ADA Flight model - ADA.cxx, ADA.hxx, flight.hxx
b) Fighter a/c HUD - flight.hxx, hud.hxx, hud.cxx, cockpit.cxx, hud_ladr.c
xx, hud_card.cxx
c) 3-window display - options.hxx, options.cxx, viewer.cxx
d) Moving objects (ship) - main.cxx
e) Patches - main.cxx
ADA.cxx, ADA.hxx
--------------------------
Interface to the external ADA flight dynamics package.
flight.hxx
----------
Included prototypes for accepting additional data fron the External flight
model for fighter aircraft HUD
Hud.hxx
-------
Included prototypes for accepting additional data for fighter HUD from Exernal F
light model.
Defined FIGHTER_HUD pre-processor directive to enable compilation of fighter hud
code.
hud.cxx, cockpit.cxx, hud_ladr.cxx, hud_card.cxx
---------------------------------------
Included code to initialise additional reticles/text for fighter HUD which is co
nditionally
compiled if FIGHTER_HUD is defined.
options.hxx
-----------
Added window_offset, and function to retrieve its value for 3 windows
options.cxx
-----------
Changed few options to suit ADA/CEF projection system/screens and checks for win
dow offset.
views.cxx
---------
Added code to retrieve view offset for window.
Main.cxx
--------
Added code to load and move an aircraft carrier.
Patch to enable clouds from command line until Curtis fixes it. By default cloud
s are disabled.
2000-10-19 19:46:13 +00:00
|
|
|
#include <FDM/ADA.hxx>
|
1999-10-15 22:21:09 +00:00
|
|
|
#include <FDM/Balloon.h>
|
1999-11-19 02:10:24 +00:00
|
|
|
#include <FDM/External.hxx>
|
2002-03-13 06:07:07 +00:00
|
|
|
#include <FDM/ExternalNet.hxx>
|
2002-02-25 03:22:03 +00:00
|
|
|
#include <FDM/JSBSim/JSBSim.hxx>
|
1999-10-14 01:53:43 +00:00
|
|
|
#include <FDM/LaRCsim.hxx>
|
|
|
|
#include <FDM/MagicCarpet.hxx>
|
2001-11-12 04:49:06 +00:00
|
|
|
#include <FDM/NullFDM.hxx>
|
2001-12-01 06:22:49 +00:00
|
|
|
#include <FDM/YASim/YASim.hxx>
|
1999-03-11 23:09:26 +00:00
|
|
|
#include <Include/general.hxx>
|
I'm attaching diffs to add a new FGInput module to FlightGear
(src/Input). So far, FGInput replaces most of src/Main/keyboard.cxx
(I've left a tiny stub); in the very near future, it will also take
over control of the joystick, mouse (Norm permitting), and panel
instrument interactions, so that there is a single mechanism for
configuring all input devices.
The new format should be (close to) self-explanatory by looking at the
new base-package file keyboard.xml, which is now included by
preferences.xml (I'll do the same thing for the joystick when I have a
chance). I have not managed to move all keybindings into this file
yet, but I've made a good start. I'm including Tony in the recipient
list so that he can see how bindings can use an external XML file.
This patch also adds support for multiple bindings for a single key,
special keys (i.e. keypad and function keys), and key modifiers
(shift/alt/ctrl); special keys use the PUI convention of adding 256 to
the Glut key code.
Unfortunately, everything comes with a price; in this case, I have not
yet found a general mechanism for the old (hard-coded) modal bindings,
which behaved differently depending on the autopilot state (i.e. left
rudder or move AP heading left); with my patches, this functionality
disappears, but you can still adjust the autopilot using the panel or
the GUI input dialogs.
2001-05-23 23:01:15 +00:00
|
|
|
#include <Input/input.hxx>
|
2001-06-04 21:07:27 +00:00
|
|
|
// #include <Joystick/joystick.hxx>
|
2000-06-23 00:30:04 +00:00
|
|
|
#include <Objects/matlib.hxx>
|
2002-04-09 18:58:24 +00:00
|
|
|
#include <Model/acmodel.hxx>
|
2000-04-24 23:51:26 +00:00
|
|
|
#include <Navaids/fixlist.hxx>
|
|
|
|
#include <Navaids/ilslist.hxx>
|
2001-03-16 23:59:02 +00:00
|
|
|
#include <Navaids/mkrbeacons.hxx>
|
2000-04-24 23:51:26 +00:00
|
|
|
#include <Navaids/navlist.hxx>
|
1998-04-30 12:34:17 +00:00
|
|
|
#include <Scenery/scenery.hxx>
|
1998-04-22 13:25:39 +00:00
|
|
|
#include <Scenery/tilemgr.hxx>
|
2001-10-29 04:39:05 +00:00
|
|
|
#include <Sound/fg_fx.hxx>
|
|
|
|
#include <Sound/soundmgr.hxx>
|
2002-04-05 20:03:49 +00:00
|
|
|
#include <Time/FGEventMgr.hxx>
|
|
|
|
#include <boost/bind.hpp>
|
1998-04-22 13:25:39 +00:00
|
|
|
#include <Time/light.hxx>
|
|
|
|
#include <Time/sunpos.hxx>
|
1999-03-22 02:08:05 +00:00
|
|
|
#include <Time/moonpos.hxx>
|
2000-07-05 02:39:30 +00:00
|
|
|
#include <Time/tmp.hxx>
|
1999-08-12 17:13:44 +00:00
|
|
|
|
2002-02-19 15:16:08 +00:00
|
|
|
#ifndef FG_NEW_ENVIRONMENT
|
1999-08-12 17:13:44 +00:00
|
|
|
# include <WeatherCM/FGLocalWeatherDatabase.h>
|
|
|
|
#else
|
2002-02-22 23:37:45 +00:00
|
|
|
# include <Environment/environment_mgr.hxx>
|
1999-08-12 17:13:44 +00:00
|
|
|
#endif
|
1997-08-23 01:46:20 +00:00
|
|
|
|
1998-04-22 13:25:39 +00:00
|
|
|
#include "fg_init.hxx"
|
1999-11-19 02:10:24 +00:00
|
|
|
#include "fg_io.hxx"
|
2001-06-01 17:52:28 +00:00
|
|
|
#include "fg_commands.hxx"
|
2001-06-05 22:12:08 +00:00
|
|
|
#include "fg_props.hxx"
|
2001-01-13 22:06:39 +00:00
|
|
|
#include "options.hxx"
|
2000-07-08 06:29:19 +00:00
|
|
|
#include "globals.hxx"
|
2002-03-12 16:29:00 +00:00
|
|
|
#include "logger.hxx"
|
2001-07-22 19:51:16 +00:00
|
|
|
#include "viewmgr.hxx"
|
1998-04-22 13:25:39 +00:00
|
|
|
|
1999-03-11 23:09:26 +00:00
|
|
|
#if defined(FX) && defined(XMESA)
|
|
|
|
#include <GL/xmesa.h>
|
|
|
|
#endif
|
|
|
|
|
2001-03-23 22:59:18 +00:00
|
|
|
SG_USING_STD(string);
|
1998-06-27 16:54:32 +00:00
|
|
|
|
1998-02-12 21:58:27 +00:00
|
|
|
extern const char *default_root;
|
1997-08-25 20:27:21 +00:00
|
|
|
|
1997-08-23 01:46:20 +00:00
|
|
|
|
2000-10-04 22:52:34 +00:00
|
|
|
// Read in configuration (file and command line) and just set fg_root
|
|
|
|
bool fgInitFGRoot ( int argc, char **argv ) {
|
2001-01-13 22:06:39 +00:00
|
|
|
string root;
|
|
|
|
char* envp;
|
|
|
|
|
|
|
|
// First parse command line options looking for fg-root, this will
|
|
|
|
// override anything specified in a config file
|
|
|
|
root = fgScanForRoot(argc, argv);
|
|
|
|
|
2001-03-22 04:02:11 +00:00
|
|
|
#if defined( unix ) || defined( __CYGWIN__ )
|
|
|
|
// Next check home directory for .fgfsrc.hostname file
|
2002-03-20 19:16:13 +00:00
|
|
|
if ( root.empty() ) {
|
2001-03-22 04:02:11 +00:00
|
|
|
envp = ::getenv( "HOME" );
|
|
|
|
if ( envp != NULL ) {
|
2001-03-25 14:20:12 +00:00
|
|
|
SGPath config( envp );
|
2001-03-22 04:02:11 +00:00
|
|
|
config.append( ".fgfsrc" );
|
|
|
|
char name[256];
|
|
|
|
gethostname( name, 256 );
|
|
|
|
config.concat( "." );
|
|
|
|
config.concat( name );
|
|
|
|
root = fgScanForRoot(config.str());
|
|
|
|
}
|
|
|
|
}
|
|
|
|
#endif
|
|
|
|
|
2001-01-13 22:06:39 +00:00
|
|
|
// Next check home directory for .fgfsrc file
|
2002-03-20 19:16:13 +00:00
|
|
|
if ( root.empty() ) {
|
2001-01-13 22:06:39 +00:00
|
|
|
envp = ::getenv( "HOME" );
|
|
|
|
if ( envp != NULL ) {
|
2001-03-25 14:20:12 +00:00
|
|
|
SGPath config( envp );
|
2001-01-13 22:06:39 +00:00
|
|
|
config.append( ".fgfsrc" );
|
|
|
|
root = fgScanForRoot(config.str());
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
// Next check if fg-root is set as an env variable
|
2002-03-20 19:16:13 +00:00
|
|
|
if ( root.empty() ) {
|
2001-01-13 22:06:39 +00:00
|
|
|
envp = ::getenv( "FG_ROOT" );
|
|
|
|
if ( envp != NULL ) {
|
|
|
|
root = envp;
|
|
|
|
}
|
|
|
|
}
|
2000-10-04 22:52:34 +00:00
|
|
|
|
2001-01-13 22:06:39 +00:00
|
|
|
// Otherwise, default to a random compiled-in location if we can't
|
|
|
|
// find fg-root any other way.
|
2002-03-20 19:16:13 +00:00
|
|
|
if ( root.empty() ) {
|
2001-04-05 20:25:40 +00:00
|
|
|
#if defined( __CYGWIN__ )
|
|
|
|
root = "/FlightGear";
|
|
|
|
#elif defined( WIN32 )
|
2001-01-13 22:06:39 +00:00
|
|
|
root = "\\FlightGear";
|
|
|
|
#elif defined( macintosh )
|
|
|
|
root = "";
|
|
|
|
#else
|
|
|
|
root = PKGLIBDIR;
|
|
|
|
#endif
|
2000-10-04 22:52:34 +00:00
|
|
|
}
|
|
|
|
|
2001-03-24 06:03:11 +00:00
|
|
|
SG_LOG(SG_INPUT, SG_INFO, "fg_root = " << root );
|
2001-01-13 22:06:39 +00:00
|
|
|
globals->set_fg_root(root);
|
2000-10-04 22:52:34 +00:00
|
|
|
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
|
|
|
|
|
2001-07-16 19:17:58 +00:00
|
|
|
// Return the current base package version
|
|
|
|
string fgBasePackageVersion() {
|
|
|
|
SGPath base_path( globals->get_fg_root() );
|
|
|
|
base_path.append("version");
|
|
|
|
|
|
|
|
sg_gzifstream in( base_path.str() );
|
|
|
|
if ( !in.is_open() ) {
|
|
|
|
SGPath old_path( globals->get_fg_root() );
|
|
|
|
old_path.append( "Thanks" );
|
|
|
|
sg_gzifstream old( old_path.str() );
|
|
|
|
if ( !old.is_open() ) {
|
2001-07-16 19:37:13 +00:00
|
|
|
return "[none]";
|
2001-07-16 19:17:58 +00:00
|
|
|
} else {
|
2001-07-16 19:37:13 +00:00
|
|
|
return "[old version]";
|
2001-07-16 19:17:58 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
string version;
|
|
|
|
in >> version;
|
|
|
|
|
|
|
|
return version;
|
|
|
|
}
|
|
|
|
|
|
|
|
|
1999-06-18 03:42:54 +00:00
|
|
|
// Read in configuration (file and command line)
|
|
|
|
bool fgInitConfig ( int argc, char **argv ) {
|
2001-01-12 15:37:40 +00:00
|
|
|
|
|
|
|
// First, set some sane default values
|
2001-01-13 22:06:39 +00:00
|
|
|
fgSetDefaults();
|
2001-01-12 15:37:40 +00:00
|
|
|
|
|
|
|
// Read global preferences from $FG_ROOT/preferences.xml
|
2001-03-25 14:20:12 +00:00
|
|
|
SGPath props_path(globals->get_fg_root());
|
2001-01-12 15:37:40 +00:00
|
|
|
props_path.append("preferences.xml");
|
2001-03-24 06:03:11 +00:00
|
|
|
SG_LOG(SG_INPUT, SG_INFO, "Reading global preferences");
|
2002-04-04 17:51:40 +00:00
|
|
|
readProperties(props_path.str(), globals->get_props());
|
2001-07-19 04:53:13 +00:00
|
|
|
SG_LOG(SG_INPUT, SG_INFO, "Finished Reading global preferences");
|
2001-01-12 15:37:40 +00:00
|
|
|
|
2001-12-11 19:27:37 +00:00
|
|
|
// Read the default aircraft config file.
|
|
|
|
string aircraft = fgGetString("/sim/aircraft", "");
|
|
|
|
if (aircraft.size() > 0) {
|
|
|
|
SGPath aircraft_path(globals->get_fg_root());
|
|
|
|
aircraft_path.append("Aircraft");
|
|
|
|
aircraft_path.append(aircraft);
|
|
|
|
aircraft_path.concat("-set.xml");
|
2001-12-12 03:46:37 +00:00
|
|
|
SG_LOG(SG_INPUT, SG_INFO, "Reading default aircraft: " << aircraft
|
2002-03-03 00:38:56 +00:00
|
|
|
<< " from " << aircraft_path.str());
|
2001-12-11 19:27:37 +00:00
|
|
|
try {
|
2001-12-12 03:46:37 +00:00
|
|
|
readProperties(aircraft_path.str(), globals->get_props());
|
2001-12-11 19:27:37 +00:00
|
|
|
} catch (const sg_exception &e) {
|
|
|
|
string message = "Error reading default aircraft: ";
|
|
|
|
message += e.getFormattedMessage();
|
|
|
|
SG_LOG(SG_INPUT, SG_ALERT, message);
|
|
|
|
exit(2);
|
|
|
|
}
|
|
|
|
} else {
|
|
|
|
SG_LOG(SG_INPUT, SG_ALERT, "No default aircraft specified");
|
|
|
|
}
|
|
|
|
|
2001-03-22 04:02:11 +00:00
|
|
|
// Attempt to locate and parse the various config files in order
|
|
|
|
// from least precidence to greatest precidence
|
|
|
|
|
|
|
|
// Check for $fg_root/system.fgfsrc
|
2001-03-25 14:20:12 +00:00
|
|
|
SGPath config( globals->get_fg_root() );
|
1999-06-18 03:42:54 +00:00
|
|
|
config.append( "system.fgfsrc" );
|
2001-01-13 22:06:39 +00:00
|
|
|
fgParseOptions(config.str());
|
1999-06-18 03:42:54 +00:00
|
|
|
|
2001-03-22 04:02:11 +00:00
|
|
|
char name[256];
|
|
|
|
#if defined( unix ) || defined( __CYGWIN__ )
|
|
|
|
// Check for $fg_root/system.fgfsrc.hostname
|
|
|
|
gethostname( name, 256 );
|
|
|
|
config.concat( "." );
|
|
|
|
config.concat( name );
|
|
|
|
fgParseOptions(config.str());
|
|
|
|
#endif
|
|
|
|
|
|
|
|
// Check for ~/.fgfsrc
|
1999-06-18 03:42:54 +00:00
|
|
|
char* envp = ::getenv( "HOME" );
|
|
|
|
if ( envp != NULL ) {
|
|
|
|
config.set( envp );
|
|
|
|
config.append( ".fgfsrc" );
|
2001-01-13 22:06:39 +00:00
|
|
|
fgParseOptions(config.str());
|
1999-06-18 03:42:54 +00:00
|
|
|
}
|
|
|
|
|
2001-03-22 04:02:11 +00:00
|
|
|
#if defined( unix ) || defined( __CYGWIN__ )
|
|
|
|
// Check for ~/.fgfsrc.hostname
|
|
|
|
gethostname( name, 256 );
|
|
|
|
config.concat( "." );
|
|
|
|
config.concat( name );
|
|
|
|
fgParseOptions(config.str());
|
|
|
|
#endif
|
|
|
|
|
1999-06-18 03:42:54 +00:00
|
|
|
// Parse remaining command line options
|
|
|
|
// These will override anything specified in a config file
|
2002-01-04 20:58:48 +00:00
|
|
|
fgParseArgs(argc, argv);
|
1999-06-18 03:42:54 +00:00
|
|
|
|
2000-10-04 22:52:34 +00:00
|
|
|
return true;
|
1999-06-18 03:42:54 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
|
2000-10-12 01:08:09 +00:00
|
|
|
// find basic airport location info from airport database
|
|
|
|
bool fgFindAirportID( const string& id, FGAirport *a ) {
|
1998-08-27 17:01:55 +00:00
|
|
|
if ( id.length() ) {
|
2001-03-25 14:20:12 +00:00
|
|
|
SGPath path( globals->get_fg_root() );
|
2000-03-29 20:21:31 +00:00
|
|
|
path.append( "Airports" );
|
2000-05-27 05:54:02 +00:00
|
|
|
path.append( "simple.mk4" );
|
2000-03-29 20:21:31 +00:00
|
|
|
FGAirports airports( path.c_str() );
|
1998-04-25 15:11:10 +00:00
|
|
|
|
2001-03-24 06:03:11 +00:00
|
|
|
SG_LOG( SG_GENERAL, SG_INFO, "Searching for airport code = " << id );
|
2000-03-29 20:21:31 +00:00
|
|
|
|
2000-10-12 01:08:09 +00:00
|
|
|
if ( ! airports.search( id, a ) ) {
|
2001-03-24 06:03:11 +00:00
|
|
|
SG_LOG( SG_GENERAL, SG_ALERT,
|
2000-10-12 01:08:09 +00:00
|
|
|
"Failed to find " << id << " in " << path.str() );
|
2000-07-21 22:54:14 +00:00
|
|
|
return false;
|
1998-05-06 03:16:23 +00:00
|
|
|
}
|
1998-07-30 23:48:24 +00:00
|
|
|
} else {
|
2000-07-21 22:54:14 +00:00
|
|
|
return false;
|
|
|
|
}
|
|
|
|
|
2001-03-24 06:03:11 +00:00
|
|
|
SG_LOG( SG_GENERAL, SG_INFO,
|
2000-07-21 22:54:14 +00:00
|
|
|
"Position for " << id << " is ("
|
2000-10-12 01:08:09 +00:00
|
|
|
<< a->longitude << ", "
|
|
|
|
<< a->latitude << ")" );
|
1998-07-30 23:48:24 +00:00
|
|
|
|
2000-07-21 22:54:14 +00:00
|
|
|
return true;
|
|
|
|
}
|
|
|
|
|
2000-08-16 00:09:03 +00:00
|
|
|
|
2000-10-12 01:08:09 +00:00
|
|
|
// Set current_options lon/lat given an airport id
|
|
|
|
bool fgSetPosFromAirportID( const string& id ) {
|
|
|
|
FGAirport a;
|
2000-10-25 15:27:55 +00:00
|
|
|
// double lon, lat;
|
2000-10-12 01:08:09 +00:00
|
|
|
|
2001-03-24 06:03:11 +00:00
|
|
|
SG_LOG( SG_GENERAL, SG_INFO,
|
2000-10-12 01:08:09 +00:00
|
|
|
"Attempting to set starting position from airport code " << id );
|
|
|
|
|
|
|
|
if ( fgFindAirportID( id, &a ) ) {
|
2001-07-02 22:27:24 +00:00
|
|
|
fgSetDouble("/position/longitude-deg", a.longitude );
|
|
|
|
fgSetDouble("/position/latitude-deg", a.latitude );
|
2001-03-24 06:03:11 +00:00
|
|
|
SG_LOG( SG_GENERAL, SG_INFO,
|
2000-10-12 01:08:09 +00:00
|
|
|
"Position for " << id << " is ("
|
|
|
|
<< a.longitude << ", "
|
|
|
|
<< a.latitude << ")" );
|
|
|
|
|
|
|
|
return true;
|
|
|
|
} else {
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
2002-04-06 17:23:18 +00:00
|
|
|
|
|
|
|
// Set current tower position lon/lat given an airport id
|
|
|
|
bool fgSetTowerPosFromAirportID( const string& id, double hdg ) {
|
|
|
|
FGAirport a;
|
|
|
|
// tower height hard coded for now...
|
|
|
|
float towerheight=50.0f;
|
|
|
|
|
|
|
|
// make a little off the heading for 1 runway airports...
|
|
|
|
float fudge_lon = fabs(sin(hdg)) * .003f;
|
|
|
|
float fudge_lat = .003f - fudge_lon;
|
|
|
|
|
|
|
|
if ( fgFindAirportID( id, &a ) ) {
|
|
|
|
fgSetDouble("/sim/tower/longitude-deg", a.longitude + fudge_lon);
|
|
|
|
fgSetDouble("/sim/tower/latitude-deg", a.latitude + fudge_lat);
|
|
|
|
fgSetDouble("/sim/tower/altitude-ft", a.elevation + towerheight);
|
|
|
|
return true;
|
|
|
|
} else {
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
2000-08-16 00:09:03 +00:00
|
|
|
// Set current_options lon/lat given an airport id and heading (degrees)
|
|
|
|
bool fgSetPosFromAirportIDandHdg( const string& id, double tgt_hdg ) {
|
|
|
|
FGRunway r;
|
|
|
|
FGRunway found_r;
|
2000-11-01 23:27:32 +00:00
|
|
|
double found_dir = 0.0;
|
2000-08-16 00:09:03 +00:00
|
|
|
|
|
|
|
if ( id.length() ) {
|
2002-02-05 20:54:08 +00:00
|
|
|
// set initial position from runway and heading
|
|
|
|
|
|
|
|
SGPath path( globals->get_fg_root() );
|
|
|
|
path.append( "Airports" );
|
|
|
|
path.append( "runways.mk4" );
|
|
|
|
FGRunways runways( path.c_str() );
|
|
|
|
|
|
|
|
SG_LOG( SG_GENERAL, SG_INFO,
|
|
|
|
"Attempting to set starting position from runway code "
|
|
|
|
<< id << " heading " << tgt_hdg );
|
|
|
|
|
|
|
|
// SGPath inpath( globals->get_fg_root() );
|
|
|
|
// inpath.append( "Airports" );
|
|
|
|
// inpath.append( "apt_simple" );
|
|
|
|
// airports.load( inpath.c_str() );
|
|
|
|
|
|
|
|
// SGPath outpath( globals->get_fg_root() );
|
|
|
|
// outpath.append( "Airports" );
|
|
|
|
// outpath.append( "simple.gdbm" );
|
|
|
|
// airports.dump_gdbm( outpath.c_str() );
|
|
|
|
|
|
|
|
if ( ! runways.search( id, &r ) ) {
|
|
|
|
SG_LOG( SG_GENERAL, SG_ALERT,
|
|
|
|
"Failed to find " << id << " in database." );
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
|
|
|
|
double diff;
|
|
|
|
double min_diff = 360.0;
|
|
|
|
|
|
|
|
while ( r.id == id ) {
|
|
|
|
// forward direction
|
|
|
|
diff = tgt_hdg - r.heading;
|
|
|
|
while ( diff < -180.0 ) { diff += 360.0; }
|
|
|
|
while ( diff > 180.0 ) { diff -= 360.0; }
|
|
|
|
diff = fabs(diff);
|
|
|
|
SG_LOG( SG_GENERAL, SG_INFO,
|
|
|
|
"Runway " << r.rwy_no << " heading = " << r.heading <<
|
|
|
|
" diff = " << diff );
|
|
|
|
if ( diff < min_diff ) {
|
|
|
|
min_diff = diff;
|
|
|
|
found_r = r;
|
|
|
|
found_dir = 0;
|
|
|
|
}
|
|
|
|
|
|
|
|
// reverse direction
|
|
|
|
diff = tgt_hdg - r.heading - 180.0;
|
|
|
|
while ( diff < -180.0 ) { diff += 360.0; }
|
|
|
|
while ( diff > 180.0 ) { diff -= 360.0; }
|
|
|
|
diff = fabs(diff);
|
|
|
|
SG_LOG( SG_GENERAL, SG_INFO,
|
|
|
|
"Runway -" << r.rwy_no << " heading = " <<
|
|
|
|
r.heading + 180.0 <<
|
|
|
|
" diff = " << diff );
|
|
|
|
if ( diff < min_diff ) {
|
|
|
|
min_diff = diff;
|
|
|
|
found_r = r;
|
|
|
|
found_dir = 180.0;
|
|
|
|
}
|
|
|
|
|
|
|
|
runways.next( &r );
|
|
|
|
}
|
|
|
|
|
|
|
|
SG_LOG( SG_GENERAL, SG_INFO, "closest runway = " << found_r.rwy_no
|
|
|
|
<< " + " << found_dir );
|
2000-08-16 00:09:03 +00:00
|
|
|
|
|
|
|
} else {
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
|
|
|
|
double heading = found_r.heading + found_dir;
|
|
|
|
while ( heading >= 360.0 ) { heading -= 360.0; }
|
|
|
|
|
|
|
|
double lat2, lon2, az2;
|
|
|
|
double azimuth = found_r.heading + found_dir + 180.0;
|
|
|
|
while ( azimuth >= 360.0 ) { azimuth -= 360.0; }
|
|
|
|
|
2001-03-24 06:03:11 +00:00
|
|
|
SG_LOG( SG_GENERAL, SG_INFO,
|
2000-08-16 00:09:03 +00:00
|
|
|
"runway = " << found_r.lon << ", " << found_r.lat
|
2001-03-24 04:56:46 +00:00
|
|
|
<< " length = " << found_r.length * SG_FEET_TO_METER * 0.5
|
2000-08-16 00:09:03 +00:00
|
|
|
<< " heading = " << azimuth );
|
2001-03-02 23:27:22 +00:00
|
|
|
|
2000-08-16 00:09:03 +00:00
|
|
|
geo_direct_wgs_84 ( 0, found_r.lat, found_r.lon,
|
2001-03-24 04:56:46 +00:00
|
|
|
azimuth, found_r.length * SG_FEET_TO_METER * 0.5 - 5.0,
|
2000-08-16 00:09:03 +00:00
|
|
|
&lat2, &lon2, &az2 );
|
2001-03-02 23:27:22 +00:00
|
|
|
|
2001-03-24 00:18:01 +00:00
|
|
|
if ( fabs( fgGetDouble("/sim/startup/offset-distance") ) > SG_EPSILON ) {
|
2001-03-02 23:27:22 +00:00
|
|
|
double olat, olon;
|
|
|
|
double odist = fgGetDouble("/sim/startup/offset-distance");
|
2001-03-24 04:56:46 +00:00
|
|
|
odist *= SG_NM_TO_METER;
|
2001-03-02 23:27:22 +00:00
|
|
|
double oaz = azimuth;
|
2001-03-24 00:18:01 +00:00
|
|
|
if ( fabs(fgGetDouble("/sim/startup/offset-azimuth")) > SG_EPSILON ) {
|
2001-03-02 23:27:22 +00:00
|
|
|
oaz = fgGetDouble("/sim/startup/offset-azimuth") + 180;
|
|
|
|
}
|
|
|
|
while ( oaz >= 360.0 ) { oaz -= 360.0; }
|
|
|
|
geo_direct_wgs_84 ( 0, lat2, lon2, oaz, odist, &olat, &olon, &az2 );
|
|
|
|
lat2=olat;
|
|
|
|
lon2=olon;
|
|
|
|
}
|
2002-02-05 20:54:08 +00:00
|
|
|
|
2001-07-02 22:27:24 +00:00
|
|
|
fgSetDouble("/position/longitude-deg", lon2 );
|
|
|
|
fgSetDouble("/position/latitude-deg", lat2 );
|
|
|
|
fgSetDouble("/orientation/heading-deg", heading );
|
2000-08-16 00:09:03 +00:00
|
|
|
|
2001-03-24 06:03:11 +00:00
|
|
|
SG_LOG( SG_GENERAL, SG_INFO,
|
2000-08-16 00:09:03 +00:00
|
|
|
"Position for " << id << " is ("
|
|
|
|
<< lon2 << ", "
|
|
|
|
<< lat2 << ") new heading is "
|
|
|
|
<< heading );
|
|
|
|
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
|
2002-02-20 16:56:44 +00:00
|
|
|
void fgSetPosFromGlideSlope(void) {
|
|
|
|
double gs = fgGetDouble("/velocities/glideslope");
|
|
|
|
double od = fgGetDouble("/sim/startup/offset-distance");
|
|
|
|
double alt = fgGetDouble("/position/altitude-ft");
|
|
|
|
|
|
|
|
//if glideslope and offset-distance are set and altitude is
|
|
|
|
//not, calculate the initial altitude
|
|
|
|
if( fabs(gs) > 0.01 && fabs(od) > 0.1 && alt < -9990 ) {
|
|
|
|
od *= SG_NM_TO_METER * SG_METER_TO_FEET;
|
|
|
|
alt = fabs(od*tan(gs));
|
|
|
|
fgSetDouble("/position/altitude-ft",alt);
|
|
|
|
fgSetBool("/sim/startup/onground", false);
|
|
|
|
SG_LOG(SG_GENERAL,SG_INFO, "Calculated altitude as: " << alt << " ft");
|
|
|
|
} else if( fabs(gs) > 0.01 && alt > 0 && fabs(od) < 0.1) {
|
|
|
|
od = alt/tan(gs);
|
|
|
|
od *= -1*SG_FEET_TO_METER * SG_METER_TO_NM;
|
|
|
|
fgSetDouble("/sim/startup/offset-distance",od);
|
|
|
|
SG_LOG(SG_GENERAL,SG_INFO, "Calculated offset distance as: "
|
|
|
|
<< od << " nm");
|
|
|
|
} else if( fabs(gs) > 0.01 ) {
|
|
|
|
SG_LOG(SG_GENERAL,SG_ALERT, "Glideslope given but not altitude"
|
|
|
|
<< " or offset-distance. Resetting"
|
|
|
|
<< " glideslope to zero" );
|
|
|
|
fgSetDouble("/velocities/glideslope",0);
|
|
|
|
}
|
|
|
|
|
|
|
|
}
|
2000-08-16 00:09:03 +00:00
|
|
|
|
1998-04-25 15:11:10 +00:00
|
|
|
// General house keeping initializations
|
1999-06-18 03:42:54 +00:00
|
|
|
bool fgInitGeneral( void ) {
|
1998-08-27 17:01:55 +00:00
|
|
|
string root;
|
1999-11-19 02:10:24 +00:00
|
|
|
|
|
|
|
#if defined(FX) && defined(XMESA)
|
1999-03-11 23:09:26 +00:00
|
|
|
char *mesa_win_state;
|
1999-11-19 02:10:24 +00:00
|
|
|
#endif
|
1998-04-25 15:11:10 +00:00
|
|
|
|
2001-03-24 06:03:11 +00:00
|
|
|
SG_LOG( SG_GENERAL, SG_INFO, "General Initialization" );
|
|
|
|
SG_LOG( SG_GENERAL, SG_INFO, "======= ==============" );
|
1998-04-25 20:24:00 +00:00
|
|
|
|
2001-01-13 22:06:39 +00:00
|
|
|
root = globals->get_fg_root();
|
1998-09-08 21:40:08 +00:00
|
|
|
if ( ! root.length() ) {
|
1998-07-13 21:00:09 +00:00
|
|
|
// No root path set? Then bail ...
|
2001-03-24 06:03:11 +00:00
|
|
|
SG_LOG( SG_GENERAL, SG_ALERT,
|
2001-10-28 16:16:30 +00:00
|
|
|
"Cannot continue without a path to the base package "
|
1998-11-06 21:17:31 +00:00
|
|
|
<< "being defined." );
|
|
|
|
exit(-1);
|
1998-04-25 15:11:10 +00:00
|
|
|
}
|
2001-03-24 06:03:11 +00:00
|
|
|
SG_LOG( SG_GENERAL, SG_INFO, "FG_ROOT = " << '"' << root << '"' << endl );
|
1998-04-25 15:11:10 +00:00
|
|
|
|
1999-03-11 23:09:26 +00:00
|
|
|
#if defined(FX) && defined(XMESA)
|
|
|
|
// initialize full screen flag
|
2002-01-06 16:51:31 +00:00
|
|
|
globals->set_fullscreen(false);
|
1999-03-11 23:09:26 +00:00
|
|
|
if ( strstr ( general.get_glRenderer(), "Glide" ) ) {
|
|
|
|
// Test for the MESA_GLX_FX env variable
|
|
|
|
if ( (mesa_win_state = getenv( "MESA_GLX_FX" )) != NULL) {
|
|
|
|
// test if we are fullscreen mesa/glide
|
1999-04-05 02:13:58 +00:00
|
|
|
if ( (mesa_win_state[0] == 'f') ||
|
1999-03-11 23:09:26 +00:00
|
|
|
(mesa_win_state[0] == 'F') ) {
|
2002-01-06 16:51:31 +00:00
|
|
|
globals->set_fullscreen(true);
|
1999-03-11 23:09:26 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
#endif
|
1998-05-07 23:14:14 +00:00
|
|
|
|
1999-06-18 03:42:54 +00:00
|
|
|
return true;
|
1998-04-25 15:11:10 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
|
2002-02-05 20:54:08 +00:00
|
|
|
// Initialize the flight model subsystem. This just creates the
|
|
|
|
// object. The actual fdm initialization is delayed until we get a
|
|
|
|
// proper scenery elevation hit. This is checked for in main.cxx
|
|
|
|
|
|
|
|
void fgInitFDM() {
|
|
|
|
|
|
|
|
if ( cur_fdm_state ) {
|
|
|
|
delete cur_fdm_state;
|
|
|
|
cur_fdm_state = 0;
|
|
|
|
}
|
|
|
|
|
|
|
|
double dt = 1.0 / fgGetInt("/sim/model-hz");
|
|
|
|
aircraft_dir = fgGetString("/sim/aircraft-dir");
|
|
|
|
const string &model = fgGetString("/sim/flight-model");
|
|
|
|
|
|
|
|
try {
|
2002-04-11 05:40:34 +00:00
|
|
|
if ( model == "larcsim" ) {
|
2002-02-05 20:54:08 +00:00
|
|
|
cur_fdm_state = new FGLaRCsim( dt );
|
2002-04-11 05:40:34 +00:00
|
|
|
} else if ( model == "jsb" ) {
|
2002-02-05 20:54:08 +00:00
|
|
|
cur_fdm_state = new FGJSBsim( dt );
|
2002-04-11 05:40:34 +00:00
|
|
|
} else if ( model == "ada" ) {
|
2002-02-05 20:54:08 +00:00
|
|
|
cur_fdm_state = new FGADA( dt );
|
2002-04-11 05:40:34 +00:00
|
|
|
} else if ( model == "balloon" ) {
|
2002-02-05 20:54:08 +00:00
|
|
|
cur_fdm_state = new FGBalloonSim( dt );
|
2002-04-11 05:40:34 +00:00
|
|
|
} else if ( model == "magic" ) {
|
2002-02-05 20:54:08 +00:00
|
|
|
cur_fdm_state = new FGMagicCarpet( dt );
|
2002-04-11 05:40:34 +00:00
|
|
|
} else if ( model == "external" ) {
|
2002-02-05 20:54:08 +00:00
|
|
|
cur_fdm_state = new FGExternal( dt );
|
2002-04-11 05:40:34 +00:00
|
|
|
} else if ( model.find("network,") == 0 ) {
|
|
|
|
string host = "localhost";
|
|
|
|
int port1 = 5501;
|
|
|
|
int port2 = 5502;
|
|
|
|
int port3 = 5503;
|
|
|
|
string net_options = model.substr(8);
|
|
|
|
string::size_type begin, end;
|
|
|
|
begin = 0;
|
|
|
|
// host
|
|
|
|
end = net_options.find( ",", begin );
|
|
|
|
if ( end != string::npos ) {
|
|
|
|
host = net_options.substr(begin, end - begin);
|
|
|
|
begin = end + 1;
|
|
|
|
}
|
|
|
|
// port1
|
|
|
|
end = net_options.find( ",", begin );
|
|
|
|
if ( end != string::npos ) {
|
|
|
|
port1 = atoi( net_options.substr(begin, end - begin).c_str() );
|
|
|
|
begin = end + 1;
|
|
|
|
}
|
|
|
|
// port2
|
|
|
|
end = net_options.find( ",", begin );
|
|
|
|
if ( end != string::npos ) {
|
|
|
|
port2 = atoi( net_options.substr(begin, end - begin).c_str() );
|
|
|
|
begin = end + 1;
|
|
|
|
}
|
|
|
|
// port3
|
|
|
|
end = net_options.find( ",", begin );
|
|
|
|
if ( end != string::npos ) {
|
|
|
|
port3 = atoi( net_options.substr(begin, end - begin).c_str() );
|
|
|
|
begin = end + 1;
|
|
|
|
}
|
|
|
|
cur_fdm_state = new FGExternalNet( dt, host, port1, port2, port3 );
|
|
|
|
} else if ( model == "null" ) {
|
2002-02-05 20:54:08 +00:00
|
|
|
cur_fdm_state = new FGNullFDM( dt );
|
2002-04-11 05:40:34 +00:00
|
|
|
} else if ( model == "yasim" ) {
|
2002-02-05 20:54:08 +00:00
|
|
|
cur_fdm_state = new YASim( dt );
|
|
|
|
} else {
|
|
|
|
SG_LOG(SG_GENERAL, SG_ALERT,
|
|
|
|
"Unrecognized flight model '" << model
|
|
|
|
<< "', cannot init flight dynamics model.");
|
|
|
|
exit(-1);
|
|
|
|
}
|
|
|
|
} catch ( ... ) {
|
|
|
|
SG_LOG(SG_GENERAL, SG_ALERT, "FlightGear aborting\n\n");
|
|
|
|
exit(-1);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
// Initialize view parameters
|
|
|
|
void fgInitView() {
|
2002-03-14 00:29:20 +00:00
|
|
|
globals->get_viewmgr()->update(0);
|
2002-02-05 20:54:08 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
|
2002-02-06 23:31:33 +00:00
|
|
|
SGTime *fgInitTime() {
|
|
|
|
// Initialize time
|
|
|
|
static const SGPropertyNode *longitude
|
|
|
|
= fgGetNode("/position/longitude-deg");
|
|
|
|
static const SGPropertyNode *latitude
|
|
|
|
= fgGetNode("/position/latitude-deg");
|
2002-02-11 23:33:20 +00:00
|
|
|
static const SGPropertyNode *cur_time_override
|
|
|
|
= fgGetNode("/sim/time/cur-time-override", true);
|
|
|
|
|
2002-02-06 23:31:33 +00:00
|
|
|
SGPath zone( globals->get_fg_root() );
|
|
|
|
zone.append( "Timezone" );
|
|
|
|
SGTime *t = new SGTime( longitude->getDoubleValue()
|
|
|
|
* SGD_DEGREES_TO_RADIANS,
|
|
|
|
latitude->getDoubleValue()
|
|
|
|
* SGD_DEGREES_TO_RADIANS,
|
2002-02-11 23:33:20 +00:00
|
|
|
zone.str(),
|
|
|
|
cur_time_override->getLongValue() );
|
2002-02-06 23:31:33 +00:00
|
|
|
|
|
|
|
// Handle potential user specified time offsets
|
|
|
|
time_t cur_time = t->get_cur_time();
|
|
|
|
time_t currGMT = sgTimeGetGMT( gmtime(&cur_time) );
|
|
|
|
time_t systemLocalTime = sgTimeGetGMT( localtime(&cur_time) );
|
|
|
|
time_t aircraftLocalTime =
|
|
|
|
sgTimeGetGMT( fgLocaltime(&cur_time, t->get_zonename() ) );
|
|
|
|
|
|
|
|
// Okay, we now have six possible scenarios
|
|
|
|
int offset = fgGetInt("/sim/startup/time-offset");
|
|
|
|
const string &offset_type = fgGetString("/sim/startup/time-offset-type");
|
|
|
|
if (offset_type == "system-offset") {
|
|
|
|
globals->set_warp( offset );
|
|
|
|
} else if (offset_type == "gmt-offset") {
|
|
|
|
globals->set_warp( offset - (currGMT - systemLocalTime) );
|
|
|
|
} else if (offset_type == "latitude-offset") {
|
|
|
|
globals->set_warp( offset - (aircraftLocalTime - systemLocalTime) );
|
|
|
|
} else if (offset_type == "system") {
|
|
|
|
globals->set_warp( offset - cur_time );
|
|
|
|
} else if (offset_type == "gmt") {
|
|
|
|
globals->set_warp( offset - currGMT );
|
|
|
|
} else if (offset_type == "latitude") {
|
|
|
|
globals->set_warp( offset - (aircraftLocalTime - systemLocalTime) -
|
|
|
|
cur_time );
|
|
|
|
} else {
|
|
|
|
SG_LOG( SG_GENERAL, SG_ALERT,
|
|
|
|
"FG_TIME::Unsupported offset type " << offset_type );
|
|
|
|
exit( -1 );
|
|
|
|
}
|
|
|
|
|
|
|
|
SG_LOG( SG_GENERAL, SG_INFO, "After time init, warp = "
|
|
|
|
<< globals->get_warp() );
|
|
|
|
|
|
|
|
globals->set_warp_delta( 0 );
|
|
|
|
|
2002-02-11 23:33:20 +00:00
|
|
|
t->update( 0.0, 0.0,
|
|
|
|
cur_time_override->getLongValue(),
|
|
|
|
globals->get_warp() );
|
2002-02-06 23:31:33 +00:00
|
|
|
|
|
|
|
return t;
|
|
|
|
}
|
|
|
|
|
|
|
|
|
1998-04-25 15:11:10 +00:00
|
|
|
// This is the top level init routine which calls all the other
|
|
|
|
// initialization routines. If you are adding a subsystem to flight
|
|
|
|
// gear, its initialization call should located in this routine.
|
|
|
|
// Returns non-zero if a problem encountered.
|
1999-06-18 03:42:54 +00:00
|
|
|
bool fgInitSubsystems( void ) {
|
2001-11-07 04:55:57 +00:00
|
|
|
static const SGPropertyNode *longitude
|
|
|
|
= fgGetNode("/position/longitude-deg");
|
|
|
|
static const SGPropertyNode *latitude
|
|
|
|
= fgGetNode("/position/latitude-deg");
|
|
|
|
static const SGPropertyNode *altitude
|
|
|
|
= fgGetNode("/position/altitude-ft");
|
|
|
|
|
1998-12-09 18:50:12 +00:00
|
|
|
fgLIGHT *l = &cur_light_params;
|
1998-04-25 15:11:10 +00:00
|
|
|
|
2001-03-24 06:03:11 +00:00
|
|
|
SG_LOG( SG_GENERAL, SG_INFO, "Initialize Subsystems");
|
|
|
|
SG_LOG( SG_GENERAL, SG_INFO, "========== ==========");
|
1998-04-25 15:11:10 +00:00
|
|
|
|
2001-04-05 20:20:44 +00:00
|
|
|
|
|
|
|
////////////////////////////////////////////////////////////////////
|
|
|
|
// Initialize the material property subsystem.
|
|
|
|
////////////////////////////////////////////////////////////////////
|
|
|
|
|
2001-03-25 14:20:12 +00:00
|
|
|
SGPath mpath( globals->get_fg_root() );
|
2001-12-28 23:33:32 +00:00
|
|
|
mpath.append( "materials.xml" );
|
2002-02-05 20:54:08 +00:00
|
|
|
if ( ! material_lib.load( mpath.str() ) ) {
|
2001-03-24 06:03:11 +00:00
|
|
|
SG_LOG( SG_GENERAL, SG_ALERT, "Error loading material lib!" );
|
2000-06-23 00:30:04 +00:00
|
|
|
exit(-1);
|
|
|
|
}
|
|
|
|
|
2001-04-05 20:20:44 +00:00
|
|
|
|
|
|
|
////////////////////////////////////////////////////////////////////
|
|
|
|
// Initialize the scenery management subsystem.
|
|
|
|
////////////////////////////////////////////////////////////////////
|
|
|
|
|
2001-10-28 16:16:30 +00:00
|
|
|
scenery.init();
|
|
|
|
scenery.bind();
|
1998-08-22 14:49:55 +00:00
|
|
|
|
2000-07-23 21:32:59 +00:00
|
|
|
if ( global_tile_mgr.init() ) {
|
1998-08-22 14:49:55 +00:00
|
|
|
// Load the local scenery data
|
2002-04-07 15:24:32 +00:00
|
|
|
double visibility_meters = fgGetDouble("/environment/visibility-m");
|
|
|
|
|
2002-02-06 23:31:33 +00:00
|
|
|
global_tile_mgr.update( longitude->getDoubleValue(),
|
2002-04-07 15:24:32 +00:00
|
|
|
latitude->getDoubleValue(),
|
|
|
|
visibility_meters );
|
1998-08-22 14:49:55 +00:00
|
|
|
} else {
|
2001-03-24 06:03:11 +00:00
|
|
|
SG_LOG( SG_GENERAL, SG_ALERT, "Error in Tile Manager initialization!" );
|
1998-11-06 21:17:31 +00:00
|
|
|
exit(-1);
|
1998-08-22 14:49:55 +00:00
|
|
|
}
|
|
|
|
|
2001-03-24 06:03:11 +00:00
|
|
|
SG_LOG( SG_GENERAL, SG_DEBUG,
|
1999-04-05 02:13:58 +00:00
|
|
|
"Current terrain elevation after tile mgr init " <<
|
2001-10-28 16:16:30 +00:00
|
|
|
scenery.get_cur_elev() );
|
1999-01-27 04:49:17 +00:00
|
|
|
|
2001-04-05 20:20:44 +00:00
|
|
|
|
|
|
|
////////////////////////////////////////////////////////////////////
|
|
|
|
// Initialize the flight model subsystem.
|
|
|
|
////////////////////////////////////////////////////////////////////
|
|
|
|
|
2002-02-05 20:54:08 +00:00
|
|
|
fgInitFDM();
|
|
|
|
|
2000-07-23 21:32:59 +00:00
|
|
|
// allocates structures so must happen before any of the flight
|
|
|
|
// model or control parameters are set
|
|
|
|
fgAircraftInit(); // In the future this might not be the case.
|
|
|
|
|
1998-08-22 14:49:55 +00:00
|
|
|
|
2001-04-05 20:20:44 +00:00
|
|
|
////////////////////////////////////////////////////////////////////
|
|
|
|
// Initialize the event manager subsystem.
|
|
|
|
////////////////////////////////////////////////////////////////////
|
|
|
|
|
2002-04-05 20:03:49 +00:00
|
|
|
global_events.init();
|
1997-12-30 20:47:34 +00:00
|
|
|
|
1998-04-25 20:24:00 +00:00
|
|
|
// Output event stats every 60 seconds
|
1998-08-29 13:09:25 +00:00
|
|
|
global_events.Register( "fgEVENT_MGR::PrintStats()",
|
2002-04-05 20:03:49 +00:00
|
|
|
boost::bind( &FGEventMgr::print_stats,
|
|
|
|
&global_events ),
|
|
|
|
60000 );
|
1997-12-30 20:47:34 +00:00
|
|
|
|
2001-04-05 20:20:44 +00:00
|
|
|
|
|
|
|
////////////////////////////////////////////////////////////////////
|
|
|
|
// Initialize the view manager subsystem.
|
|
|
|
////////////////////////////////////////////////////////////////////
|
|
|
|
|
2002-02-05 20:54:08 +00:00
|
|
|
fgInitView();
|
1998-04-25 20:24:00 +00:00
|
|
|
|
2001-04-05 20:20:44 +00:00
|
|
|
|
|
|
|
////////////////////////////////////////////////////////////////////
|
|
|
|
// Initialize the lighting subsystem.
|
|
|
|
////////////////////////////////////////////////////////////////////
|
|
|
|
|
1998-04-25 20:24:00 +00:00
|
|
|
// fgUpdateSunPos() needs a few position and view parameters set
|
|
|
|
// so it can calculate local relative sun angle and a few other
|
|
|
|
// things for correctly orienting the sky.
|
|
|
|
fgUpdateSunPos();
|
1999-03-22 02:08:05 +00:00
|
|
|
fgUpdateMoonPos();
|
2002-04-05 20:03:49 +00:00
|
|
|
global_events.Register( "fgUpdateSunPos()", &fgUpdateSunPos,
|
|
|
|
60000);
|
|
|
|
global_events.Register( "fgUpdateMoonPos()", &fgUpdateMoonPos,
|
|
|
|
60000);
|
1998-04-25 20:24:00 +00:00
|
|
|
|
1998-04-22 13:25:39 +00:00
|
|
|
// Initialize Lighting interpolation tables
|
1998-05-20 20:51:33 +00:00
|
|
|
l->Init();
|
1998-04-22 13:25:39 +00:00
|
|
|
|
|
|
|
// update the lighting parameters (based on sun angle)
|
1998-08-29 13:09:25 +00:00
|
|
|
global_events.Register( "fgLight::Update()",
|
2002-04-05 20:03:49 +00:00
|
|
|
boost::bind( &fgLIGHT::Update, &cur_light_params ),
|
|
|
|
30000 );
|
2001-04-05 20:20:44 +00:00
|
|
|
|
|
|
|
|
2002-03-12 16:29:00 +00:00
|
|
|
////////////////////////////////////////////////////////////////////
|
|
|
|
// Initialize the logger.
|
|
|
|
////////////////////////////////////////////////////////////////////
|
|
|
|
|
|
|
|
globals->set_logger(new FGLogger);
|
|
|
|
globals->get_logger()->init();
|
|
|
|
globals->get_logger()->bind();
|
|
|
|
|
2002-04-09 18:58:24 +00:00
|
|
|
|
2001-04-05 20:20:44 +00:00
|
|
|
////////////////////////////////////////////////////////////////////
|
|
|
|
// Initialize the local time subsystem.
|
|
|
|
////////////////////////////////////////////////////////////////////
|
|
|
|
|
1999-10-22 00:27:49 +00:00
|
|
|
// update the current timezone each 30 minutes
|
2002-04-05 20:03:49 +00:00
|
|
|
global_events.Register( "fgUpdateLocalTime()", &fgUpdateLocalTime,
|
|
|
|
30*60*1000 );
|
1998-04-22 13:25:39 +00:00
|
|
|
|
2001-04-05 20:20:44 +00:00
|
|
|
|
|
|
|
////////////////////////////////////////////////////////////////////
|
|
|
|
// Initialize the weather subsystem.
|
|
|
|
////////////////////////////////////////////////////////////////////
|
|
|
|
|
1998-04-22 13:25:39 +00:00
|
|
|
// Initialize the weather modeling subsystem
|
2002-02-19 15:16:08 +00:00
|
|
|
#ifndef FG_NEW_ENVIRONMENT
|
1999-08-10 03:44:47 +00:00
|
|
|
// Initialize the WeatherDatabase
|
2001-03-24 06:03:11 +00:00
|
|
|
SG_LOG(SG_GENERAL, SG_INFO, "Creating LocalWeatherDatabase");
|
1999-10-21 22:53:12 +00:00
|
|
|
sgVec3 position;
|
|
|
|
sgSetVec3( position, current_aircraft.fdm_state->get_Latitude(),
|
|
|
|
current_aircraft.fdm_state->get_Longitude(),
|
2001-03-24 04:56:46 +00:00
|
|
|
current_aircraft.fdm_state->get_Altitude() * SG_FEET_TO_METER );
|
2001-07-19 22:10:14 +00:00
|
|
|
double init_vis = fgGetDouble("/environment/visibility-m");
|
|
|
|
|
|
|
|
FGLocalWeatherDatabase::DatabaseWorkingType working_type;
|
|
|
|
|
2002-03-26 02:38:11 +00:00
|
|
|
if (!strcmp(fgGetString("/environment/weather/working-type"), "internet"))
|
2001-07-19 22:10:14 +00:00
|
|
|
{
|
|
|
|
working_type = FGLocalWeatherDatabase::use_internet;
|
|
|
|
} else {
|
|
|
|
working_type = FGLocalWeatherDatabase::default_mode;
|
|
|
|
}
|
|
|
|
|
|
|
|
if ( init_vis > 0 ) {
|
|
|
|
FGLocalWeatherDatabase::theFGLocalWeatherDatabase =
|
2000-12-06 04:13:16 +00:00
|
|
|
new FGLocalWeatherDatabase( position,
|
2001-07-19 22:10:14 +00:00
|
|
|
globals->get_fg_root(),
|
|
|
|
working_type,
|
|
|
|
init_vis );
|
|
|
|
} else {
|
|
|
|
FGLocalWeatherDatabase::theFGLocalWeatherDatabase =
|
|
|
|
new FGLocalWeatherDatabase( position,
|
|
|
|
globals->get_fg_root(),
|
|
|
|
working_type );
|
|
|
|
}
|
|
|
|
|
1999-10-21 22:53:12 +00:00
|
|
|
// cout << theFGLocalWeatherDatabase << endl;
|
|
|
|
// cout << "visibility = "
|
|
|
|
// << theFGLocalWeatherDatabase->getWeatherVisibility() << endl;
|
1999-08-10 03:44:47 +00:00
|
|
|
|
|
|
|
WeatherDatabase = FGLocalWeatherDatabase::theFGLocalWeatherDatabase;
|
2000-12-06 04:13:16 +00:00
|
|
|
|
1999-08-10 03:44:47 +00:00
|
|
|
// register the periodic update of the weather
|
2002-04-05 20:03:49 +00:00
|
|
|
global_events.Register( "weather update", &fgUpdateWeatherDatabase,
|
|
|
|
30000);
|
1999-08-12 17:13:44 +00:00
|
|
|
#else
|
2002-02-22 22:51:34 +00:00
|
|
|
globals->get_environment_mgr()->init();
|
|
|
|
globals->get_environment_mgr()->bind();
|
1999-08-12 17:13:44 +00:00
|
|
|
#endif
|
1997-08-23 01:46:20 +00:00
|
|
|
|
2001-04-05 20:20:44 +00:00
|
|
|
////////////////////////////////////////////////////////////////////
|
2000-04-24 23:51:26 +00:00
|
|
|
// Initialize vor/ndb/ils/fix list management and query systems
|
2001-04-05 20:20:44 +00:00
|
|
|
////////////////////////////////////////////////////////////////////
|
|
|
|
|
2001-03-24 06:03:11 +00:00
|
|
|
SG_LOG(SG_GENERAL, SG_INFO, "Loading Navaids");
|
2000-04-25 17:33:13 +00:00
|
|
|
|
2001-03-24 06:03:11 +00:00
|
|
|
SG_LOG(SG_GENERAL, SG_INFO, " VOR/NDB");
|
2000-04-24 23:51:26 +00:00
|
|
|
current_navlist = new FGNavList;
|
2001-03-25 14:20:12 +00:00
|
|
|
SGPath p_nav( globals->get_fg_root() );
|
2000-04-24 23:51:26 +00:00
|
|
|
p_nav.append( "Navaids/default.nav" );
|
|
|
|
current_navlist->init( p_nav );
|
|
|
|
|
2001-03-24 06:03:11 +00:00
|
|
|
SG_LOG(SG_GENERAL, SG_INFO, " ILS and Marker Beacons");
|
2001-03-16 23:59:02 +00:00
|
|
|
current_beacons = new FGMarkerBeacons;
|
|
|
|
current_beacons->init();
|
2000-04-24 23:51:26 +00:00
|
|
|
current_ilslist = new FGILSList;
|
2001-03-25 14:20:12 +00:00
|
|
|
SGPath p_ils( globals->get_fg_root() );
|
2000-04-24 23:51:26 +00:00
|
|
|
p_ils.append( "Navaids/default.ils" );
|
|
|
|
current_ilslist->init( p_ils );
|
|
|
|
|
2001-03-24 06:03:11 +00:00
|
|
|
SG_LOG(SG_GENERAL, SG_INFO, " Fixes");
|
2000-04-24 23:51:26 +00:00
|
|
|
current_fixlist = new FGFixList;
|
2001-03-25 14:20:12 +00:00
|
|
|
SGPath p_fix( globals->get_fg_root() );
|
2000-04-24 23:51:26 +00:00
|
|
|
p_fix.append( "Navaids/default.fix" );
|
|
|
|
current_fixlist->init( p_fix );
|
|
|
|
|
2001-11-07 17:55:28 +00:00
|
|
|
////////////////////////////////////////////////////////////////////
|
|
|
|
// Initialize ATC list management and query systems
|
|
|
|
////////////////////////////////////////////////////////////////////
|
|
|
|
|
|
|
|
SG_LOG(SG_GENERAL, SG_INFO, " ATIS");
|
|
|
|
current_atislist = new FGATISList;
|
|
|
|
SGPath p_atis( globals->get_fg_root() );
|
|
|
|
p_atis.append( "ATC/default.atis" );
|
|
|
|
current_atislist->init( p_atis );
|
|
|
|
|
2002-04-03 23:54:44 +00:00
|
|
|
SG_LOG(SG_GENERAL, SG_INFO, " Tower");
|
|
|
|
current_towerlist = new FGTowerList;
|
|
|
|
SGPath p_tower( globals->get_fg_root() );
|
|
|
|
p_tower.append( "ATC/default.tower" );
|
|
|
|
current_towerlist->init( p_tower );
|
|
|
|
|
|
|
|
SG_LOG(SG_GENERAL, SG_INFO, " Approach");
|
|
|
|
current_approachlist = new FGApproachList;
|
|
|
|
SGPath p_approach( globals->get_fg_root() );
|
|
|
|
p_approach.append( "ATC/default.approach" );
|
|
|
|
current_approachlist->init( p_approach );
|
|
|
|
|
2001-11-07 17:55:28 +00:00
|
|
|
////////////////////////////////////////////////////////////////////
|
|
|
|
// Initialise ATC display system
|
|
|
|
////////////////////////////////////////////////////////////////////
|
|
|
|
|
|
|
|
SG_LOG(SG_GENERAL, SG_INFO, " ATC Display");
|
2002-03-01 17:39:52 +00:00
|
|
|
globals->set_ATC_display(new FGATCDisplay);
|
|
|
|
globals->get_ATC_display()->init();
|
|
|
|
|
|
|
|
////////////////////////////////////////////////////////////////////
|
|
|
|
// Initialise the ATC Manager
|
|
|
|
////////////////////////////////////////////////////////////////////
|
|
|
|
|
|
|
|
SG_LOG(SG_GENERAL, SG_INFO, " ATC Manager");
|
|
|
|
globals->set_ATC_mgr(new FGATCMgr);
|
2002-04-03 23:54:44 +00:00
|
|
|
globals->get_ATC_mgr()->init();
|
|
|
|
|
|
|
|
////////////////////////////////////////////////////////////////////
|
|
|
|
// Initialise the AI Manager
|
|
|
|
////////////////////////////////////////////////////////////////////
|
|
|
|
|
|
|
|
SG_LOG(SG_GENERAL, SG_INFO, " AI Manager");
|
|
|
|
globals->set_AI_mgr(new FGAIMgr);
|
|
|
|
globals->get_AI_mgr()->init();
|
2001-04-05 20:20:44 +00:00
|
|
|
|
2001-06-01 17:52:28 +00:00
|
|
|
////////////////////////////////////////////////////////////////////
|
|
|
|
// Initialize the built-in commands.
|
|
|
|
////////////////////////////////////////////////////////////////////
|
|
|
|
fgInitCommands();
|
|
|
|
|
|
|
|
|
2002-02-05 20:54:08 +00:00
|
|
|
#ifdef ENABLE_AUDIO_SUPPORT
|
2001-10-29 04:39:05 +00:00
|
|
|
////////////////////////////////////////////////////////////////////
|
|
|
|
// Initialize the sound subsystem.
|
|
|
|
////////////////////////////////////////////////////////////////////
|
|
|
|
|
|
|
|
globals->set_soundmgr(new FGSoundMgr);
|
|
|
|
globals->get_soundmgr()->init();
|
|
|
|
globals->get_soundmgr()->bind();
|
|
|
|
|
|
|
|
|
|
|
|
////////////////////////////////////////////////////////////////////
|
|
|
|
// Initialize the sound-effects subsystem.
|
|
|
|
////////////////////////////////////////////////////////////////////
|
|
|
|
globals->set_fx(new FGFX);
|
|
|
|
globals->get_fx()->init();
|
|
|
|
globals->get_fx()->bind();
|
|
|
|
|
2002-02-05 20:54:08 +00:00
|
|
|
#endif
|
2001-10-29 04:39:05 +00:00
|
|
|
|
2001-04-05 20:20:44 +00:00
|
|
|
////////////////////////////////////////////////////////////////////
|
|
|
|
// Initialize the radio stack subsystem.
|
|
|
|
////////////////////////////////////////////////////////////////////
|
|
|
|
|
|
|
|
// A textbook example of how FGSubsystem
|
|
|
|
// should work...
|
2000-04-25 03:09:26 +00:00
|
|
|
current_radiostack = new FGRadioStack;
|
2001-01-11 22:44:18 +00:00
|
|
|
current_radiostack->init();
|
|
|
|
current_radiostack->bind();
|
2000-05-04 01:18:45 +00:00
|
|
|
|
2001-04-05 20:20:44 +00:00
|
|
|
|
|
|
|
////////////////////////////////////////////////////////////////////
|
|
|
|
// Initialize the cockpit subsystem
|
|
|
|
////////////////////////////////////////////////////////////////////
|
|
|
|
|
1998-02-12 21:58:27 +00:00
|
|
|
if( fgCockpitInit( ¤t_aircraft )) {
|
|
|
|
// Cockpit initialized ok.
|
|
|
|
} else {
|
2001-03-24 06:03:11 +00:00
|
|
|
SG_LOG( SG_GENERAL, SG_ALERT, "Error in Cockpit initialization!" );
|
1998-11-06 21:17:31 +00:00
|
|
|
exit(-1);
|
1997-09-04 02:17:18 +00:00
|
|
|
}
|
1997-08-25 20:27:21 +00:00
|
|
|
|
1998-02-12 21:58:27 +00:00
|
|
|
|
2001-04-05 20:20:44 +00:00
|
|
|
////////////////////////////////////////////////////////////////////
|
|
|
|
// Initialize the autopilot subsystem.
|
|
|
|
////////////////////////////////////////////////////////////////////
|
|
|
|
|
2002-03-13 16:31:21 +00:00
|
|
|
globals->set_autopilot(new FGAutopilot);
|
|
|
|
globals->get_autopilot()->init();
|
|
|
|
globals->get_autopilot()->bind();
|
2000-04-30 06:51:49 +00:00
|
|
|
|
2002-03-13 16:31:21 +00:00
|
|
|
// FIXME: these should go in the
|
|
|
|
// GUI initialization code, not here.
|
2002-02-05 20:54:08 +00:00
|
|
|
fgAPAdjustInit();
|
2000-04-30 06:51:49 +00:00
|
|
|
NewTgtAirportInit();
|
|
|
|
NewHeadingInit();
|
|
|
|
NewAltitudeInit();
|
1998-11-16 13:59:58 +00:00
|
|
|
|
2001-04-05 20:20:44 +00:00
|
|
|
////////////////////////////////////////////////////////////////////
|
|
|
|
// Initialize I/O subsystem.
|
|
|
|
////////////////////////////////////////////////////////////////////
|
|
|
|
|
2000-09-10 00:04:50 +00:00
|
|
|
#if ! defined( macintosh )
|
1999-11-19 02:10:24 +00:00
|
|
|
fgIOInit();
|
1999-04-27 19:27:45 +00:00
|
|
|
#endif
|
1998-11-16 13:59:58 +00:00
|
|
|
|
User-visible
- knobs now continue to rotate when you hold down the mouse
- the middle mouse button makes knobs rotate much faster
- there are NAV1, NAV2, and ADF radios that can be tuned using the mouse
- there are standby frequencies for NAV1 and NAV2, and buttons to swap
- there is a crude, rather silly-looking DME, hard-wired to NAV1
- there is a crude, rather silly-looking autopilot that can lock
the heading (to the bug on the gyro), can lock to NAV1, and can lock
the current altitude
- the knobs for changing the radials on NAV1 and NAV2 look much better
and are in the right place
- tuning into an ILS frequency doesn't change the displayed radial for
NAV1
Code
- I've created a new module, sp_panel.[ch]xx, that constructs the
default single-prop panel; this works entirely outside of FGPanel,
so it is possible to construct similar modules for other sorts of
panels; all code specific to the default panel has been removed from
panel.cxx
- current_panel is now a pointer
- radiostack.[ch]xx keeps track both of the actual radial and of the
selected radial (they will differ with ILS); the NAV gauges should
not spin around automatically to show the actual radial (we need to
do something similar with the autopilot)
- the panel is initialized fairly early
- make sure that standby frequencies also get initialized
- I've started combining and clipping small textures to save texture
memory; there's a lot more to do, but at least I've made a start
2000-05-02 18:26:00 +00:00
|
|
|
// Initialize the 2D panel.
|
2001-01-13 22:06:39 +00:00
|
|
|
string panel_path = fgGetString("/sim/panel/path",
|
|
|
|
"Panels/Default/default.xml");
|
2000-09-22 17:20:56 +00:00
|
|
|
current_panel = fgReadPanel(panel_path);
|
|
|
|
if (current_panel == 0) {
|
2001-03-24 06:03:11 +00:00
|
|
|
SG_LOG( SG_INPUT, SG_ALERT,
|
2000-10-25 19:27:13 +00:00
|
|
|
"Error reading new panel from " << panel_path );
|
|
|
|
} else {
|
2001-03-24 06:03:11 +00:00
|
|
|
SG_LOG( SG_INPUT, SG_INFO, "Loaded new panel from " << panel_path );
|
2001-01-11 22:44:18 +00:00
|
|
|
current_panel->init();
|
|
|
|
current_panel->bind();
|
2000-09-22 17:20:56 +00:00
|
|
|
}
|
User-visible
- knobs now continue to rotate when you hold down the mouse
- the middle mouse button makes knobs rotate much faster
- there are NAV1, NAV2, and ADF radios that can be tuned using the mouse
- there are standby frequencies for NAV1 and NAV2, and buttons to swap
- there is a crude, rather silly-looking DME, hard-wired to NAV1
- there is a crude, rather silly-looking autopilot that can lock
the heading (to the bug on the gyro), can lock to NAV1, and can lock
the current altitude
- the knobs for changing the radials on NAV1 and NAV2 look much better
and are in the right place
- tuning into an ILS frequency doesn't change the displayed radial for
NAV1
Code
- I've created a new module, sp_panel.[ch]xx, that constructs the
default single-prop panel; this works entirely outside of FGPanel,
so it is possible to construct similar modules for other sorts of
panels; all code specific to the default panel has been removed from
panel.cxx
- current_panel is now a pointer
- radiostack.[ch]xx keeps track both of the actual radial and of the
selected radial (they will differ with ILS); the NAV gauges should
not spin around automatically to show the actual radial (we need to
do something similar with the autopilot)
- the panel is initialized fairly early
- make sure that standby frequencies also get initialized
- I've started combining and clipping small textures to save texture
memory; there's a lot more to do, but at least I've made a start
2000-05-02 18:26:00 +00:00
|
|
|
|
2001-04-05 20:20:44 +00:00
|
|
|
|
|
|
|
////////////////////////////////////////////////////////////////////
|
2001-06-05 22:12:08 +00:00
|
|
|
// Initialize the default (kludged) properties.
|
2001-04-05 20:20:44 +00:00
|
|
|
////////////////////////////////////////////////////////////////////
|
|
|
|
|
2001-07-02 22:27:24 +00:00
|
|
|
fgInitProps();
|
2000-07-03 20:09:56 +00:00
|
|
|
|
2001-04-05 20:20:44 +00:00
|
|
|
|
|
|
|
////////////////////////////////////////////////////////////////////
|
|
|
|
// Initialize the controls subsystem.
|
|
|
|
////////////////////////////////////////////////////////////////////
|
|
|
|
|
2001-07-22 19:51:16 +00:00
|
|
|
globals->get_controls()->init();
|
|
|
|
globals->get_controls()->bind();
|
2001-01-05 17:38:58 +00:00
|
|
|
|
2001-04-05 20:20:44 +00:00
|
|
|
|
I'm attaching diffs to add a new FGInput module to FlightGear
(src/Input). So far, FGInput replaces most of src/Main/keyboard.cxx
(I've left a tiny stub); in the very near future, it will also take
over control of the joystick, mouse (Norm permitting), and panel
instrument interactions, so that there is a single mechanism for
configuring all input devices.
The new format should be (close to) self-explanatory by looking at the
new base-package file keyboard.xml, which is now included by
preferences.xml (I'll do the same thing for the joystick when I have a
chance). I have not managed to move all keybindings into this file
yet, but I've made a good start. I'm including Tony in the recipient
list so that he can see how bindings can use an external XML file.
This patch also adds support for multiple bindings for a single key,
special keys (i.e. keypad and function keys), and key modifiers
(shift/alt/ctrl); special keys use the PUI convention of adding 256 to
the Glut key code.
Unfortunately, everything comes with a price; in this case, I have not
yet found a general mechanism for the old (hard-coded) modal bindings,
which behaved differently depending on the autopilot state (i.e. left
rudder or move AP heading left); with my patches, this functionality
disappears, but you can still adjust the autopilot using the panel or
the GUI input dialogs.
2001-05-23 23:01:15 +00:00
|
|
|
////////////////////////////////////////////////////////////////////
|
|
|
|
// Initialize the input subsystem.
|
|
|
|
////////////////////////////////////////////////////////////////////
|
|
|
|
|
|
|
|
current_input.init();
|
|
|
|
current_input.bind();
|
|
|
|
|
|
|
|
|
2001-04-05 20:20:44 +00:00
|
|
|
////////////////////////////////////////////////////////////////////////
|
|
|
|
// End of subsystem initialization.
|
|
|
|
////////////////////////////////////////////////////////////////////
|
|
|
|
|
2001-03-24 06:03:11 +00:00
|
|
|
SG_LOG( SG_GENERAL, SG_INFO, endl);
|
1998-04-24 00:49:17 +00:00
|
|
|
|
2001-01-19 22:57:24 +00:00
|
|
|
// Save the initial state for future
|
|
|
|
// reference.
|
|
|
|
globals->saveInitialState();
|
|
|
|
|
1999-06-18 03:42:54 +00:00
|
|
|
return true;
|
1997-08-23 01:46:20 +00:00
|
|
|
}
|
1999-04-27 15:52:32 +00:00
|
|
|
|
|
|
|
|
|
|
|
void fgReInitSubsystems( void )
|
|
|
|
{
|
2001-10-28 16:16:30 +00:00
|
|
|
static const SGPropertyNode *longitude
|
|
|
|
= fgGetNode("/position/longitude-deg");
|
|
|
|
static const SGPropertyNode *latitude
|
|
|
|
= fgGetNode("/position/latitude-deg");
|
|
|
|
static const SGPropertyNode *altitude
|
|
|
|
= fgGetNode("/position/altitude-ft");
|
2002-01-20 03:52:36 +00:00
|
|
|
static const SGPropertyNode *master_freeze
|
|
|
|
= fgGetNode("/sim/freeze/master");
|
2001-10-28 16:16:30 +00:00
|
|
|
|
2001-03-24 06:03:11 +00:00
|
|
|
SG_LOG( SG_GENERAL, SG_INFO,
|
2001-10-28 16:16:30 +00:00
|
|
|
"/position/altitude = " << altitude->getDoubleValue() );
|
2001-01-17 23:30:35 +00:00
|
|
|
|
2002-01-20 03:52:36 +00:00
|
|
|
bool freeze = master_freeze->getBoolValue();
|
|
|
|
if ( !freeze ) {
|
|
|
|
fgSetBool("/sim/freeze/master", true);
|
2001-10-28 16:16:30 +00:00
|
|
|
}
|
1999-05-12 02:07:21 +00:00
|
|
|
|
2001-01-17 20:32:02 +00:00
|
|
|
// Initialize the Scenery Management subsystem
|
2001-10-28 16:16:30 +00:00
|
|
|
scenery.init();
|
2001-01-17 20:32:02 +00:00
|
|
|
|
2002-02-05 20:54:08 +00:00
|
|
|
#if 0
|
|
|
|
if( global_tile_mgr.init() ) {
|
|
|
|
Load the local scenery data
|
2001-10-28 16:16:30 +00:00
|
|
|
global_tile_mgr.update( longitude->getDoubleValue(),
|
|
|
|
latitude->getDoubleValue() );
|
2002-02-05 20:54:08 +00:00
|
|
|
} else {
|
|
|
|
SG_LOG( SG_GENERAL, SG_ALERT, "Error in Tile Manager initialization!" );
|
|
|
|
exit(-1);
|
1999-04-27 15:52:32 +00:00
|
|
|
}
|
2002-02-05 20:54:08 +00:00
|
|
|
#endif
|
2000-07-23 21:32:59 +00:00
|
|
|
|
2002-02-05 20:54:08 +00:00
|
|
|
fgInitFDM();
|
2002-02-17 21:05:27 +00:00
|
|
|
|
|
|
|
// allocates structures so must happen before any of the flight
|
|
|
|
// model or control parameters are set
|
|
|
|
fgAircraftInit(); // In the future this might not be the case.
|
2000-10-27 22:00:43 +00:00
|
|
|
|
2002-02-05 20:54:08 +00:00
|
|
|
fgInitView();
|
1999-04-27 15:52:32 +00:00
|
|
|
|
2001-07-22 19:51:16 +00:00
|
|
|
globals->get_controls()->reset_all();
|
2002-03-13 16:31:21 +00:00
|
|
|
globals->get_autopilot()->reset();
|
1999-05-12 02:07:21 +00:00
|
|
|
|
2001-04-05 21:14:37 +00:00
|
|
|
fgUpdateSunPos();
|
|
|
|
fgUpdateMoonPos();
|
|
|
|
cur_light_params.Update();
|
|
|
|
fgUpdateLocalTime();
|
|
|
|
|
2002-01-20 03:52:36 +00:00
|
|
|
if ( !freeze ) {
|
|
|
|
fgSetBool("/sim/freeze/master", false);
|
|
|
|
}
|
1999-04-27 15:52:32 +00:00
|
|
|
}
|
2002-04-06 17:23:18 +00:00
|
|
|
|
2002-04-11 04:26:07 +00:00
|
|
|
|