From c67311c8eee52cc6765b38a18604c99b98f2bf48 Mon Sep 17 00:00:00 2001 From: hitchcock9307 Date: Wed, 1 May 2024 05:07:47 -0500 Subject: [PATCH] Added the ability to dynamically change thrusters location via property (#1073) --- src/models/propulsion/FGForce.h | 6 +++--- src/models/propulsion/FGThruster.cpp | 13 +++++++++++++ 2 files changed, 16 insertions(+), 3 deletions(-) diff --git a/src/models/propulsion/FGForce.h b/src/models/propulsion/FGForce.h index 84e3bc7543..8859b755b3 100644 --- a/src/models/propulsion/FGForce.h +++ b/src/models/propulsion/FGForce.h @@ -261,9 +261,9 @@ class JSBSIM_API FGForce : public FGJSBBase inline void SetLocationX(double x) {vXYZn(eX) = x; vActingXYZn(eX) = x;} inline void SetLocationY(double y) {vXYZn(eY) = y; vActingXYZn(eY) = y;} inline void SetLocationZ(double z) {vXYZn(eZ) = z; vActingXYZn(eZ) = z;} - inline double SetActingLocationX(double x) {vActingXYZn(eX) = x; return x;} - inline double SetActingLocationY(double y) {vActingXYZn(eY) = y; return y;} - inline double SetActingLocationZ(double z) {vActingXYZn(eZ) = z; return z;} + inline void SetActingLocationX(double x) {vActingXYZn(eX) = x;} + inline void SetActingLocationY(double y) {vActingXYZn(eY) = y;} + inline void SetActingLocationZ(double z) {vActingXYZn(eZ) = z;} inline void SetLocation(const FGColumnVector3& vv) { vXYZn = vv; SetActingLocation(vv);} inline void SetActingLocation(const FGColumnVector3& vv) { vActingXYZn = vv; } diff --git a/src/models/propulsion/FGThruster.cpp b/src/models/propulsion/FGThruster.cpp index d1c9d1de32..601f85bbd4 100644 --- a/src/models/propulsion/FGThruster.cpp +++ b/src/models/propulsion/FGThruster.cpp @@ -79,6 +79,19 @@ FGThruster::FGThruster(FGFDMExec *FDMExec, Element *el, int num ): FGForce(FDMEx string property_name, base_property_name; base_property_name = CreateIndexedPropertyName("propulsion/engine", EngineNum); + property_name = base_property_name + "/x-reference-position"; + PropertyManager->Tie(property_name.c_str(), (FGForce*)this, &FGForce::GetLocationX); + property_name = base_property_name + "/y-reference-position"; + PropertyManager->Tie(property_name.c_str(), (FGForce*)this, &FGForce::GetLocationY); + property_name = base_property_name + "/z-reference-position"; + PropertyManager->Tie(property_name.c_str(), (FGForce*)this, &FGForce::GetLocationZ); + property_name = base_property_name + "/x-position"; + PropertyManager->Tie(property_name.c_str(), (FGForce*)this, &FGForce::GetActingLocationX, &FGForce::SetActingLocationX); + property_name = base_property_name + "/y-position"; + PropertyManager->Tie(property_name.c_str(), (FGForce*)this, &FGForce::GetActingLocationY, &FGForce::SetActingLocationY); + property_name = base_property_name + "/z-position"; + PropertyManager->Tie(property_name.c_str(), (FGForce*)this, &FGForce::GetActingLocationZ, &FGForce::SetActingLocationZ); + element = thruster_element->FindElement("pointing"); if (element) {