Skip to content
Snippets Groups Projects
QGCXPlaneLink.h 6.26 KiB
Newer Older
  • Learn to ignore specific revisions
  • /****************************************************************************
     *
     *   (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.
     *
     ****************************************************************************/
    
    
    
    /**
     * @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>
    
    #include "Vehicle.h"
    
    
    class QGCXPlaneLink : public QGCHilLink
    {
        Q_OBJECT
        //Q_INTERFACES(QGCXPlaneLinkInterface:LinkInterface)
    
    public:
    
    Bart Slinger's avatar
    Bart Slinger committed
        QGCXPlaneLink(Vehicle* vehicle, QString remoteHost=QString("127.0.0.1:49000"), QHostAddress localHost = QHostAddress::Any, quint16 localPort = 49005);
    
    Lorenz Meier's avatar
    Lorenz Meier committed
        /**
         * @brief Load X-Plane HIL settings
         */
        void loadSettings();
    
        /**
         * @brief Store X-Plane HIL settings
         */
        void storeSettings();
    
    
    Bart Slinger's avatar
    Bart Slinger committed
        int getPort() const {
    
            return localPort;
    
        }
    
        /**
         * @brief The human readable port name
         */
        QString getName();
    
        void run();
    
    
    Lorenz Meier's avatar
    Lorenz Meier committed
        /**
         * @brief Get remote host and port
         * @return string in format <host>:<port>
         */
        QString getRemoteHost();
    
    
        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
        };
    
    
        QString getVersion()
        {
            return QString("X-Plane %1").arg(xPlaneVersion);
        }
    
        int getAirFrameIndex()
        {
            return (int)airframeID;
        }
    
    
    Bart Slinger's avatar
    Bart Slinger committed
        bool sensorHilEnabled() {
    
    Bart Slinger's avatar
    Bart Slinger committed
        bool useHilActuatorControls() {
    
            return _useHilActuatorControls;
        }
    
    signals:
        /** @brief Sensor leve HIL state changed */
        void useHilActuatorControlsChanged(bool enabled);
    
    
    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
        void setRemoteHost(const QString& host);
    
        /** @brief Send new control states to the simulation */
    
        void updateControls(quint64 time, float rollAilerons, float pitchElevator, float yawRudder, float throttle, quint8 systemMode, quint8 navMode);
    
        /** @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
        /** @brief Set the simulator version as text string */
    
    Bart Slinger's avatar
    Bart Slinger committed
        void setVersion(const QString& version);
    
    Lorenz Meier's avatar
    Lorenz Meier committed
        /** @brief Set the simulator version as integer */
        void setVersion(unsigned int version);
    
    Bart Slinger's avatar
    Bart Slinger committed
        void enableSensorHIL(bool enable) {
    
            if (enable != _sensorHilEnabled)
                _sensorHilEnabled = enable;
    
    Bart Slinger's avatar
    Bart Slinger committed
                emit sensorHilChanged(enable);
    
        void enableHilActuatorControls(bool enable);
    
    
        void processError(QProcess::ProcessError err);
    
        void readBytes();
    
        /**
         * @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
         **/
    
        void _writeBytes(const QByteArray data);
    
        bool connectSimulation();
        bool disconnectSimulation();
    
        /**
         * @brief Select airplane model
         * @param plane the name of the airplane
         */
    
    Bart Slinger's avatar
    Bart Slinger committed
        void selectAirframe(const QString& airframe);
    
        /**
         * @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();
    
    Bart Slinger's avatar
    Bart Slinger committed
        Vehicle* _vehicle;
    
        QHostAddress localHost;
        quint16 localPort;
        QHostAddress remoteHost;
        quint16 remotePort;
    
    Bart Slinger's avatar
    Bart Slinger committed
        QUdpSocket* socket;
    
        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
        QProcess* process;
        QProcess* terraSync;
    
        bool gpsReceived;
        bool attitudeReceived;
    
    
        float roll, pitch, yaw, rollspeed, pitchspeed, yawspeed;
    
        float vx, vy, vz, xacc, yacc, zacc;
    
        float ind_airspeed;
        float true_airspeed;
    
        float groundspeed;
    
    Lorenz Meier's avatar
    Lorenz Meier committed
        float xmag, ymag, zmag, abs_pressure, diff_pressure, pressure_alt, temperature;
    
        float barometerOffsetkPa;
    
    
        float man_roll, man_pitch, man_yaw;
    
        QString airframeName;
        enum AIRFRAME airframeID;
        bool xPlaneConnected;
    
    Lorenz Meier's avatar
    Lorenz Meier committed
        unsigned int xPlaneVersion;
    
        quint64 simUpdateFirst;
    
        quint64 simUpdateLastGroundTruth;
    
        bool _useHilActuatorControls;
    
        bool _should_exit;
    
        void sendDataRef(QString ref, float value);