// antenna.hxx -- FGRadioAntenna: class to represent antenna properties // // Written by Adrian Musceac, started December 2011. // // This program is free software; you can redistribute it and/or // modify it under the terms of the GNU General Public License as // published by the Free Software Foundation; either version 2 of the // License, or (at your option) any later version. // // This program is distributed in the hope that it will be useful, but // WITHOUT ANY WARRANTY; without even the implied warranty of // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU // General Public License for more details. // // You should have received a copy of the GNU General Public License // along with this program; if not, write to the Free Software // Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. #ifndef __cplusplus # error This library requires C++ #endif #include #include #include
#include #include using std::string; class FGRadioAntenna { private: void load_antenna_pattern(string type); int _mirror_y; int _mirror_z; int _invert_ground; double _heading_deg; double _elevation_angle_deg; struct AntennaGain { double azimuth; double elevation; double gain; }; SGPath _pattern_file; typedef std::vector AntennaPattern; AntennaPattern _pattern; public: FGRadioAntenna(string type); ~FGRadioAntenna(); double calculate_gain(double bearing, double angle); void set_heading(double heading_deg) {_heading_deg = heading_deg ;}; void set_elevation_angle(double elevation_angle_deg) {_elevation_angle_deg = elevation_angle_deg ;}; };