2001-12-01 06:22:24 +00:00
|
|
|
#ifndef _CONTROL_MAP_HPP
|
|
|
|
#define _CONTROL_MAP_HPP
|
|
|
|
|
2001-12-06 18:16:22 +00:00
|
|
|
#include "Vector.hpp"
|
2001-12-01 06:22:24 +00:00
|
|
|
|
|
|
|
namespace yasim {
|
|
|
|
|
|
|
|
class ControlMap {
|
|
|
|
public:
|
|
|
|
~ControlMap();
|
|
|
|
|
2004-07-20 22:17:58 +00:00
|
|
|
enum OutputType { THROTTLE, MIXTURE, CONDLEVER, STARTER, MAGNETOS,
|
2002-02-20 04:27:22 +00:00
|
|
|
ADVANCE, REHEAT, PROP,
|
2004-12-27 13:18:29 +00:00
|
|
|
BRAKE, STEER, EXTEND, HEXTEND, LEXTEND,
|
2001-12-24 13:54:03 +00:00
|
|
|
INCIDENCE, FLAP0, FLAP1, SLAT, SPOILER, VECTOR,
|
2004-07-20 22:17:58 +00:00
|
|
|
BOOST, CASTERING, PROPPITCH, PROPFEATHER,
|
2004-01-30 23:21:26 +00:00
|
|
|
COLLECTIVE, CYCLICAIL, CYCLICELE, ROTORENGINEON,
|
2006-08-14 21:59:44 +00:00
|
|
|
ROTORBRAKE,
|
2006-02-27 23:35:02 +00:00
|
|
|
REVERSE_THRUST, WASTEGATE };
|
2001-12-01 06:22:24 +00:00
|
|
|
|
2001-12-07 20:00:59 +00:00
|
|
|
enum { OPT_SPLIT = 0x01,
|
|
|
|
OPT_INVERT = 0x02,
|
|
|
|
OPT_SQUARE = 0x04 };
|
2001-12-01 06:22:24 +00:00
|
|
|
|
|
|
|
// Returns a new, not-yet-used "input handle" for addMapping and
|
|
|
|
// setInput. This typically corresponds to one user axis.
|
|
|
|
int newInput();
|
|
|
|
|
|
|
|
// Adds a mapping to between input handle and a particular setting
|
|
|
|
// on an output object. The value of output MUST match the type
|
|
|
|
// of object!
|
|
|
|
void addMapping(int input, int output, void* object, int options=0);
|
|
|
|
|
2001-12-24 13:54:03 +00:00
|
|
|
// An additional form to specify a mapping range. Input values
|
|
|
|
// outside of [src0:src1] are clamped, and are then mapped to
|
|
|
|
// [dst0:dst1] before being set on the object.
|
|
|
|
void addMapping(int input, int output, void* object, int options,
|
|
|
|
float src0, float src1, float dst0, float dst1);
|
|
|
|
|
2001-12-01 06:22:24 +00:00
|
|
|
// Resets our accumulated input values. Call before any
|
|
|
|
// setInput() invokations.
|
|
|
|
void reset();
|
|
|
|
|
|
|
|
// Sets the specified input (as returned by newInput) to the
|
|
|
|
// specified value.
|
|
|
|
void setInput(int input, float value);
|
|
|
|
|
|
|
|
// Calculates and applies the settings received since the last reset().
|
2002-03-01 06:47:28 +00:00
|
|
|
void applyControls(float dt);
|
|
|
|
|
|
|
|
// Returns the input/output range appropriate for the given
|
|
|
|
// control. Ailerons go from -1 to 1, while throttles are never
|
|
|
|
// lower than zero, etc...
|
|
|
|
static float rangeMin(int type);
|
|
|
|
static float rangeMax(int type);
|
|
|
|
|
|
|
|
// Each output record is identified by both an object/type tuple
|
|
|
|
// and a numeric handle.
|
|
|
|
int getOutputHandle(void* obj, int type);
|
|
|
|
|
|
|
|
// Sets the transition time for the control output to swing
|
|
|
|
// through its full range.
|
|
|
|
void setTransitionTime(int handle, float time);
|
|
|
|
|
|
|
|
// Retrieves the current value of the control output. Controls
|
|
|
|
// with OPT_SPLIT settable on inputs will have a separately
|
|
|
|
// computed "right side" value.
|
|
|
|
float getOutput(int handle);
|
|
|
|
float getOutputR(int handle);
|
2001-12-01 06:22:24 +00:00
|
|
|
|
|
|
|
private:
|
2002-03-01 06:47:28 +00:00
|
|
|
struct OutRec { int type; void* object; Vector maps;
|
|
|
|
float oldL, oldR, time; };
|
2001-12-24 13:54:03 +00:00
|
|
|
struct MapRec { OutRec* out; int idx; int opt; float val;
|
|
|
|
float src0; float src1; float dst0; float dst1; };
|
2001-12-01 06:22:24 +00:00
|
|
|
|
|
|
|
// A list of (sub)Vectors containing a bunch of MapRec objects for
|
|
|
|
// each input handle.
|
|
|
|
Vector _inputs;
|
|
|
|
|
|
|
|
// An unordered list of output settings.
|
|
|
|
Vector _outputs;
|
|
|
|
};
|
|
|
|
|
|
|
|
}; // namespace yasim
|
|
|
|
#endif // _CONTROL_MAP_HPP
|