FlightDisplayViewMap.qml 10.2 KB
Newer Older
1 2 3 4 5 6 7 8
/****************************************************************************
 *
 *   (c) 2009-2016 QGROUNDCONTROL PROJECT <http://www.qgroundcontrol.org>
 *
 * QGroundControl is licensed according to the terms in the file
 * COPYING.md in the root of the source code directory.
 *
 ****************************************************************************/
9 10


11 12 13 14
import QtQuick                      2.3
import QtQuick.Controls             1.2
import QtLocation                   5.3
import QtPositioning                5.3
15 16 17 18 19 20 21 22 23 24 25 26 27 28 29

import QGroundControl               1.0
import QGroundControl.FlightDisplay 1.0
import QGroundControl.FlightMap     1.0
import QGroundControl.ScreenTools   1.0
import QGroundControl.Controls      1.0
import QGroundControl.Palette       1.0
import QGroundControl.Vehicle       1.0
import QGroundControl.Controllers   1.0

FlightMap {
    id:             flightMap
    anchors.fill:   parent
    mapName:        _mapName

30
    property alias  missionController: missionController
Don Gagne's avatar
Don Gagne committed
31
    property var    flightWidgets
32
    property var    rightPanelWidth
Don Gagne's avatar
Don Gagne committed
33

34
    property bool   _followVehicle:                 true
Don Gagne's avatar
Don Gagne committed
35 36 37 38
    property var    _activeVehicle:                 QGroundControl.multiVehicleManager.activeVehicle
    property bool   _activeVehicleCoordinateValid:  _activeVehicle ? _activeVehicle.coordinateValid : false
    property var    activeVehicleCoordinate:        _activeVehicle ? _activeVehicle.coordinate : QtPositioning.coordinate()
    property var    _gotoHereCoordinate:            QtPositioning.coordinate()
39
    property int    _retaskSequence:                0
40
    property real   _toolButtonTopMargin:           parent.height - ScreenTools.availableHeight + (ScreenTools.defaultFontPixelHeight / 2)
41

42 43 44 45
    Component.onCompleted: {
        QGroundControl.flightMapPosition = center
        QGroundControl.flightMapZoom = zoomLevel
    }
46
    onCenterChanged: QGroundControl.flightMapPosition = center
47
    onZoomLevelChanged: QGroundControl.flightMapZoom = zoomLevel
48

49
    onActiveVehicleCoordinateChanged: {
50
        if (_followVehicle && _activeVehicleCoordinateValid && activeVehicleCoordinate.isValid) {
51 52
            _initialMapPositionSet = true
            flightMap.center  = activeVehicleCoordinate
53 54 55
        }
    }

Don Gagne's avatar
Don Gagne committed
56
    QGCPalette { id: qgcPal; colorGroupEnabled: true }
57
    QGCMapPalette { id: mapPal; lightColors: isSatelliteMap }
Don Gagne's avatar
Don Gagne committed
58

59
    MissionController {
60
        id: missionController
61 62 63
        Component.onCompleted: start(false /* editMode */)
    }

64
    GeoFenceController {
65
        id: geoFenceController
66 67 68
        Component.onCompleted: start(false /* editMode */)
    }

69 70 71 72 73
    RallyPointController {
        id: rallyPointController
        Component.onCompleted: start(false /* editMode */)
    }

74
    ExclusiveGroup {
Don Gagne's avatar
Don Gagne committed
75
        id: _mapTypeButtonsExclusiveGroup
76 77
    }

Don Gagne's avatar
Don Gagne committed
78 79 80 81 82 83 84 85 86 87
    ToolStrip {
        id:                 toolStrip
        anchors.leftMargin: ScreenTools.defaultFontPixelWidth
        anchors.left:       parent.left
        anchors.topMargin:  _toolButtonTopMargin
        anchors.top:        parent.top
        color:              qgcPal.window
        title:              qsTr("Fly")
        z:                  QGroundControl.zOrderWidgets
        buttonVisible:      [ true, true, _showZoom, _showZoom ]
88
        maxHeight:          (_flightVideo.visible ? _flightVideo.y : parent.height) - toolStrip.y   // Massive reach across hack
Don Gagne's avatar
Don Gagne committed
89

Don Gagne's avatar
Don Gagne committed
90
        property bool _showZoom: !ScreenTools.isMobile
Don Gagne's avatar
Don Gagne committed
91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111

        model: [
            {
                name:               "Center",
                iconSource:         "/qmlimages/MapCenter.svg",
                dropPanelComponent: centerMapDropPanel
            },
            {
                name:               "Map",
                iconSource:         "/qmlimages/MapType.svg",
                dropPanelComponent: mapTypeDropPanel
            },
            {
                name:               "In",
                iconSource:         "/qmlimages/ZoomPlus.svg"
            },
            {
                name:               "Out",
                iconSource:         "/qmlimages/ZoomMinus.svg"
            }
        ]
112 113

        onClicked: {
Don Gagne's avatar
Don Gagne committed
114 115 116 117 118 119 120
            switch (index) {
            case 2:
                _flightMap.zoomLevel += 0.5
                break
            case 3:
                _flightMap.zoomLevel -= 0.5
                break
121 122 123 124
            }
        }
    }

Don Gagne's avatar
Don Gagne committed
125
    // Toolstrip drop panel compomnents
Don Gagne's avatar
Don Gagne committed
126

Don Gagne's avatar
Don Gagne committed
127 128 129 130 131 132 133 134
    MapFitFunctions {
        id:                         mapFitFunctions
        map:                        _flightMap
        mapFitViewport:             Qt.rect(leftToolWidth, _toolButtonTopMargin, flightMap.width - leftToolWidth - rightPanelWidth, flightMap.height - _toolButtonTopMargin)
        usePlannedHomePosition:     false
        mapMissionController:      missionController
        mapGeoFenceController:     geoFenceController
        mapRallyPointController:   rallyPointController
135

Don Gagne's avatar
Don Gagne committed
136 137
        property real leftToolWidth:    toolStrip.x + toolStrip.width
    }
138

Don Gagne's avatar
Don Gagne committed
139 140
    Component {
        id: centerMapDropPanel
141

Don Gagne's avatar
Don Gagne committed
142
        CenterMapDropPanel {
143 144 145 146 147 148
            map:                _flightMap
            fitFunctions:       mapFitFunctions
            showFollowVehicle:  true
            followVehicle:      _followVehicle

            onFollowVehicleChanged: _followVehicle = followVehicle
Don Gagne's avatar
Don Gagne committed
149 150
        }
    }
151

Don Gagne's avatar
Don Gagne committed
152 153
    Component {
        id: mapTypeDropPanel
154

Don Gagne's avatar
Don Gagne committed
155 156
        Column {
            spacing: ScreenTools.defaultFontPixelHeight / 2
157

Don Gagne's avatar
Don Gagne committed
158 159 160 161 162 163 164 165 166 167 168 169 170 171 172
            QGCLabel { text: qsTr("Map type:") }
            Row {
                spacing: ScreenTools.defaultFontPixelWidth
                Repeater {
                    model: QGroundControl.flightMapSettings.mapTypes

                    QGCButton {
                        checkable:      true
                        checked:        QGroundControl.flightMapSettings.mapType === text
                        text:           modelData
                        exclusiveGroup: _mapTypeButtonsExclusiveGroup
                        onClicked: {
                            QGroundControl.flightMapSettings.mapType = text
                            dropPanel.hide()
                        }
173 174 175 176
                    }
                }
            }
        }
Don Gagne's avatar
Don Gagne committed
177
    }
178

179 180
    // Add trajectory points to the map
    MapItemView {
181
        model: _mainIsMap ? _activeVehicle ? _activeVehicle.trajectoryPoints : 0 : 0
182 183
        delegate:
            MapPolyline {
Don Gagne's avatar
Don Gagne committed
184 185 186 187
            line.width: 3
            line.color: "red"
            z:          QGroundControl.zOrderMapItems - 1
            path: [
188 189
                object.coordinate1,
                object.coordinate2,
Don Gagne's avatar
Don Gagne committed
190 191
            ]
        }
192 193 194 195
    }

    // Add the vehicles to the map
    MapItemView {
196
        model: QGroundControl.multiVehicleManager.vehicles
197 198
        delegate:
            VehicleMapItem {
Don Gagne's avatar
Don Gagne committed
199 200 201 202
            vehicle:        object
            coordinate:     object.coordinate
            isSatellite:    flightMap.isSatelliteMap
            size:           _mainIsMap ? ScreenTools.defaultFontPixelHeight * 5 : ScreenTools.defaultFontPixelHeight * 2
203
            z:              QGroundControl.zOrderMapItems - 1
Don Gagne's avatar
Don Gagne committed
204
        }
205 206 207 208
    }

    // Add the mission items to the map
    MissionItemView {
209
        model: _mainIsMap ? missionController.visualItems : 0
210 211 212 213
    }

    // Add lines between waypoints
    MissionLineView {
214
        model: _mainIsMap ? missionController.waypointLines : 0
215 216
    }

217 218 219 220
    // GeoFence polygon
    MapPolygon {
        border.color:   "#80FF0000"
        border.width:   3
221
        path:           geoFenceController.polygon.path
222
        visible:        geoFenceController.polygonEnabled
223 224 225 226 227 228 229
    }

    // GeoFence circle
    MapCircle {
        border.color:   "#80FF0000"
        border.width:   3
        center:         missionController.plannedHomePosition
230
        radius:         geoFenceController.circleRadius
231
        z:              QGroundControl.zOrderMapItems
232
        visible:        geoFenceController.circleEnabled
233 234 235 236
    }

    // GeoFence breach return point
    MapQuickItem {
237 238
        anchorPoint.x:  sourceItem.anchorPointX
        anchorPoint.y:  sourceItem.anchorPointY
239
        coordinate:     geoFenceController.breachReturnPoint
240
        visible:        geoFenceController.breachReturnEnabled
241
        sourceItem:     MissionItemIndexLabel { label: "F" }
242
        z:              QGroundControl.zOrderMapItems
243 244
    }

245 246 247 248 249 250
    // Rally points on map
    MapItemView {
        model: rallyPointController.points

        delegate: MapQuickItem {
            id:             itemIndicator
251 252
            anchorPoint.x:  sourceItem.anchorPointX
            anchorPoint.y:  sourceItem.anchorPointY
253 254 255 256 257 258 259 260 261 262
            coordinate:     object.coordinate
            z:              QGroundControl.zOrderMapItems

            sourceItem: MissionItemIndexLabel {
                id:         itemIndexLabel
                label:      qsTr("R", "rally point map item label")
            }
        }
    }

Don Gagne's avatar
Don Gagne committed
263 264 265
    // GoTo here waypoint
    MapQuickItem {
        coordinate:     _gotoHereCoordinate
Don Gagne's avatar
Don Gagne committed
266
        visible:        _activeVehicle && _activeVehicle.guidedMode && _gotoHereCoordinate.isValid
Don Gagne's avatar
Don Gagne committed
267
        z:              QGroundControl.zOrderMapItems
268 269
        anchorPoint.x:  sourceItem.anchorPointX
        anchorPoint.y:  sourceItem.anchorPointY
Don Gagne's avatar
Don Gagne committed
270 271

        sourceItem: MissionItemIndexLabel {
272 273
            checked: true
            label:   qsTr("G", "Goto here waypoint") // second string is translator's hint.
Don Gagne's avatar
Don Gagne committed
274
        }
275 276 277 278 279 280 281 282 283
    }    

    MapScale {
        anchors.bottomMargin:   ScreenTools.defaultFontPixelHeight * (0.66)
        anchors.rightMargin:    ScreenTools.defaultFontPixelHeight * (0.33)
        anchors.bottom:         parent.bottom
        anchors.right:          parent.right
        mapControl:             flightMap
        visible:                !ScreenTools.isTinyScreen
Don Gagne's avatar
Don Gagne committed
284 285 286
    }

    // Handle guided mode clicks
287 288
    MouseArea {
        anchors.fill: parent
Don Gagne's avatar
Don Gagne committed
289 290

        onClicked: {
Don Gagne's avatar
Don Gagne committed
291
            if (_activeVehicle) {
292
                if (flightWidgets.guidedModeBar.state != "Shown") {
Don Gagne's avatar
Don Gagne committed
293
                    flightWidgets.guidedModeBar.state = "Shown"
294 295 296 297 298
                } else {
                    if (flightWidgets.gotoEnabled) {
                        _gotoHereCoordinate = flightMap.toCoordinate(Qt.point(mouse.x, mouse.y))
                        flightWidgets.guidedModeBar.confirmAction(flightWidgets.guidedModeBar.confirmGoTo)
                    }
Don Gagne's avatar
Don Gagne committed
299
                }
Don Gagne's avatar
Don Gagne committed
300 301
            }
        }
302 303
    }
}