1
0
mirror of https://bitbucket.org/librepilot/librepilot.git synced 2025-01-23 08:52:10 +01:00

147 lines
4.1 KiB
C
Raw Normal View History

/**
******************************************************************************
*
* @file il2bridge.h
* @author The OpenPilot Team, http://www.openpilot.org Copyright (C) 2010.
* @brief
* @see The GNU Public License (GPL) Version 3
* @defgroup hitlil2plugin
* @{
*
*****************************************************************************/
/*
* 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 3 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.,
* 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
*/
#ifndef IL2BRIDGE_H
#define IL2BRIDGE_H
#include <QObject>
#include <QUdpSocket>
#include <QTimer>
#include <QTime>
#include <QMessageBox>
#include <math.h>
#include "uavtalk/telemetrymanager.h"
#include "uavobjects/uavobjectmanager.h"
#include "uavobjects/actuatordesired.h"
#include "uavobjects/altitudeactual.h"
#include "uavobjects/attitudeactual.h"
#include "uavobjects/positionactual.h"
#include "uavobjects/gcstelemetrystats.h"
/**
* just imagine this was a class without methods and all public properties
*/
struct flightParams {
// time
float T;
float dT;
// speed (relative)
float ias;
float tas;
float groundspeed;
// position (absolute)
float X;
float Y;
float Z;
// speed (absolute)
float dX;
float dY;
float dZ;
//angle
float azimuth;
float pitch;
float roll;
};
class Il2Bridge: public QObject
{
Q_OBJECT
public:
Il2Bridge(QString il2HostName, int il2Port);
~Il2Bridge();
bool isAutopilotConnected();
bool isIl2Connected();
signals:
void autopilotConnected();
void autopilotDisconnected();
void il2Connected();
void il2Disconnected();
private slots:
void transmitUpdate();
void receiveUpdate();
void onAutopilotConnect();
void onAutopilotDisconnect();
void onIl2ConnectionTimeout();
void telStatsUpdated(UAVObject* obj);
private:
static const float FT2M = 0.3048;
static const float KT2MPS = 0.514444444;
static const float MPS2KMH = 3.6;
static const float KMH2MPS = (1.0/3.6);
static const float INHG2KPA = 3.386;
static const float RAD2DEG = (180.0/M_PI);
static const float DEG2RAD = (M_PI/180.0);
static const float M2DEG = 60.*1852.; // 60 miles per degree times 1852 meters per mile
static const float DEG2M = (1.0/(60.*1852.));
static const float AIR_CONST = 287.058; // J/(kg*K)
static const float GROUNDDENSITY = 1.225; // kg/m³ ;)
static const float TEMP_GROUND = (15.0 + 273.0); // 15°C in Kelvin
static const float TEMP_LAPSE_RATE = -0.0065; //degrees per meter
static const float AIR_CONST_FACTOR = -0.0341631947363104; //several nature constants calculated into one
struct flightParams current;
struct flightParams old;
QUdpSocket* outSocket;
ActuatorDesired* actDesired;
AltitudeActual* altActual;
AttitudeActual* attActual;
PositionActual* posActual;
GCSTelemetryStats* telStats;
QHostAddress il2Host;
int outPort;
int updatePeriod;
QTimer* txTimer;
QTimer* il2Timer;
QTime* time;
bool autopilotConnectionStatus;
bool il2ConnectionStatus;
int il2Timeout;
float DENSITY(float pressure);
float PRESSURE(float alt);
float TAS(float ias,float alt);
void processUpdate(QString& data);
void setupOutputObject(UAVObject* obj, int updatePeriod);
void setupInputObject(UAVObject* obj, int updatePeriod);
void setupObjects();
};
#endif // IL2BRIDGE_H