QGCXPlaneLink.h 6.27 KB
Newer Older
1 2 3 4 5 6 7 8
/****************************************************************************
 *
 *   (c) 2009-2016 QGROUNDCONTROL PROJECT <http://www.qgroundcontrol.org>
 *
 * QGroundControl is licensed according to the terms in the file
 * COPYING.md in the root of the source code directory.
 *
 ****************************************************************************/
9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28


/**
 * @file QGCXPlaneLink.h
 *   @brief X-Plane simulation link
 *   @author Lorenz Meier <mavteam@student.ethz.ch>
 *
 */

#ifndef QGCXPLANESIMULATIONLINK_H
#define QGCXPLANESIMULATIONLINK_H

#include <QString>
#include <QList>
#include <QMap>
#include <QMutex>
#include <QUdpSocket>
#include <QTimer>
#include <QProcess>
#include <LinkInterface.h>
29
#include "QGCConfig.h"
30
#include "QGCHilLink.h"
31
#include "Vehicle.h"
32 33 34 35 36 37 38

class QGCXPlaneLink : public QGCHilLink
{
    Q_OBJECT
    //Q_INTERFACES(QGCXPlaneLinkInterface:LinkInterface)

public:
Bart Slinger's avatar
Bart Slinger committed
39
    QGCXPlaneLink(Vehicle *vehicle, QString remoteHost = QString("127.0.0.1:49000"), QHostAddress localHost = QHostAddress::Any, quint16 localPort = 49005);
40 41
    ~QGCXPlaneLink();

Lorenz Meier's avatar
Lorenz Meier committed
42 43 44 45 46 47 48 49 50 51
    /**
     * @brief Load X-Plane HIL settings
     */
    void loadSettings();

    /**
     * @brief Store X-Plane HIL settings
     */
    void storeSettings();

52 53
    bool isConnected();
    qint64 bytesAvailable();
Bart Slinger's avatar
Bart Slinger committed
54 55
    int getPort() const
    {
56
        return localPort;
57 58 59 60 61 62 63 64 65
    }

    /**
     * @brief The human readable port name
     */
    QString getName();

    void run();

Lorenz Meier's avatar
Lorenz Meier committed
66 67 68 69 70 71
    /**
     * @brief Get remote host and port
     * @return string in format <host>:<port>
     */
    QString getRemoteHost();

72 73 74 75 76 77 78 79 80 81
    enum AIRFRAME
    {
        AIRFRAME_UNKNOWN = 0,
        AIRFRAME_QUAD_DJI_F450_PWM,
        AIRFRAME_QUAD_X_MK_10INCH_I2C,
        AIRFRAME_QUAD_X_ARDRONE,
        AIRFRAME_FIXED_WING_BIXLER_II,
        AIRFRAME_FIXED_WING_BIXLER_II_AILERONS
    };

82 83 84 85 86 87 88 89 90 91
    QString getVersion()
    {
        return QString("X-Plane %1").arg(xPlaneVersion);
    }

    int getAirFrameIndex()
    {
        return (int)airframeID;
    }

Bart Slinger's avatar
Bart Slinger committed
92 93
    bool sensorHilEnabled()
    {
94 95 96
        return _sensorHilEnabled;
    }

Bart Slinger's avatar
Bart Slinger committed
97 98
    bool useHilActuatorControls()
    {
99 100 101 102 103 104 105
        return _useHilActuatorControls;
    }

signals:
    /** @brief Sensor leve HIL state changed */
    void useHilActuatorControlsChanged(bool enabled);

106 107 108 109
public slots:
//    void setAddress(QString address);
    void setPort(int port);
    /** @brief Add a new host to broadcast messages to */
Bart Slinger's avatar
Bart Slinger committed
110
    void setRemoteHost(const QString &host);
111
    /** @brief Send new control states to the simulation */
112
    void updateControls(quint64 time, float rollAilerons, float pitchElevator, float yawRudder, float throttle, quint8 systemMode, quint8 navMode);
113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131
    /** @brief Send new control commands to the simulation */
    void updateActuatorControls(quint64 time, quint64 flags,
                                float ctl_0,
                                float ctl_1,
                                float ctl_2,
                                float ctl_3,
                                float ctl_4,
                                float ctl_5,
                                float ctl_6,
                                float ctl_7,
                                float ctl_8,
                                float ctl_9,
                                float ctl_10,
                                float ctl_11,
                                float ctl_12,
                                float ctl_13,
                                float ctl_14,
                                float ctl_15,
                                quint8 mode);
Lorenz Meier's avatar
Lorenz Meier committed
132
    /** @brief Set the simulator version as text string */
Bart Slinger's avatar
Bart Slinger committed
133
    void setVersion(const QString &version);
Lorenz Meier's avatar
Lorenz Meier committed
134 135
    /** @brief Set the simulator version as integer */
    void setVersion(unsigned int version);
Lorenz Meier's avatar
Lorenz Meier committed
136

Bart Slinger's avatar
Bart Slinger committed
137 138
    void enableSensorHIL(bool enable)
    {
139 140
        if (enable != _sensorHilEnabled)
            _sensorHilEnabled = enable;
Bart Slinger's avatar
Bart Slinger committed
141 142

        emit sensorHilChanged(enable);
Lorenz Meier's avatar
Lorenz Meier committed
143 144
    }

145 146
    void enableHilActuatorControls(bool enable);

147 148 149
    void processError(QProcess::ProcessError err);

    void readBytes();
150 151

private slots:
152 153 154 155 156 157
    /**
     * @brief Write a number of bytes to the interface.
     *
     * @param data Pointer to the data byte array
     * @param size The size of the bytes array
     **/
158
    void _writeBytes(const QByteArray data);
159 160

public slots:
161 162
    bool connectSimulation();
    bool disconnectSimulation();
163 164 165 166
    /**
     * @brief Select airplane model
     * @param plane the name of the airplane
     */
Bart Slinger's avatar
Bart Slinger committed
167
    void selectAirframe(const QString &airframe);
168 169 170 171 172 173 174 175 176 177 178 179 180 181 182 183 184 185 186 187
    /**
     * @brief Set the airplane position and attitude
     * @param lat
     * @param lon
     * @param alt
     * @param roll
     * @param pitch
     * @param yaw
     */
    void setPositionAttitude(double lat, double lon, double alt, double roll, double pitch, double yaw);

    /**
     * @brief Set a random position
     */
    void setRandomPosition();

    /**
     * @brief Set a random attitude
     */
    void setRandomAttitude();
188 189

protected:
Bart Slinger's avatar
Bart Slinger committed
190
    Vehicle *_vehicle;
191
    QString name;
192 193 194 195
    QHostAddress localHost;
    quint16 localPort;
    QHostAddress remoteHost;
    quint16 remotePort;
196
    int id;
Bart Slinger's avatar
Bart Slinger committed
197
    QUdpSocket *socket;
198 199 200 201 202 203 204 205 206 207 208 209
    bool connectState;

    quint64 bitsSentTotal;
    quint64 bitsSentCurrent;
    quint64 bitsSentMax;
    quint64 bitsReceivedTotal;
    quint64 bitsReceivedCurrent;
    quint64 bitsReceivedMax;
    quint64 connectionStartTime;
    QMutex statisticsMutex;
    QMutex dataMutex;
    QTimer refreshTimer;
Bart Slinger's avatar
Bart Slinger committed
210 211
    QProcess *process;
    QProcess *terraSync;
212

213 214 215
    bool gpsReceived;
    bool attitudeReceived;

216
    float roll, pitch, yaw, rollspeed, pitchspeed, yawspeed;
217
    double lat, lon, alt, alt_agl;
218
    float vx, vy, vz, xacc, yacc, zacc;
219 220
    float ind_airspeed;
    float true_airspeed;
221
    float groundspeed;
Lorenz Meier's avatar
Lorenz Meier committed
222
    float xmag, ymag, zmag, abs_pressure, diff_pressure, pressure_alt, temperature;
223
    float barometerOffsetkPa;
224 225

    float man_roll, man_pitch, man_yaw;
226 227 228
    QString airframeName;
    enum AIRFRAME airframeID;
    bool xPlaneConnected;
Lorenz Meier's avatar
Lorenz Meier committed
229
    unsigned int xPlaneVersion;
230
    quint64 simUpdateLast;
231
    quint64 simUpdateFirst;
232
    quint64 simUpdateLastText;
233
    quint64 simUpdateLastGroundTruth;
234
    float simUpdateHz;
235
    bool _sensorHilEnabled;
236
    bool _useHilActuatorControls;
237
    bool _should_exit;
238

239
    void setName(QString name);
240
    void sendDataRef(QString ref, float value);
241 242 243
};

#endif // QGCXPLANESIMULATIONLINK_H