HSIDisplay.h 11.9 KB
Newer Older
1 2
/*=====================================================================

3
QGroundControl Open Source Ground Control Station
4

5
(c) 2009, 2010 QGROUNDCONTROL PROJECT <http://www.qgroundcontrol.org>
6

7
This file is part of the QGROUNDCONTROL project
8

9
    QGROUNDCONTROL is free software: you can redistribute it and/or modify
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,
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/>.
21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39

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

/**
 * @file
 *   @brief Definition of of Horizontal Situation Indicator class
 *
 *   @author Lorenz Meier <mavteam@student.ethz.ch>
 *
 */

#ifndef HSIDISPLAY_H
#define HSIDISPLAY_H

#include <QtGui/QWidget>
#include <QColor>
#include <QTimer>
#include <QMap>
#include <QPair>
40
#include <QMouseEvent>
41 42 43
#include <cmath>

#include "HDDisplay.h"
lm's avatar
lm committed
44
#include "MG.h"
45

46 47
class HSIDisplay : public HDDisplay
{
48 49
    Q_OBJECT
public:
50
    HSIDisplay(QWidget *parent = 0);
51
    ~HSIDisplay();
52 53 54

public slots:
    void setActiveUAS(UASInterface* uas);
55 56
    /** @brief Set the width in meters this widget shows from top */
    void setMetricWidth(double width);
lm's avatar
lm committed
57
    void updateSatellite(int uasid, int satid, float azimuth, float direction, float snr, bool used);
58
    void updateAttitudeSetpoints(UASInterface*, double rollDesired, double pitchDesired, double yawDesired, double thrustDesired, quint64 usec);
lm's avatar
lm committed
59
    void updateAttitude(UASInterface* uas, double roll, double pitch, double yaw, quint64 time);
60
    void updateUserPositionSetpoints(int uasid, float xDesired, float yDesired, float zDesired, float yawDesired);
lm's avatar
lm committed
61
    void updatePositionSetpoints(int uasid, float xDesired, float yDesired, float zDesired, float yawDesired, quint64 usec);
62 63
    void updateLocalPosition(UASInterface*, double x, double y, double z, quint64 usec);
    void updateGlobalPosition(UASInterface*, double lat, double lon, double alt, quint64 usec);
64
    void updateSpeed(UASInterface* uas, double vx, double vy, double vz, quint64 time);
lm's avatar
lm committed
65
    void updatePositionLock(UASInterface* uas, bool lock);
pixhawk's avatar
pixhawk committed
66 67 68
    void updateAttitudeControllerEnabled(bool enabled);
    void updatePositionXYControllerEnabled(bool enabled);
    void updatePositionZControllerEnabled(bool enabled);
LM's avatar
LM committed
69
    void updateObjectPosition(unsigned int time, int id, int type, const QString& name, int quality, float bearing, float distance);
pixhawk's avatar
pixhawk committed
70
    /** @brief Heading control enabled/disabled */
71
    void updatePositionYawControllerEnabled(bool enabled);
pixhawk's avatar
pixhawk committed
72

73
    /** @brief Localization quality changed */
pixhawk's avatar
pixhawk committed
74
    void updateLocalization(UASInterface* uas, int localization);
75
    /** @brief GPS localization quality changed */
pixhawk's avatar
pixhawk committed
76
    void updateGpsLocalization(UASInterface* uas, int localization);
77
    /** @brief Vision localization quality changed */
pixhawk's avatar
pixhawk committed
78 79
    void updateVisionLocalization(UASInterface* uas, int localization);

80 81 82
    /** @brief Ultrasound/Infrared localization changed */
    void updateInfraredUltrasoundLocalization(UASInterface* uas, int fix);

83
    /** @brief Repaint the widget */
lm's avatar
lm committed
84
    void paintEvent(QPaintEvent * event);
85 86 87
    /** @brief Update state from joystick */
    void updateJoystick(double roll, double pitch, double yaw, double thrust, int xHat, int yHat);
    void pressKey(int key);
88 89
    /** @brief Reset the state of the view */
    void resetMAVState();
90 91 92 93
    /** @brief Clear the status message */
    void clearStatusMessage()
    {
        statusMessage = "";
94 95
        if (actionPending) statusMessage = "TIMED OUT, NO ACTION";
        statusClearTimer.start();
pixhawk's avatar
pixhawk committed
96
        userSetPointSet = false;
pixhawk's avatar
pixhawk committed
97
        actionPending = false;
98
    }
99

100 101 102
signals:
    void metricWidthChanged(double width);

103
protected slots:
104
    void renderOverlay();
105 106 107 108
    void drawGPS(QPainter &painter);
    void drawObjects(QPainter &painter);
    void drawPositionDirection(float xRef, float yRef, float radius, const QColor& color, QPainter* painter);
    void drawAttitudeDirection(float xRef, float yRef, float radius, const QColor& color, QPainter* painter);
109
    void drawAltitudeSetpoint(float xRef, float yRef, float radius, const QColor& color, QPainter* painter);
110 111 112 113
    /** @brief Draw a status flag indicator */
    void drawStatusFlag(float x, float y, QString label, bool status, bool known, QPainter& painter);
    /** @brief Draw a position lock indicator */
    void drawPositionLock(float x, float y, QString label, int status, bool known, QPainter& painter);
114
    void setBodySetpointCoordinateXY(double x, double y);
115
    void setBodySetpointCoordinateYaw(double yaw);
116 117 118 119
    void setBodySetpointCoordinateZ(double z);
    /** @brief Send the current ui setpoint coordinates as new setpoint to the MAV */
    void sendBodySetPointCoordinates();
    /** @brief Draw one setpoint */
120
    void drawSetpointXYZYaw(float x, float y, float z, float yaw, const QColor &color, QPainter &painter);
121 122
    /** @brief Draw waypoints of this system */
    void drawWaypoints(QPainter& painter);
123 124
    /** @brief Draw the limiting safety area */
    void drawSafetyArea(const QPointF &topLeft, const QPointF &bottomRight,  const QColor &color, QPainter &painter);
pixhawk's avatar
pixhawk committed
125
    /** @brief Receive mouse clicks */
126
    void mouseDoubleClickEvent(QMouseEvent* event);
127 128 129
    void mousePressEvent(QMouseEvent * event);
    void mouseReleaseEvent(QMouseEvent * event);
    void mouseMoveEvent(QMouseEvent * event);
130 131
    /** @brief Receive mouse wheel events */
    void wheelEvent(QWheelEvent* event);
pixhawk's avatar
pixhawk committed
132 133
    /** @brief Read out send keys */
    void keyPressEvent(QKeyEvent* event);
134 135
    /** @brief Ignore context menu event */
    void contextMenuEvent (QContextMenuEvent* event);
136 137 138 139 140 141
    /** @brief Set status message on screen */
    void setStatusMessage(const QString& message)
    {
        statusMessage = message;
        statusClearTimer.start();
    }
142 143

protected:
144

145
    void showEvent(QShowEvent* event);
146
    void hideEvent(QHideEvent* event);
pixhawk's avatar
pixhawk committed
147
    /** @brief Get color from GPS signal-to-noise colormap */
lm's avatar
lm committed
148
    static QColor getColorForSNR(float snr);
pixhawk's avatar
pixhawk committed
149 150 151 152
    /** @brief Metric world coordinates to metric body coordinates */
    QPointF metricWorldToBody(QPointF world);
    /** @brief Metric body coordinates to metric world coordinates */
    QPointF metricBodyToWorld(QPointF body);
153 154 155 156 157
    /** @brief Screen coordinates of widget to metric coordinates in body frame */
    QPointF screenToMetricBody(QPointF ref);
    /** @brief Reference coordinates to metric coordinates */
    QPointF refToMetricBody(QPointF &ref);
    /** @brief Metric coordinates to reference coordinates */
158
    QPointF metricBodyToRef(QPointF &metric);
159 160 161 162
    /** @brief Metric length to reference coordinates */
    double metricToRef(double metric);
    /** @bried Reference coordinates to metric length */
    double refToMetric(double ref);
163 164
    /** @brief Metric body coordinates to screen coordinates */
    QPointF metricBodyToScreen(QPointF metric);
LM's avatar
LM committed
165 166 167 168 169
    QMap<int, QString> objectNames;
    QMap<int, int> objectTypes;
    QMap<int, float> objectQualities;
    QMap<int, float> objectBearings;
    QMap<int, float> objectDistances;
170
    bool dragStarted;
171 172
    bool leftDragStarted;
    bool mouseHasMoved;
173
    float startX;
174
    float startY;
175 176
    QTimer statusClearTimer;
    QString statusMessage;
pixhawk's avatar
pixhawk committed
177
    bool actionPending;
LM's avatar
LM committed
178
    bool directSending;
lm's avatar
lm committed
179 180 181 182 183 184 185

    /**
     * @brief Private data container class to be used within the HSI widget
     */
    class GPSSatellite
    {
    public:
lm's avatar
lm committed
186
        GPSSatellite(int id, float elevation, float azimuth, float snr, bool used) :
187 188 189 190 191 192
            id(id),
            elevation(elevation),
            azimuth(azimuth),
            snr(snr),
            used(used),
            lastUpdate(MG::TIME::getGroundTimeNowUsecs()) {
lm's avatar
lm committed
193 194 195

        }

196
        void update(int id, float elevation, float azimuth, float snr, bool used) {
lm's avatar
lm committed
197
            this->id = id;
lm's avatar
lm committed
198
            this->elevation = elevation;
lm's avatar
lm committed
199 200 201
            this->azimuth = azimuth;
            this->snr = snr;
            this->used = used;
lm's avatar
lm committed
202
            this->lastUpdate = MG::TIME::getGroundTimeNowUsecs();
lm's avatar
lm committed
203 204 205
        }

        int id;
lm's avatar
lm committed
206
        float elevation;
lm's avatar
lm committed
207 208 209
        float azimuth;
        float snr;
        bool used;
lm's avatar
lm committed
210
        quint64 lastUpdate;
lm's avatar
lm committed
211 212 213 214

        friend class HSIDisplay;
    };

lm's avatar
lm committed
215
    QMap<int, GPSSatellite*> gpsSatellites;
pixhawk's avatar
pixhawk committed
216
    unsigned int satellitesUsed;
217

218 219 220 221 222 223 224 225 226 227 228 229 230 231 232 233 234 235 236 237 238 239 240
    // Current controller values
    float attXSet;
    float attYSet;
    float attYawSet;
    float altitudeSet;

    float posXSet;
    float posYSet;
    float posZSet;

    // Controller saturation values
    float attXSaturation;
    float attYSaturation;
    float attYawSaturation;

    float posXSaturation;
    float posYSaturation;
    float altitudeSaturation;

    // Position
    float lat;
    float lon;
    float alt;
241
    quint64 globalAvailable;   ///< Last global position update time
242 243 244
    float x;
    float y;
    float z;
245 246 247 248 249 250 251 252 253 254 255 256 257 258 259 260
    float vx;
    float vy;
    float vz;
    float speed;
    quint64 localAvailable;    ///< Last local position update time
    float roll;
    float pitch;
    float yaw;
    float bodyXSetCoordinate;  ///< X Setpoint coordinate active on the MAV
    float bodyYSetCoordinate;  ///< Y Setpoint coordinate active on the MAV
    float bodyZSetCoordinate;  ///< Z Setpoint coordinate active on the MAV
    float bodyYawSet;          ///< Yaw setpoint coordinate active on the MAV
    float uiXSetCoordinate;    ///< X Setpoint coordinate wanted by the UI
    float uiYSetCoordinate;    ///< Y Setpoint coordinate wanted by the UI
    float uiZSetCoordinate;    ///< Z Setpoint coordinate wanted by the UI
    float uiYawSet;            ///< Yaw Setpoint wanted by the UI
261
    double metricWidth;        ///< Width the instrument represents in meters (the width of the ground shown by the widget)
262 263

    //
264 265
    float xCenterPos;         ///< X center of instrument in virtual coordinates
    float yCenterPos;         ///< Y center of instrument in virtual coordinates
266

lm's avatar
lm committed
267
    bool positionLock;
268 269 270 271 272 273 274 275 276
    bool attControlEnabled;   ///< Attitude control enabled
    bool xyControlEnabled;    ///< Horizontal control enabled
    bool zControlEnabled;     ///< Vertical control enabled
    bool yawControlEnabled;   ///< Yaw angle position control enabled
    int positionFix;          ///< Total dimensions the MAV is localizaed in
    int gpsFix;               ///< Localization dimensions based on GPS
    int visionFix;            ///< Localizaiton dimensions based on computer vision
    int laserFix;             ///< Localization dimensions based on laser
    int iruFix;               ///< Localization dimensions based on ultrasound
pixhawk's avatar
pixhawk committed
277
    bool mavInitialized;      ///< The MAV is initialized once the setpoint has been received
pixhawk's avatar
pixhawk committed
278 279
    float bottomMargin;       ///< Margin on the bottom of the page, in virtual coordinates
    float topMargin;          ///< Margin on top of the page, in virtual coordinates
lm's avatar
lm committed
280

281 282 283 284 285 286 287 288 289 290 291 292 293
    bool attControlKnown;     ///< Attitude control status known flag
    bool xyControlKnown;      ///< XY control status known flag
    bool zControlKnown;       ///< Z control status known flag
    bool yawControlKnown;     ///< Yaw control status known flag

    // Position lock indicators
    bool positionFixKnown;    ///< Position fix status known flag
    bool visionFixKnown;      ///< Vision fix status known flag
    bool gpsFixKnown;         ///< GPS fix status known flag
    bool iruFixKnown;         ///< Infrared/Ultrasound fix status known flag

    // Data indicators
    bool setPointKnown;       ///< Controller setpoint known status flag
294
    bool positionSetPointKnown; ///< Position setpoint known status flag
295 296
    bool userSetPointSet;     ///< User set X, Y and Z
    bool userXYSetPointSet;   ///< User set the X/Y position already
LM's avatar
LM committed
297 298
    bool userZSetPointSet;   ///< User set the Z position already
    bool userYawSetPointSet;   ///< User set the YAW position already
299

300 301 302 303
private:
};

#endif // HSIDISPLAY_H