UASWaypointManager.h 12 KB
Newer Older
pixhawk's avatar
pixhawk committed
1 2
/*=====================================================================

3
QGroundControl Open Source Ground Control Station
pixhawk's avatar
pixhawk committed
4

5
(c) 2009, 2010 QGROUNDCONTROL PROJECT <http://www.qgroundcontrol.org>
pixhawk's avatar
pixhawk committed
6

7
This file is part of the QGROUNDCONTROL project
pixhawk's avatar
pixhawk committed
8

9
    QGROUNDCONTROL is free software: you can redistribute it and/or modify
pixhawk's avatar
pixhawk committed
10 11 12 13
    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.

14
    QGROUNDCONTROL is distributed in the hope that it will be useful,
pixhawk's avatar
pixhawk committed
15 16 17 18 19
    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
20
    along with QGROUNDCONTROL. If not, see <http://www.gnu.org/licenses/>.
pixhawk's avatar
pixhawk committed
21 22 23 24 25 26 27 28 29 30 31

======================================================================*/

/**
 * @file
 *   @brief Definition of the waypoint protocol handler
 *
 *   @author Petri Tanskanen <mavteam@student.ethz.ch>
 *
 */

32 33 34 35
#ifndef UASWAYPOINTMANAGER_H
#define UASWAYPOINTMANAGER_H

#include <QObject>
36
#include <QList>
pixhawk's avatar
pixhawk committed
37
#include <QTimer>
38
#include <QPointer>
39
#include "Waypoint.h"
pixhawk's avatar
pixhawk committed
40
#include "QGCMAVLink.h"
41
class UAS;
42
class UASInterface;
43

44 45 46 47
/**
 * @brief Implementation of the MAVLINK waypoint protocol
 *
 * This class handles the communication with a waypoint manager on the MAV.
48
 * All waypoints are stored in the QList waypoints, modifications can be done with the WaypointList widget.
49 50 51 52
 * Notice that currently the access to the internal waypoint storage is not guarded nor thread-safe. This works as long as no other widget alters the data.
 *
 * See http://qgroundcontrol.org/waypoint_protocol for more information about the protocol and the states.
 */
53 54
class UASWaypointManager : public QObject
{
55
    Q_OBJECT
56 57
private:
    enum WaypointState {
58 59 60
        WP_IDLE = 0,        ///< Waiting for commands
        WP_SENDLIST,        ///< Initial state for sending waypoints to the MAV
        WP_SENDLIST_SENDWPS,///< Sending waypoints
61
        WP_GETLIST,         ///< Initial state for retrieving waypoints from the MAV
62
        WP_GETLIST_GETWPS,  ///< Receiving waypoints
63 64
        WP_CLEARLIST,       ///< Clearing waypoint list on the MAV
        WP_SETCURRENT       ///< Setting new current waypoint on the MAV
65 66 67
    }; ///< The possible states for the waypoint protocol

public:
lm's avatar
lm committed
68
    UASWaypointManager(UAS* uas=NULL);   ///< Standard constructor
LM's avatar
LM committed
69
    ~UASWaypointManager();
70
    bool guidedModeSupported();
71

72
    void goToWaypoint(Waypoint *wp);
pixhawk's avatar
pixhawk committed
73
    /** @name Received message handlers */
74 75
    /*@{*/
    void handleWaypointCount(quint8 systemId, quint8 compId, quint16 count);                            ///< Handles received waypoint count messages
lm's avatar
lm committed
76 77 78 79 80
    void handleWaypoint(quint8 systemId, quint8 compId, mavlink_mission_item_t *wp);                        ///< Handles received waypoint messages
    void handleWaypointAck(quint8 systemId, quint8 compId, mavlink_mission_ack_t *wpa);                ///< Handles received waypoint ack messages
    void handleWaypointRequest(quint8 systemId, quint8 compId, mavlink_mission_request_t *wpr);        ///< Handles received waypoint request messages
    void handleWaypointReached(quint8 systemId, quint8 compId, mavlink_mission_item_reached_t *wpr);        ///< Handles received waypoint reached messages
    void handleWaypointCurrent(quint8 systemId, quint8 compId, mavlink_mission_current_t *wpc);        ///< Handles received set current waypoint messages
81
    /*@}*/
82

83 84 85
    /** @name Remote operations */
    /*@{*/
    void clearWaypointList();                       ///< Sends the waypoint clear all message to the MAV
pixhawk's avatar
pixhawk committed
86 87

    void readWaypoints(bool read_to_edit=false);    ///< Requests the MAV's current waypoint list.
88
    void writeWaypoints();                          ///< Sends the waypoint list to the MAV
89 90
    int setCurrentWaypoint(quint16 seq);            ///< Sends the sequence number of the waypoint that should get the new target waypoint to the UAS
    int setCurrentEditable(quint16 seq);          ///< Changes the current waypoint in edit tab
91 92
    /*@}*/

93
    /** @name Waypoint list operations */
94
    /*@{*/
95
    const QList<Waypoint *> &getWaypointEditableList(void) {
pixhawk's avatar
pixhawk committed
96 97
        return waypointsEditable;    ///< Returns a const reference to the waypoint list.
    }
98
    const QList<Waypoint *> &getWaypointViewOnlyList(void) {
pixhawk's avatar
pixhawk committed
99
        return waypointsViewOnly;    ///< Returns a const reference to the waypoint list.
100
    }
101 102 103
    const QList<Waypoint *> getGlobalFrameWaypointList();  ///< Returns a global waypoint list
    const QList<Waypoint *> getGlobalFrameAndNavTypeWaypointList(); ///< Returns a global waypoint list containing only waypoints suitable for navigation. Actions and other mission items are filtered out.
    const QList<Waypoint *> getNavTypeWaypointList(); ///< Returns a waypoint list containing only waypoints suitable for navigation. Actions and other mission items are filtered out.
104 105
    int getIndexOf(Waypoint* wp);                   ///< Get the index of a waypoint in the list
    int getGlobalFrameIndexOf(Waypoint* wp);    ///< Get the index of a waypoint in the list, counting only global waypoints
lm's avatar
lm committed
106
    int getGlobalFrameAndNavTypeIndexOf(Waypoint* wp); ///< Get the index of a waypoint in the list, counting only global AND navigation mode waypoints
LM's avatar
LM committed
107
    int getNavTypeIndexOf(Waypoint* wp); ///< Get the index of a waypoint in the list, counting only navigation mode waypoints
108 109 110
    int getLocalFrameIndexOf(Waypoint* wp);     ///< Get the index of a waypoint in the list, counting only local waypoints
    int getMissionFrameIndexOf(Waypoint* wp);   ///< Get the index of a waypoint in the list, counting only mission waypoints
    int getGlobalFrameCount(); ///< Get the count of global waypoints in the list
lm's avatar
lm committed
111
    int getGlobalFrameAndNavTypeCount(); ///< Get the count of global waypoints in navigation mode in the list
LM's avatar
LM committed
112
    int getNavTypeCount(); ///< Get the count of global waypoints in navigation mode in the list
113
    int getLocalFrameCount();   ///< Get the count of local waypoints in the list
114
    /*@}*/
115

116 117 118 119 120
    UAS* getUAS();
    float getAltitudeRecommendation();
    int getFrameRecommendation();
    float getAcceptanceRadiusRecommendation();
    float getHomeAltitudeOffsetDefault();
121

122
private:
pixhawk's avatar
pixhawk committed
123 124
    /** @name Message send functions */
    /*@{*/
125 126 127 128
    void sendWaypointClearAll();
    void sendWaypointSetCurrent(quint16 seq);
    void sendWaypointCount();
    void sendWaypointRequestList();
129 130 131
    void sendWaypointRequest(quint16 seq);          ///< Requests a waypoint with sequence number seq
    void sendWaypoint(quint16 seq);                 ///< Sends a waypoint with sequence number seq
    void sendWaypointAck(quint8 type);              ///< Sends a waypoint ack
pixhawk's avatar
pixhawk committed
132
    /*@}*/
133 134

public slots:
135
    void timeout();                                 ///< Called by the timer if a response times out. Handles send retries.
136 137
    /** @name Waypoint list operations */
    /*@{*/
138
    void addWaypointEditable(Waypoint *wp, bool enforceFirstActive=true);                 ///< adds a new waypoint to the end of the editable list and changes its sequence number accordingly
pixhawk's avatar
pixhawk committed
139
    void addWaypointViewOnly(Waypoint *wp);                                               ///< adds a new waypoint to the end of the view-only list and changes its sequence number accordingly
140
    Waypoint* createWaypoint(bool enforceFirstActive=true);     ///< Creates a waypoint
141 142 143 144
    int removeWaypoint(quint16 seq);                       ///< locally remove the specified waypoint from the storage
    void moveWaypoint(quint16 cur_seq, quint16 new_seq);   ///< locally move a waypoint from its current position cur_seq to a new position new_seq
    void saveWaypoints(const QString &saveFile);           ///< saves the local waypoint list to saveFile
    void loadWaypoints(const QString &loadFile);           ///< loads a waypoint list from loadFile
145
    void notifyOfChangeEditable(Waypoint* wp);             ///< Notifies manager to changes to an editable waypoint
146
    void notifyOfChangeViewOnly(Waypoint* wp);             ///< Notifies manager to changes to a viewonly waypoint, e.g. some widget wants to change "current"
147
    /*@}*/
148
    void handleLocalPositionChanged(UASInterface* mav, double x, double y, double z, quint64 time);
149
    void handleGlobalPositionChanged(UASInterface* mav, double lat, double lon, double altAMSL, double altWGS84, quint64 time);
150

pixhawk's avatar
pixhawk committed
151
signals:
152 153 154
    void waypointEditableListChanged(void);                 ///< emits signal that the list of editable waypoints has been changed
    void waypointEditableListChanged(int uasid);            ///< emits signal that the list of editable waypoints has been changed
    void waypointEditableChanged(int uasid, Waypoint* wp);  ///< emits signal that a single editable waypoint has been changed
pixhawk's avatar
pixhawk committed
155 156 157
    void waypointViewOnlyListChanged(void);                 ///< emits signal that the list of editable waypoints has been changed
    void waypointViewOnlyListChanged(int uasid);            ///< emits signal that the list of editable waypoints has been changed
    void waypointViewOnlyChanged(int uasid, Waypoint* wp);  ///< emits signal that a single editable waypoint has been changed
158 159
    void currentWaypointChanged(quint16);           ///< emits the new current waypoint sequence number
    void updateStatusString(const QString &);       ///< emits the current status string
160
    void waypointDistanceChanged(double distance);   ///< Distance to next waypoint changed (in meters)
pixhawk's avatar
pixhawk committed
161

162 163
    void loadWPFile();                              ///< emits signal that a file wp has been load
    void readGlobalWPFromUAS(bool value);           ///< emits signal when finish to read Global WP from UAS
164 165 166 167 168 169 170
    
    void _startProtocolTimer(void);                 ///< emits signal to start protocol timer
    void _stopProtocolTimer(void);                 ///< emits signal to stop protocol timer
    
private slots:
    void _startProtocolTimerOnThisThread(void);                 ///< Starts the protocol timer
    void _stopProtocolTimerOnThisThread(void);                 ///< Starts the protocol timer
171
    void _updateWPonTimer(void);                               ///< Starts requesting WP on timer timeout
172

173
private:
lm's avatar
lm committed
174
    UAS* uas;                                       ///< Reference to the corresponding UAS
175
    quint32 current_retries;                        ///< The current number of retries left
176 177 178 179 180
    quint16 current_wp_id;                          ///< The last used waypoint ID in the current protocol transaction
    quint16 current_count;                          ///< The number of waypoints in the current protocol transaction
    WaypointState current_state;                    ///< The current protocol state
    quint8 current_partner_systemid;                ///< The current protocol communication target system
    quint8 current_partner_compid;                  ///< The current protocol communication target component
pixhawk's avatar
pixhawk committed
181
    bool read_to_edit;                              ///< If true, after readWaypoints() incoming waypoints will be copied both to "edit"-tab and "view"-tab. Otherwise, only to "view"-tab.
182

183 184
    QList<Waypoint *> waypointsViewOnly;                  ///< local copy of current waypoint list on MAV
    QList<Waypoint *> waypointsEditable;                  ///< local editable waypoint list
185
    QPointer<Waypoint> currentWaypointEditable;                      ///< The currently used waypoint
186
    QList<mavlink_mission_item_t *> waypoint_buffer;  ///< buffer for waypoints during communication
pixhawk's avatar
pixhawk committed
187
    QTimer protocol_timer;                          ///< Timer to catch timeouts
188
    QTimer _updateWPlist_timer;                     ///< update WP list if modified by another instance onboard
189
    bool standalone;                                ///< If standalone is set, do not write to UAS
190
    int uasid;                                   ///< The ID of the current UAS. Retrieved via `uas->getUASID();`, stored as an `int` to match its return type.
191 192

    // XXX export to settings
193
    static const float defaultAltitudeHomeOffset;    ///< Altitude offset in meters from home for new waypoints
194 195
    
    QString _offlineEditingModeMessage;
196 197 198
};

#endif // UASWAYPOINTMANAGER_H