//
// Written by Curtis Olson, started October 2000.
//
-// Copyright (C) 2000 Curtis L. Olson - curt@flightgear.org
+// Copyright (C) 2000 Curtis L. Olson - http://www.flightgear.org/~curt
//
// This program is free software; you can redistribute it and/or
// modify it under the terms of the GNU General Public License as
#include <simgear/compiler.h>
+#include <simgear/structure/subsystem_mgr.hxx>
#ifdef HAVE_CONFIG_H
# include <config.h>
#include <vector>
-#include "fgfs.hxx"
#include "viewer.hxx"
SG_USING_STD(vector);
// Define a structure containing view information
-class FGViewMgr : public FGSubsystem
+class FGViewMgr : public SGSubsystem
{
public:
return views[i];
}
inline FGViewer *next_view() {
- ++current;
- if ( current >= (int)views.size() ) {
- current = 0;
- }
- copyToCurrent();
+ setView((current+1 < (int)views.size()) ? (current + 1) : 0);
return views[current];
}
inline FGViewer *prev_view() {
- --current;
- if ( current < 0 ) {
- current = views.size() - 1;
- }
+ setView((0 < current) ? (current - 1) : (views.size() - 1));
return views[current];
}
double getViewPitchOffset_deg () const;
void setViewPitchOffset_deg (double tilt);
double getGoalViewPitchOffset_deg () const;
+ void setGoalViewRollOffset_deg (double tilt);
+ double getViewRollOffset_deg () const;
+ void setViewRollOffset_deg (double tilt);
+ double getGoalViewRollOffset_deg () const;
void setGoalViewPitchOffset_deg (double tilt);
double getViewXOffset_m () const;
void setViewXOffset_m (double x);
void setViewTargetZOffset_m (double z);
double getFOV_deg () const;
void setFOV_deg (double fov);
+ double getARM_deg () const; // Aspect Ratio Multiplier
+ void setARM_deg (double fov);
double getNear_m () const;
void setNear_m (double near_m);
void setViewAxisLong (double axis);