#include "Aerodynamics_output.hpp" const std::string XNSim::C909::ATA04::Aerodynamics_output_Interface::topic_name = "XNSim::C909::ATA04::Aerodynamics_output"; namespace XNSim::C909::ATA04 { Aerodynamics_output_Interface::Aerodynamics_output_Interface() { MAP_DATA_FUNC(l_04_o_aerocomac_fxb_f8); MAP_DATA_FUNC(l_04_o_aerocomac_fyb_f8); MAP_DATA_FUNC(l_04_o_aerocomac_fzb_f8); MAP_DATA_FUNC(l_04_o_aerocomac_mxb_f8); MAP_DATA_FUNC(l_04_o_aerocomac_myb_f8); MAP_DATA_FUNC(l_04_o_aerocomac_mzb_f8); MAP_DATA_FUNC(l_04_o_aerocomac_cls_f8); MAP_DATA_FUNC(l_04_o_aerocomac_cl_f8); MAP_DATA_FUNC(l_04_o_aerocomac_cd_f8); MAP_DATA_FUNC(l_04_o_aerocomac_cm_f8); MAP_DATA_FUNC(l_04_o_aerocomac_cr_f8); MAP_DATA_FUNC(l_04_o_aerocomac_cy_f8); MAP_DATA_FUNC(l_04_o_aerocomac_cn_f8); } Aerodynamics_output_Interface::~Aerodynamics_output_Interface() { } void Aerodynamics_output_Interface::Initialize(XNFrameworkPtr framework, uint32_t modelId,uint32_t DDS_type) { auto ddsManager = framework->GetDDSManager(); if (!ddsManager) { LOG_ERROR("DDSManager is nullptr"); return; } if (DDS_type == 0) { dataWriter = ddsManager->RegisterPublisher("XNSim::C909::ATA04::Aerodynamics_output", modelId); ddsManager->RegisterSubscriber("XNSim::C909::ATA04::Aerodynamics_output", modelId, std::bind(&Aerodynamics_output_Interface::inputDataListener, this, std::placeholders::_1)); } else if (DDS_type == 1) { ddsManager->RegisterSubscriber("XNSim::C909::ATA04::Aerodynamics_output", modelId, std::bind(&Aerodynamics_output_Interface::inputDataListener, this, std::placeholders::_1)); } else if (DDS_type == 2) { dataWriter = ddsManager->RegisterPublisher("XNSim::C909::ATA04::Aerodynamics_output", modelId); } } void Aerodynamics_output_Interface::clearOutData() { this->out_data = XNSim::C909::ATA04::Aerodynamics_output(); } void Aerodynamics_output_Interface::sendOutData() { if (dataWriter) { dataWriter->write(&this->out_data); } } void Aerodynamics_output_Interface::inputDataListener(const XNSim::C909::ATA04::Aerodynamics_output &input) { this->data = input; } }