Skip to content
Snippets Groups Projects
MAVLinkProtocol.h 3.94 KiB
Newer Older
  • Learn to ignore specific revisions
  • pixhawk's avatar
    pixhawk committed
    /*=====================================================================
    
    
    pixhawk's avatar
    pixhawk committed
    QGroundControl Open Source Ground Control Station
    
    pixhawk's avatar
    pixhawk committed
    
    
    pixhawk's avatar
    pixhawk committed
    (c) 2009, 2010 QGROUNDCONTROL PROJECT <http://www.qgroundcontrol.org>
    
    pixhawk's avatar
    pixhawk committed
    
    
    pixhawk's avatar
    pixhawk committed
    This file is part of the QGROUNDCONTROL project
    
    pixhawk's avatar
    pixhawk committed
    
    
    pixhawk's avatar
    pixhawk committed
        QGROUNDCONTROL is free software: you can redistribute it and/or modify
    
    pixhawk's avatar
    pixhawk committed
        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.
    
    
    pixhawk's avatar
    pixhawk committed
        QGROUNDCONTROL is distributed in the hope that it will be useful,
    
    pixhawk's avatar
    pixhawk committed
        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
    
    pixhawk's avatar
    pixhawk committed
        along with QGROUNDCONTROL. If not, see <http://www.gnu.org/licenses/>.
    
    pixhawk's avatar
    pixhawk committed
    
    ======================================================================*/
    
    /**
     * @file
    
    pixhawk's avatar
    pixhawk committed
     *   @brief Definition of class MAVLinkProtocol
     *   @author Lorenz Meier <mail@qgroundcontrol.org>
    
    pixhawk's avatar
    pixhawk committed
     */
    
    #ifndef MAVLINKPROTOCOL_H_
    #define MAVLINKPROTOCOL_H_
    
    #include <QObject>
    #include <QMutex>
    #include <QString>
    #include <QTimer>
    
    lm's avatar
    lm committed
    #include <QFile>
    
    lm's avatar
    lm committed
    #include <QMap>
    
    pixhawk's avatar
    pixhawk committed
    #include <QByteArray>
    #include "ProtocolInterface.h"
    #include "LinkInterface.h"
    
    pixhawk's avatar
    pixhawk committed
    #include "QGCMAVLink.h"
    
    pixhawk's avatar
    pixhawk committed
    
    /**
    
    pixhawk's avatar
    pixhawk committed
     * @brief MAVLink micro air vehicle protocol reference implementation.
    
    pixhawk's avatar
    pixhawk committed
     *
    
    pixhawk's avatar
    pixhawk committed
     * MAVLink is a generic communication protocol for micro air vehicles.
     * for more information, please see the official website.
     * @ref http://pixhawk.ethz.ch/software/mavlink/
    
    pixhawk's avatar
    pixhawk committed
     **/
    class MAVLinkProtocol : public ProtocolInterface {
        Q_OBJECT
    
    public:
        MAVLinkProtocol();
        ~MAVLinkProtocol();
    
        void run();
        /** @brief Get the human-friendly name of this protocol */
        QString getName();
    
        /** @brief Get the system id of this application */
        int getSystemId();
        /** @brief Get the component id of this application */
        int getComponentId();
    
    pixhawk's avatar
    pixhawk committed
        /** @brief The auto heartbeat emission rate in Hertz */
        int getHeartbeatRate();
        /** @brief Get heartbeat state */
        bool heartbeatsEnabled(void);
    
    lm's avatar
    lm committed
        /** @brief Get logging state */
        bool loggingEnabled(void);
    
    pixhawk's avatar
    pixhawk committed
        /** @brief Get the name of the packet log file */
    
        static QString getLogfileName();
    
    pixhawk's avatar
    pixhawk committed
    
    public slots:
        /** @brief Receive bytes from a communication interface */
    
        void receiveBytes(LinkInterface* link, QByteArray b);
    
    pixhawk's avatar
    pixhawk committed
        /** @brief Send MAVLink message through serial interface */
        void sendMessage(mavlink_message_t message);
        /** @brief Send MAVLink message through serial interface */
        void sendMessage(LinkInterface* link, mavlink_message_t message);
        /** @brief Set the rate at which heartbeats are emitted */
        void setHeartbeatRate(int rate);
    
        /** @brief Enable / disable the heartbeat emission */
        void enableHeartbeats(bool enabled);
    
    
    lm's avatar
    lm committed
        /** @brief Enable/disable binary packet logging */
        void enableLogging(bool enabled);
    
    
    pixhawk's avatar
    pixhawk committed
        /** @brief Send an extra heartbeat to all connected units */
        void sendHeartbeat();
    
    protected:
    
    lm's avatar
    lm committed
        QTimer* heartbeatTimer;    ///< Timer to emit heartbeats
        int heartbeatRate;         ///< Heartbeat rate, controls the timer interval
    
    pixhawk's avatar
    pixhawk committed
        bool m_heartbeatsEnabled;  ///< Enabled/disable heartbeat emission
    
    lm's avatar
    lm committed
        bool m_loggingEnabled;     ///< Enable/disable packet logging
        QFile* m_logfile;           ///< Logfile
        QMutex receiveMutex;       ///< Mutex to protect receiveBytes function
    
    lm's avatar
    lm committed
        int lastIndex[256][256];
    
    lm's avatar
    lm committed
        int totalReceiveCounter;
        int totalLossCounter;
    
        int currReceiveCounter;
        int currLossCounter;
    
    pixhawk's avatar
    pixhawk committed
    
    signals:
        /** @brief Message received and directly copied via signal */
        void messageReceived(LinkInterface* link, mavlink_message_t message);
        /** @brief Emitted if heartbeat emission mode is changed */
        void heartbeatChanged(bool heartbeats);
    
    lm's avatar
    lm committed
        /** @brief Emitted if logging is started / stopped */
        void loggingChanged(bool enabled);
    
    pixhawk's avatar
    pixhawk committed
    };
    
    #endif // MAVLINKPROTOCOL_H_