QGCMapWidget.h 6.88 KB
Newer Older
lm's avatar
lm committed
1
2
3
#ifndef QGCMAPWIDGET_H
#define QGCMAPWIDGET_H

4
#include <QMap>
5
#include <QTimer>
6
#include "../../../libs/opmapcontrol/opmapcontrol.h"
lm's avatar
lm committed
7

lm's avatar
lm committed
8
class UASInterface;
9
10
class UASWaypointManager;
class Waypoint;
11
typedef mapcontrol::WayPointItem WayPointItem;
lm's avatar
lm committed
12

13
14
15
/**
 * @brief Class representing a 2D map using aerial imagery
 */
lm's avatar
lm committed
16
class QGCMapWidget : public mapcontrol::OPMapWidget
lm's avatar
lm committed
17
18
19
20
{
    Q_OBJECT
public:
    explicit QGCMapWidget(QWidget *parent = 0);
lm's avatar
lm committed
21
    ~QGCMapWidget();
22
23
24
25
//    /** @brief Convert meters to pixels */
//    float metersToPixels(double meters);
//    double headingP1P2(internals::PointLatLng p1, internals::PointLatLng p2);
//    internals::PointLatLng targetLatLon(internals::PointLatLng source, double heading, double dist);
lm's avatar
lm committed
26

27
28
    /** @brief Map centered on current active system */
    bool getFollowUAVEnabled() { return followUAVEnabled; }
29
    /** @brief The maximum map update rate */
30
31
32
33
34
    float getUpdateRateLimit() { return maxUpdateInterval; }
    /** @brief Get the trail type */
    int getTrailType() { return static_cast<int>(trailType); }
    /** @brief Get the trail interval */
    float getTrailInterval() { return trailInterval; }
35

lm's avatar
lm committed
36
signals:
37
    void homePositionChanged(double latitude, double longitude, double altitude);
38
39
40
    /** @brief Signal for newly created map waypoints */
    void waypointCreated(Waypoint* wp);
    void waypointChanged(Waypoint* wp);
lm's avatar
lm committed
41
42

public slots:
43
44
    /** @brief Action triggered with point-camera action is selected from the context menu */
    void cameraActionTriggered();
45
46
47
48
    /** @brief Action triggered when guided action is selected from the context menu */
    void guidedActionTriggered();
    /** @brief Action triggered when guided action is selected from the context menu, allows for altitude selection */
    bool guidedAltActionTriggered();
49
50
    /** @brief Action triggered when set home action is selected from the context menu. */
    bool setHomeActionTriggered();
51
    /** @brief Add system to map view */
lm's avatar
lm committed
52
    void addUAS(UASInterface* uas);
53
    /** @brief Update the global position of a system */
lm's avatar
lm committed
54
    void updateGlobalPosition(UASInterface* uas, double lat, double lon, double alt, quint64 usec);
55
56
    /** @brief Update the global position of all systems */
    void updateGlobalPosition();
57
58
59
60
    /** @brief Update the local position and draw it converted to GPS reference */
    void updateLocalPosition();
    /** @brief Update the local position estimates (individual sensors) and draw it converted to GPS reference */
    void updateLocalPositionEstimates();
61
62
    /** @brief Update the type, size, etc. of this system */
    void updateSystemSpecs(int uas);
63
64
65
66
    /** @brief Change current system in focus / editing */
    void activeUASSet(UASInterface* uas);
    /** @brief Show a dialog to jump to given GPS coordinates */
    void showGoToDialog();
67
68
    /** @brief Jump to the home position on the map */
    void goHome();
69
70
71
72
73
74
    /** @brief Update this waypoint for this UAS */
    void updateWaypoint(int uas, Waypoint* wp);
    /** @brief Update the whole waypoint */
    void updateWaypointList(int uas);
    /** @brief Update the home position on the map */
    void updateHomePosition(double latitude, double longitude, double altitude);
75
76
    /** @brief Set update rate limit */
    void setUpdateRateLimit(float seconds);
77
78
79
80
    /** @brief Cache visible region to harddisk */
    void cacheVisibleRegion();
    /** @brief Set follow mode */
    void setFollowUAVEnabled(bool enabled) { followUAVEnabled = enabled; }
81
    /** @brief Set trail to time mode and set time @param seconds The minimum time between trail dots in seconds. If set to a value < 0, trails will be disabled*/
82
83
84
85
    void setTrailModeTimed(int seconds)
    {
        foreach(mapcontrol::UAVItem* uav, GetUAVS())
        {
86
87
88
89
90
91
92
93
94
            if (seconds >= 0)
            {
                uav->SetTrailTime(seconds);
                uav->SetTrailType(mapcontrol::UAVTrailType::ByTimeElapsed);
            }
            else
            {
                uav->SetTrailType(mapcontrol::UAVTrailType::NoTrail);
            }
95
96
        }
    }
97
    /** @brief Set trail to distance mode and set time @param meters The minimum distance between trail dots in meters. The actual distance depends on the MAV's update rate as well. If set to a value < 0, trails will be disabled*/
98
99
100
101
    void setTrailModeDistance(int meters)
    {
        foreach(mapcontrol::UAVItem* uav, GetUAVS())
        {
102
103
104
105
106
107
108
109
110
            if (meters >= 0)
            {
                uav->SetTrailDistance(meters);
                uav->SetTrailType(mapcontrol::UAVTrailType::ByDistance);
            }
            else
            {
                uav->SetTrailType(mapcontrol::UAVTrailType::NoTrail);
            }
111
112
        }
    }
lm's avatar
lm committed
113
114
115
116
117
118
119
120
    /** @brief Delete all trails */
    void deleteTrails()
    {
        foreach(mapcontrol::UAVItem* uav, GetUAVS())
        {
            uav->DeleteTrail();
        }
    }
121

122
    /** @brief Load the settings for this widget from disk */
123
    void loadSettings(bool changePosition=true);
124
    /** @brief Store the settings for this widget to disk */
125
126
    void storeSettings();

127
128
129
130
protected slots:
    /** @brief Convert a map edit into a QGC waypoint event */
    void handleMapWaypointEdit(WayPointItem* waypoint);

131
protected:
132
133
    /** @brief Update the highlighting of the currently controlled system */
    void updateSelectedSystem(int uas);
134
135
136
    /** @brief Initialize */
    void showEvent(QShowEvent* event);
    void hideEvent(QHideEvent* event);
137
138
    void mousePressEvent(QMouseEvent *event);
    void mouseReleaseEvent(QMouseEvent *event);
139
    void mouseDoubleClickEvent(QMouseEvent* event);
140

141
142
    //void contextMenuEvent(QContextMenuEvent *);

143
    UASWaypointManager* currWPManager; ///< The current waypoint manager
144
    bool offlineMode;
145
146
    QMap<Waypoint* , mapcontrol::WayPointItem*> waypointsToIcons;
    QMap<mapcontrol::WayPointItem*, Waypoint*> iconsToWaypoints;
147
    Waypoint* firingWaypointChange;
148
149
    QTimer updateTimer;
    float maxUpdateInterval;
150
151
152
153
154
155
156
157
158
    enum editMode {
        EDIT_MODE_NONE,
        EDIT_MODE_WAYPOINTS,
        EDIT_MODE_SWEEP,
        EDIT_MODE_UAVS,
        EDIT_MODE_HOME,
        EDIT_MODE_SAFE_AREA,
        EDIT_MODE_CACHING
    };
159
    editMode currEditMode;              ///< The current edit mode on the map
160
    bool followUAVEnabled;              ///< Does the map follow the UAV?
161
162
    mapcontrol::UAVTrailType::Types trailType; ///< Time or distance based trail dots
    float trailInterval;                ///< Time or distance between trail items
163
    int followUAVID;                    ///< Which UAV should be tracked?
164
    bool mapInitialized;                ///< Map initialized?
165
    float homeAltitude;                 ///< Home altitude
166
    QPoint mousePressPos;               ///< Mouse position when the button is released.
167
    QPoint contextMousePressPos;        ///< Mouse position when context menu activated.
168
    int defaultGuidedAlt;               ///< Default altitude for guided mode
169
    UASInterface *uas;                  ///< Currently selected UAS.
lm's avatar
lm committed
170
171
172
173

};

#endif // QGCMAPWIDGET_H