]> git.mxchange.org Git - flightgear.git/blobdiff - src/FDM/YASim/Model.hpp
Add support for a turbo prop condition lever.
[flightgear.git] / src / FDM / YASim / Model.hpp
index 0a32c63040ab76096868ac0cbcf43fac74b51ba2..a27af5c057b677de2c5bb95a8bd065bfd7441456 100644 (file)
@@ -4,7 +4,8 @@
 #include "Integrator.hpp"
 #include "RigidBody.hpp"
 #include "BodyEnvironment.hpp"
-#include "util/Vector.hpp"
+#include "Vector.hpp"
+#include "Turbulence.hpp"
 
 namespace yasim {
 
@@ -12,6 +13,9 @@ namespace yasim {
 class Integrator;
 class Thruster;
 class Surface;
+class Rotorpart;
+class Rotorblade;
+class Rotor;
 class Gear;
 
 class Model : public BodyEnvironment {
@@ -22,16 +26,28 @@ public:
     RigidBody* getBody();
     Integrator* getIntegrator();
 
+    void setTurbulence(Turbulence* turb) { _turb = turb; }
+
     State* getState();
     void setState(State* s);
 
+    bool isCrashed();
+    void setCrashed(bool crashed);
+    float getAGL();
+
     void iterate();
 
     // Externally-managed subcomponents
     int addThruster(Thruster* t);
     int addSurface(Surface* surf);
+    int addRotorpart(Rotorpart* rpart);
+    int addRotorblade(Rotorblade* rblade);
+    int addRotor(Rotor* rotor);
     int addGear(Gear* gear);
     Surface* getSurface(int handle);
+    Rotorpart* getRotorpart(int handle);
+    Rotorblade* getRotorblade(int handle);
+    Rotor* getRotor(int handle);
     Gear* getGear(int handle);
 
     // Semi-private methods for use by the Airplane solver.
@@ -47,23 +63,29 @@ public:
     void setGroundPlane(double* planeNormal, double fromOrigin);
     void setGroundEffect(float* pos, float span, float mul);
     void setWind(float* wind);
-    void setAir(float pressure, float temp);
+    void setAir(float pressure, float temp, float density);
 
     // BodyEnvironment callbacks
     virtual void calcForces(State* s);
     virtual void newState(State* s);
 
 private:
+    void initRotorIteration();
     void calcGearForce(Gear* g, float* v, float* rot, float* ground);
     float gearFriction(float wgt, float v, Gear* g);
     float localGround(State* s, float* out);
-    void localWind(float* pos, State* s, float* out);
+    void localWind(float* pos, State* s, float* out, float alt);
 
     Integrator _integrator;
     RigidBody _body;
 
+    Turbulence* _turb;
+
     Vector _thrusters;
     Vector _surfaces;
+    Vector _rotorparts;
+    Vector _rotorblades;
+    Vector _rotors;
     Vector _gears;
 
     float _groundEffectSpan;
@@ -71,8 +93,8 @@ private:
     float _wingCenter[3];
 
     double _ground[4];
-    float _P;
-    float _T;
+    float _pressure;
+    float _temp;
     float _rho;
     float _wind[3];
 
@@ -81,6 +103,8 @@ private:
     float _torque[3];
 
     State* _s;
+    bool _crashed;
+    float _agl;
 };
 
 }; // namespace yasim