1 #ifndef _PROPENGINE_HPP
2 #define _PROPENGINE_HPP
4 #include "Thruster.hpp"
11 class PropEngine : public Thruster {
13 PropEngine(Propeller* prop, Engine* eng, float moment);
14 virtual ~PropEngine();
16 void setEngine(Engine* eng) { delete _eng; _eng = eng; }
18 void setMagnetos(int magnetos);
19 void setAdvance(float advance);
20 void setPropPitch(float proppitch);
21 void setVariableProp(float min, float max);
22 void setPropFeather(int state);
23 void setGearRatio(float ratio) { _gearRatio = ratio; }
25 virtual PropEngine* getPropEngine() { return this; }
26 virtual Engine* getEngine() { return _eng; }
27 virtual Propeller* getPropeller() { return _prop; }
30 virtual bool isRunning();
31 virtual bool isCranking();
32 virtual void getThrust(float* out);
33 virtual void getTorque(float* out);
34 virtual void getGyro(float* out);
35 virtual float getFuelFlow();
37 // Runtime instructions
39 virtual void integrate(float dt);
40 virtual void stabilize();
43 void setOmega (float omega);
51 int _magnetos; // 0=off, 1=right, 2=left, 3=both
53 float _advance; // control input, 0-1
57 float _omega; // RPM, in radians/sec
65 #endif // _PROPENGINE_HPP