1
0
Fork 0

- remove dependence on /sim/number-views: the view manager just uses all

/sim/view[*] that it finds. It's not only unnecessary that view definitions
  have subsequent indices, but aircraft are now *requested* to use indices
  100++. /sim/view[0] .. /sim/view[99] are reserved for the system. (Not
  that we'd ever need that many, This is just a convention, it's nowhere
  hard-coded.)
- replace the string operations for property paths by method calls & other
  improvements
This commit is contained in:
mfranz 2007-05-04 14:58:52 +00:00
parent dad550e0eb
commit 5d8f383ded
2 changed files with 99 additions and 254 deletions

View file

@ -34,18 +34,17 @@
#include <Model/acmodel.hxx>
#include "viewmgr.hxx"
#include "fg_props.hxx"
// Constructor
FGViewMgr::FGViewMgr( void ) :
axis_long(0),
axis_lat(0),
config_list(fgGetNode("/sim", true)->getChildren("view")),
current(0)
{
}
// Destructor
FGViewMgr::~FGViewMgr( void ) {
}
@ -53,120 +52,52 @@ FGViewMgr::~FGViewMgr( void ) {
void
FGViewMgr::init ()
{
char stridx [ 20 ];
string viewpath, nodepath, strdata;
bool from_model = false;
bool at_model = false;
int from_model_index = 0;
int at_model_index = 0;
// double damp_alt;
double damp_roll = 0.0, damp_pitch = 0.0, damp_heading = 0.0;
double x_offset_m, y_offset_m, z_offset_m, fov_deg;
double heading_offset_deg, pitch_offset_deg, roll_offset_deg;
double target_x_offset_m, target_y_offset_m, target_z_offset_m;
double near_m;
bool internal;
double aspect_ratio_multiplier
= fgGetDouble("/sim/current-view/aspect-ratio-multiplier");
for (int i = 0; i < fgGetInt("/sim/number-views"); i++) {
viewpath = "/sim/view";
sprintf(stridx, "[%d]", i);
viewpath += stridx;
// find out what type of view this is...
nodepath = viewpath;
nodepath += "/type";
strdata = fgGetString(nodepath.c_str());
for (unsigned int i = 0; i < config_list.size(); i++) {
SGPropertyNode *n = config_list[i];
// find out if this is an internal view (e.g. in cockpit, low near plane)
internal = false; // default
nodepath = viewpath;
nodepath += "/internal";
internal = fgGetBool(nodepath.c_str());
bool internal = n->getBoolValue("internal", false);
// FIXME:
// this is assumed to be an aircraft model...we will need to read
// model-from-type as well.
// find out if this is a model we are looking from...
nodepath = viewpath;
nodepath += "/config/from-model";
from_model = fgGetBool(nodepath.c_str());
bool from_model = n->getBoolValue("config/from-model");
int from_model_index = n->getIntValue("config/from-model-idx");
// get model index (which model)
if (from_model) {
nodepath = viewpath;
nodepath += "/config/from-model-idx";
from_model_index = fgGetInt(nodepath.c_str());
}
double x_offset_m = n->getDoubleValue("config/x-offset-m");
double y_offset_m = n->getDoubleValue("config/y-offset-m");
double z_offset_m = n->getDoubleValue("config/z-offset-m");
if ( strcmp("lookat",strdata.c_str()) == 0 ) {
// find out if this is a model we are looking at...
nodepath = viewpath;
nodepath += "/config/at-model";
at_model = fgGetBool(nodepath.c_str());
double heading_offset_deg = n->getDoubleValue("config/heading-offset-deg");
n->setDoubleValue(heading_offset_deg);
double pitch_offset_deg = n->getDoubleValue("config/pitch-offset-deg");
n->setDoubleValue(pitch_offset_deg);
double roll_offset_deg = n->getDoubleValue("config/roll-offset-deg");
n->setDoubleValue(roll_offset_deg);
// get model index (which model)
if (at_model) {
nodepath = viewpath;
nodepath += "/config/at-model-idx";
at_model_index = fgGetInt(nodepath.c_str());
double fov_deg = n->getDoubleValue("config/default-field-of-view-deg");
double near_m = n->getDoubleValue("config/ground-level-nearplane-m");
nodepath = viewpath;
nodepath += "/config/at-model-roll-damping";
damp_roll = fgGetDouble(nodepath.c_str(), 0.0);
nodepath = viewpath;
nodepath += "/config/at-model-pitch-damping";
damp_pitch = fgGetDouble(nodepath.c_str(), 0.0);
nodepath = viewpath;
nodepath += "/config/at-model-heading-damping";
damp_heading = fgGetDouble(nodepath.c_str(), 0.0);
}
}
// supporting two types "lookat" = 1 and "lookfrom" = 0
const char *type = n->getStringValue("type");
if (!strcmp(type, "lookat")) {
nodepath = viewpath;
nodepath += "/config/x-offset-m";
x_offset_m = fgGetDouble(nodepath.c_str());
nodepath = viewpath;
nodepath += "/config/y-offset-m";
y_offset_m = fgGetDouble(nodepath.c_str());
nodepath = viewpath;
nodepath += "/config/z-offset-m";
z_offset_m = fgGetDouble(nodepath.c_str());
nodepath = viewpath;
nodepath += "/config/pitch-offset-deg";
pitch_offset_deg = fgGetDouble(nodepath.c_str());
fgSetDouble(nodepath.c_str(),pitch_offset_deg);
nodepath = viewpath;
nodepath += "/config/heading-offset-deg";
heading_offset_deg = fgGetDouble(nodepath.c_str());
fgSetDouble(nodepath.c_str(),heading_offset_deg);
nodepath = viewpath;
nodepath += "/config/roll-offset-deg";
roll_offset_deg = fgGetDouble(nodepath.c_str());
fgSetDouble(nodepath.c_str(),roll_offset_deg);
nodepath = viewpath;
nodepath += "/config/default-field-of-view-deg";
fov_deg = fgGetDouble(nodepath.c_str());
bool at_model = n->getBoolValue("config/at-model");
int at_model_index = n->getIntValue("config/at-model-idx");
// target offsets for lookat mode only...
nodepath = viewpath;
nodepath += "/config/target-x-offset-m";
target_x_offset_m = fgGetDouble(nodepath.c_str());
nodepath = viewpath;
nodepath += "/config/target-y-offset-m";
target_y_offset_m = fgGetDouble(nodepath.c_str());
nodepath = viewpath;
nodepath += "/config/target-z-offset-m";
target_z_offset_m = fgGetDouble(nodepath.c_str());
double damp_roll = n->getDoubleValue("config/at-model-roll-damping");
double damp_pitch = n->getDoubleValue("config/at-model-pitch-damping");
double damp_heading = n->getDoubleValue("config/at-model-heading-damping");
nodepath = viewpath;
nodepath += "/config/ground-level-nearplane-m";
near_m = fgGetDouble(nodepath.c_str());
double target_x_offset_m = n->getDoubleValue("config/target-x-offset-m");
double target_y_offset_m = n->getDoubleValue("config/target-y-offset-m");
double target_z_offset_m = n->getDoubleValue("config/target-z-offset-m");
// supporting two types now "lookat" = 1 and "lookfrom" = 0
if ( strcmp("lookat",strdata.c_str()) == 0 )
add_view(new FGViewer ( FG_LOOKAT, from_model, from_model_index,
at_model, at_model_index,
damp_roll, damp_pitch, damp_heading,
@ -175,90 +106,54 @@ FGViewMgr::init ()
roll_offset_deg, fov_deg, aspect_ratio_multiplier,
target_x_offset_m, target_y_offset_m,
target_z_offset_m, near_m, internal ));
else
} else {
add_view(new FGViewer ( FG_LOOKFROM, from_model, from_model_index,
false, 0, 0.0, 0.0, 0.0,
x_offset_m, y_offset_m, z_offset_m,
heading_offset_deg, pitch_offset_deg,
roll_offset_deg, fov_deg, aspect_ratio_multiplier,
0, 0, 0, near_m, internal ));
}
}
copyToCurrent();
}
void
FGViewMgr::reinit ()
{
char stridx [ 20 ];
string viewpath, nodepath, strdata;
double fov_deg;
// reset offsets and fov to configuration defaults
for (int i = 0; i < fgGetInt("/sim/number-views"); i++) {
viewpath = "/sim/view";
sprintf(stridx, "[%d]", i);
viewpath += stridx;
for (unsigned int i = 0; i < config_list.size(); i++) {
SGPropertyNode *n = config_list[i];
setView(i);
nodepath = viewpath;
nodepath += "/config/x-offset-m";
fgSetDouble("/sim/current-view/x-offset-m",fgGetDouble(nodepath.c_str()));
nodepath = viewpath;
nodepath += "/config/y-offset-m";
fgSetDouble("/sim/current-view/y-offset-m",fgGetDouble(nodepath.c_str()));
nodepath = viewpath;
nodepath += "/config/z-offset-m";
fgSetDouble("/sim/current-view/z-offset-m",fgGetDouble(nodepath.c_str()));
nodepath = viewpath;
nodepath += "/config/pitch-offset-deg";
fgSetDouble("/sim/current-view/x-offset-m",
n->getDoubleValue("config/x-offset-m"));
fgSetDouble("/sim/current-view/y-offset-m",
n->getDoubleValue("config/y-offset-m"));
fgSetDouble("/sim/current-view/z-offset-m",
n->getDoubleValue("config/z-offset-m"));
fgSetDouble("/sim/current-view/pitch-offset-deg",
fgGetDouble(nodepath.c_str()));
nodepath = viewpath;
nodepath += "/config/heading-offset-deg";
n->getDoubleValue("config/pitch-offset-deg"));
fgSetDouble("/sim/current-view/heading-offset-deg",
fgGetDouble(nodepath.c_str()));
nodepath = viewpath;
nodepath += "/config/roll-offset-deg";
n->getDoubleValue("config/heading-offset-deg"));
fgSetDouble("/sim/current-view/roll-offset-deg",
fgGetDouble(nodepath.c_str()));
n->getDoubleValue("config/roll-offset-deg"));
nodepath = viewpath;
nodepath += "/config/default-field-of-view-deg";
fov_deg = fgGetDouble(nodepath.c_str());
if (fov_deg < 10.0) {
double fov_deg = n->getDoubleValue("config/default-field-of-view-deg");
if (fov_deg < 10.0)
fov_deg = 55.0;
}
fgSetDouble("/sim/current-view/field-of-view",fov_deg);
fgSetDouble("/sim/current-view/field-of-view", fov_deg);
// target offsets for lookat mode only...
nodepath = viewpath;
nodepath += "/config/target-x-offset-m";
fgSetDouble("/sim/current-view/target-x-offset-deg",
fgGetDouble(nodepath.c_str()));
nodepath = viewpath;
nodepath += "/config/target-y-offset-m";
n->getDoubleValue("config/target-x-offset-m"));
fgSetDouble("/sim/current-view/target-y-offset-deg",
fgGetDouble(nodepath.c_str()));
nodepath = viewpath;
nodepath += "/config/target-z-offset-m";
n->getDoubleValue("config/target-y-offset-m"));
fgSetDouble("/sim/current-view/target-z-offset-deg",
fgGetDouble(nodepath.c_str()));
}
setView(0);
n->getDoubleValue("config/target-z-offset-m"));
}
setView(0);
}
typedef double (FGViewMgr::*double_getter)() const;
@ -292,7 +187,7 @@ FGViewMgr::bind ()
&FGViewMgr::setGoalViewRollOffset_deg);
fgSetArchivable("/sim/current-view/goal-roll-offset-deg");
fgTie("/sim/current-view/view-number", this,
fgTie("/sim/current-view/view-number", this,
&FGViewMgr::getView, &FGViewMgr::setView);
fgSetArchivable("/sim/current-view/view-number", FALSE);
@ -338,45 +233,24 @@ FGViewMgr::unbind ()
void
FGViewMgr::update (double dt)
{
char stridx [20];
string viewpath, nodepath;
double lon_deg, lat_deg, alt_ft, roll_deg, pitch_deg, heading_deg;
FGViewer * view = get_current_view();
if (view == 0)
return;
//
int i = current;
viewpath = "/sim/view";
sprintf(stridx, "[%d]", i);
viewpath += stridx;
FGViewer *loop_view = (FGViewer *)get_view(current);
SGPropertyNode *n = config_list[current];
double lon_deg, lat_deg, alt_ft, roll_deg, pitch_deg, heading_deg;
FGViewer *loop_view = (FGViewer *)get_view( i );
// Set up view location and orientation
// Set up view location and orientation
if (!n->getBoolValue("config/from-model")) {
lon_deg = fgGetDouble(n->getStringValue("config/eye-lon-deg-path"));
lat_deg = fgGetDouble(n->getStringValue("config/eye-lat-deg-path"));
alt_ft = fgGetDouble(n->getStringValue("config/eye-alt-ft-path"));
roll_deg = fgGetDouble(n->getStringValue("config/eye-roll-deg-path"));
pitch_deg = fgGetDouble(n->getStringValue("config/eye-pitch-deg-path"));
heading_deg = fgGetDouble(n->getStringValue("config/eye-heading-deg-path"));
nodepath = viewpath;
nodepath += "/config/from-model";
if (!fgGetBool(nodepath.c_str())) {
nodepath = viewpath;
nodepath += "/config/eye-lon-deg-path";
lon_deg = fgGetDouble(fgGetString(nodepath.c_str()));
nodepath = viewpath;
nodepath += "/config/eye-lat-deg-path";
lat_deg = fgGetDouble(fgGetString(nodepath.c_str()));
nodepath = viewpath;
nodepath += "/config/eye-alt-ft-path";
alt_ft = fgGetDouble(fgGetString(nodepath.c_str()));
nodepath = viewpath;
nodepath += "/config/eye-roll-deg-path";
roll_deg = fgGetDouble(fgGetString(nodepath.c_str()));
nodepath = viewpath;
nodepath += "/config/eye-pitch-deg-path";
pitch_deg = fgGetDouble(fgGetString(nodepath.c_str()));
nodepath = viewpath;
nodepath += "/config/eye-heading-deg-path";
heading_deg = fgGetDouble(fgGetString(nodepath.c_str()));
loop_view->setPosition(lon_deg, lat_deg, alt_ft);
loop_view->setOrientation(roll_deg, pitch_deg, heading_deg);
} else {
@ -386,27 +260,13 @@ FGViewMgr::update (double dt)
// if lookat (type 1) then get target data...
if (loop_view->getType() == FG_LOOKAT) {
nodepath = viewpath;
nodepath += "/config/from-model";
if (!fgGetBool(nodepath.c_str())) {
nodepath = viewpath;
nodepath += "/config/target-lon-deg-path";
lon_deg = fgGetDouble(fgGetString(nodepath.c_str()));
nodepath = viewpath;
nodepath += "/config/target-lat-deg-path";
lat_deg = fgGetDouble(fgGetString(nodepath.c_str()));
nodepath = viewpath;
nodepath += "/config/target-alt-ft-path";
alt_ft = fgGetDouble(fgGetString(nodepath.c_str()));
nodepath = viewpath;
nodepath += "/config/target-roll-deg-path";
roll_deg = fgGetDouble(fgGetString(nodepath.c_str()));
nodepath = viewpath;
nodepath += "/config/target-pitch-deg-path";
pitch_deg = fgGetDouble(fgGetString(nodepath.c_str()));
nodepath = viewpath;
nodepath += "/config/target-heading-deg-path";
heading_deg = fgGetDouble(fgGetString(nodepath.c_str()));
if (!n->getBoolValue("config/from-model")) {
lon_deg = fgGetDouble(n->getStringValue("config/target-lon-deg-path"));
lat_deg = fgGetDouble(n->getStringValue("config/target-lat-deg-path"));
alt_ft = fgGetDouble(n->getStringValue("config/target-alt-ft-path"));
roll_deg = fgGetDouble(n->getStringValue("config/target-roll-deg-path"));
pitch_deg = fgGetDouble(n->getStringValue("config/target-pitch-deg-path"));
heading_deg = fgGetDouble(n->getStringValue("config/target-heading-deg-path"));
loop_view->setTargetPosition(lon_deg, lat_deg, alt_ft);
loop_view->setTargetOrientation(roll_deg, pitch_deg, heading_deg);
@ -423,7 +283,7 @@ FGViewMgr::update (double dt)
setViewTargetYOffset_m(fgGetDouble("/sim/current-view/target-y-offset-m"));
setViewTargetZOffset_m(fgGetDouble("/sim/current-view/target-z-offset-m"));
// Update the current view
// Update the current view
do_axes();
view->update(dt);
}
@ -431,45 +291,25 @@ FGViewMgr::update (double dt)
void
FGViewMgr::copyToCurrent()
{
char stridx [20];
string viewpath, nodepath;
int i = current;
viewpath = "/sim/view";
sprintf(stridx, "[%d]", i);
viewpath += stridx;
SGPropertyNode *n = config_list[current];
// copy certain view config data for default values
nodepath = viewpath;
nodepath += "/config/default-heading-offset-deg";
fgSetDouble("/sim/current-view/config/heading-offset-deg",
fgGetDouble(nodepath.c_str()));
nodepath = viewpath;
nodepath += "/config/pitch-offset-deg";
n->getDoubleValue("config/default-heading-offset-deg"));
fgSetDouble("/sim/current-view/config/pitch-offset-deg",
fgGetDouble(nodepath.c_str()));
nodepath = viewpath;
nodepath += "/config/roll-offset-deg";
n->getDoubleValue("config/pitch-offset-deg"));
fgSetDouble("/sim/current-view/config/roll-offset-deg",
fgGetDouble(nodepath.c_str()));
nodepath = viewpath;
nodepath += "/config/default-field-of-view-deg";
n->getDoubleValue("config/roll-offset-deg"));
fgSetDouble("/sim/current-view/config/default-field-of-view-deg",
fgGetDouble(nodepath.c_str()));
nodepath = viewpath;
nodepath += "/config/from-model";
n->getDoubleValue("config/default-field-of-view-deg"));
fgSetBool("/sim/current-view/config/from-model",
fgGetBool(nodepath.c_str()));
n->getBoolValue("config/from-model"));
// copy view data
fgSetDouble("/sim/current-view/x-offset-m", getViewXOffset_m());
fgSetDouble("/sim/current-view/y-offset-m", getViewYOffset_m());
fgSetDouble("/sim/current-view/z-offset-m", getViewZOffset_m());
fgSetDouble("/sim/current-view/goal-heading-offset-deg",
get_current_view()->getGoalHeadingOffset_deg());
fgSetDouble("/sim/current-view/goal-pitch-offset-deg",
@ -488,10 +328,8 @@ FGViewMgr::copyToCurrent()
get_current_view()->getTargetYOffset_m());
fgSetDouble("/sim/current-view/target-z-offset-m",
get_current_view()->getTargetZOffset_m());
fgSetBool("/sim/current-view/internal",
get_current_view()->getInternal());
}
@ -718,20 +556,31 @@ FGViewMgr::getView () const
}
void
FGViewMgr::setView (int newview )
FGViewMgr::setView (int newview)
{
// negative numbers -> set view with node index -newview
if (newview < 0) {
for (int i = 0; i < (int)config_list.size(); i++) {
int index = -config_list[i]->getIndex();
if (index == newview)
newview = i;
}
if (newview < 0)
return;
}
// if newview number too low wrap to last view...
if ( newview < 0 ) {
if (newview < 0)
newview = (int)views.size() -1;
}
// if newview number to high wrap to zero...
if ( newview > ((int)views.size() -1) ) {
if (newview > ((int)views.size() -1))
newview = 0;
}
// set new view
set_view( newview );
set_view(newview);
// copy in view data
copyToCurrent ();
copyToCurrent();
// Copy the fdm's position into the SGLocation which is shared with
// some views ...

View file

@ -24,11 +24,7 @@
#ifndef _VIEWMGR_HXX
#define _VIEWMGR_HXX
#ifndef __cplusplus
# error This library requires C++
#endif
#include <vector>
#include <simgear/compiler.h>
#include <simgear/structure/subsystem_mgr.hxx>
@ -37,8 +33,7 @@
# include <config.h>
#endif
#include <vector>
#include "fg_props.hxx"
#include "viewer.hxx"
SG_USING_STD(vector);
@ -151,7 +146,8 @@ private:
int getView () const;
void setView (int newview);
typedef vector < FGViewer * > viewer_list;
vector<SGPropertyNode_ptr> config_list;
typedef vector<FGViewer *> viewer_list;
viewer_list views;
int current;