QGCMAVLinkInspector.h 3.11 KB
Newer Older
lm's avatar
lm committed
1 2 3 4 5 6
#ifndef QGCMAVLINKINSPECTOR_H
#define QGCMAVLINKINSPECTOR_H

#include <QMap>
#include <QTimer>

7
#include "QGCDockWidget.h"
lm's avatar
lm committed
8
#include "MAVLinkProtocol.h"
9
#include "Vehicle.h"
lm's avatar
lm committed
10 11 12 13 14 15

namespace Ui {
    class QGCMAVLinkInspector;
}

class QTreeWidgetItem;
LM's avatar
LM committed
16
class UASInterface;
lm's avatar
lm committed
17

18
class QGCMAVLinkInspector : public QGCDockWidget
lm's avatar
lm committed
19 20 21 22
{
    Q_OBJECT

public:
23
    explicit QGCMAVLinkInspector(const QString& title, QAction* action, MAVLinkProtocol* protocol, QWidget *parent = 0);
lm's avatar
lm committed
24 25 26 27
    ~QGCMAVLinkInspector();

public slots:
    void receiveMessage(LinkInterface* link,mavlink_message_t message);
28 29
    /** @brief Clear all messages */
    void clearView();
30
    /** @brief Update view */
lm's avatar
lm committed
31
    void refreshView();
32
    /** @brief Add component to the list */
LM's avatar
LM committed
33 34 35 36 37
    void addComponent(int uas, int component, const QString& name);
    /** @Brief Select a system through the drop down menu */
    void selectDropDownMenuSystem(int dropdownid);
    /** @Brief Select a component through the drop down menu */
    void selectDropDownMenuComponent(int dropdownid);
lm's avatar
lm committed
38

39 40
    void rateTreeItemChanged(QTreeWidgetItem* paramItem, int column);

lm's avatar
lm committed
41
protected:
42
    MAVLinkProtocol *_protocol;     ///< MAVLink instance
LM's avatar
LM committed
43 44
    int selectedSystemID;          ///< Currently selected system
    int selectedComponentID;       ///< Currently selected component
45 46 47 48
    QMap<int, int> systems;     ///< Already observed systems
    QMap<int, int> components; ///< Already observed components
    QMap<int, float> onboardMessageInterval; ///< Stores the onboard selected data rate
    QMap<int, QTreeWidgetItem*> rateTreeWidgetItems; ///< Available rate tree widget items
lm's avatar
lm committed
49
    QTimer updateTimer; ///< Only update at 1 Hz to not overload the GUI
50
    mavlink_message_info_t messageInfo[256]; // Store the metadata for all available MAVLink messages.
lm's avatar
lm committed
51

52 53 54
    QMap<int, QTreeWidgetItem* > uasTreeWidgetItems; ///< Tree of available uas with their widget
    QMap<int, QMap<int, QTreeWidgetItem*>* > uasMsgTreeItems; ///< Stores the widget of the received message for each UAS

55 56
    QMap<int, mavlink_message_t* > uasMessageStorage; ///< Stores the messages for every UAS

57 58 59 60 61 62 63
    QMap<int, QMap<int, float>* > uasMessageHz; ///< Stores the frequency of each message of each UAS
    QMap<int, QMap<int, unsigned int>* > uasMessageCount; ///< Stores the message count of each message of each UAS

    QMap<int, QMap<int, quint64>* > uasLastMessageUpdate; ///< Stores the time of the last message for each message of each UAS

    /* @brief Update one message field */
    void updateField(int sysid, int msgid, int fieldid, QTreeWidgetItem* item);
LM's avatar
LM committed
64 65
    /** @brief Rebuild the list of components */
    void rebuildComponentList();
66 67
    /** @brief Change the stream interval */
    void changeStreamInterval(int msgid, int interval);
68 69
    /* @brief Create a new tree for a new UAS */
    void addUAStoTree(int sysId);
lm's avatar
lm committed
70

71 72
    static const unsigned int updateInterval; ///< The update interval of the refresh function
    static const float updateHzLowpass; ///< The low-pass filter value for the frequency of each message
73 74 75
    
private slots:
    void _vehicleAdded(Vehicle* vehicle);
LM's avatar
LM committed
76

lm's avatar
lm committed
77 78 79 80 81
private:
    Ui::QGCMAVLinkInspector *ui;
};

#endif // QGCMAVLINKINSPECTOR_H