PlanToolBar.qml 14 KB
Newer Older
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19
import QtQuick          2.3
import QtQuick.Controls 1.2
import QtQuick.Layouts  1.2
import QtQuick.Dialogs  1.2

import QGroundControl                   1.0
import QGroundControl.ScreenTools       1.0
import QGroundControl.Controls          1.0
import QGroundControl.FactControls      1.0
import QGroundControl.Palette           1.0

// Toolbar for Plan View
Rectangle {
    id:                 _root
    height:             ScreenTools.toolbarHeight
    anchors.left:       parent.left
    anchors.right:      parent.right
    anchors.top:        parent.top
    z:                  toolBar.z + 1
Gus Grubba's avatar
Gus Grubba committed
20
    color:              qgcPal.globalTheme === QGCPalette.Light ? Qt.rgba(1,1,1,0.8) : Qt.rgba(0,0,0,0.75)
21
    visible:            false
22
    anchors.bottomMargin: 1
23 24 25

    signal showFlyView

26
    property var    planMasterController
27 28
    property var    currentMissionItem          ///< Mission item to display status for

29 30 31 32 33
    property var    missionItems:               _controllerValid ? planMasterController.missionController.visualItems : undefined
    property real   missionDistance:            _controllerValid ? planMasterController.missionController.missionDistance : NaN
    property real   missionTime:                _controllerValid ? planMasterController.missionController.missionTime : NaN
    property real   missionMaxTelemetry:        _controllerValid ? planMasterController.missionController.missionMaxTelemetry : NaN
    property bool   missionDirty:               _controllerValid ? planMasterController.missionController.dirty : false
34

35
    property bool   _controllerValid:           planMasterController !== undefined
DonLakeFlyer's avatar
DonLakeFlyer committed
36 37 38
    property bool   _controllerOffline:         _controllerValid ? planMasterController.offline : true
    property var    _controllerDirty:           _controllerValid ? planMasterController.dirty : false
    property var    _controllerSyncInProgress:  _controllerValid ? planMasterController.syncInProgress : false
39

40 41
    property bool   _statusValid:               currentMissionItem !== undefined
    property bool   _missionValid:              missionItems !== undefined
42

43
    property real   _dataFontSize:              ScreenTools.defaultFontPointSize
44
    property real   _largeValueWidth:           ScreenTools.defaultFontPixelWidth * 8
45 46
    property real   _mediumValueWidth:          ScreenTools.defaultFontPixelWidth * 4
    property real   _smallValueWidth:           ScreenTools.defaultFontPixelWidth * 3
47
    property real   _labelToValueSpacing:       ScreenTools.defaultFontPixelWidth
48
    property real   _rowSpacing:                ScreenTools.isMobile ? 1 : 0
49 50 51 52 53
    property real   _distance:                  _statusValid ? currentMissionItem.distance : NaN
    property real   _altDifference:             _statusValid ? currentMissionItem.altDifference : NaN
    property real   _gradient:                  _statusValid && currentMissionItem.distance > 0 ? Math.atan(currentMissionItem.altDifference / currentMissionItem.distance) : NaN
    property real   _gradientPercent:           isNaN(_gradient) ? NaN : _gradient * 100
    property real   _azimuth:                   _statusValid ? currentMissionItem.azimuth : NaN
54
    property real   _heading:                   _statusValid ? currentMissionItem.missionVehicleYaw : NaN
55 56 57
    property real   _missionDistance:           _missionValid ? missionDistance : NaN
    property real   _missionMaxTelemetry:       _missionValid ? missionMaxTelemetry : NaN
    property real   _missionTime:               _missionValid ? missionTime : NaN
58 59
    property int    _batteryChangePoint:        _controllerValid ? planMasterController.missionController.batteryChangePoint : -1
    property int    _batteriesRequired:         _controllerValid ? planMasterController.missionController.batteriesRequired : -1
60
    property bool   _batteryInfoAvailable:      _batteryChangePoint >= 0 || _batteriesRequired >= 0
61 62
    property real   _controllerProgressPct:     _controllerValid ? planMasterController.missionController.progressPct : 0
    property bool   _syncInProgress:            _controllerValid ? planMasterController.missionController.syncInProgress : false
63 64 65

    property string _distanceText:              isNaN(_distance) ?              "-.-" : QGroundControl.metersToAppSettingsDistanceUnits(_distance).toFixed(1) + " " + QGroundControl.appSettingsDistanceUnitsString
    property string _altDifferenceText:         isNaN(_altDifference) ?         "-.-" : QGroundControl.metersToAppSettingsDistanceUnits(_altDifference).toFixed(1) + " " + QGroundControl.appSettingsDistanceUnitsString
66
    property string _gradientText:              isNaN(_gradient) ?              "-.-" : _gradientPercent.toFixed(0) + " %"
67 68
    property string _azimuthText:               isNaN(_azimuth) ?               "-.-" : Math.round(_azimuth) % 360
    property string _headingText:               isNaN(_azimuth) ?               "-.-" : Math.round(_heading) % 360
69 70
    property string _missionDistanceText:       isNaN(_missionDistance) ?       "-.-" : QGroundControl.metersToAppSettingsDistanceUnits(_missionDistance).toFixed(0) + " " + QGroundControl.appSettingsDistanceUnitsString
    property string _missionMaxTelemetryText:   isNaN(_missionMaxTelemetry) ?   "-.-" : QGroundControl.metersToAppSettingsDistanceUnits(_missionMaxTelemetry).toFixed(0) + " " + QGroundControl.appSettingsDistanceUnitsString
71 72
    property string _batteryChangePointText:    _batteryChangePoint < 0 ?       "N/A" : _batteryChangePoint
    property string _batteriesRequiredText:     _batteriesRequired < 0 ?        "N/A" : _batteriesRequired
73

Donald Gagne's avatar
Donald Gagne committed
74
    readonly property real _margins: ScreenTools.defaultFontPixelWidth
75 76 77

    QGCPalette { id: qgcPal }

78 79 80 81 82 83 84 85
    function getMissionTime() {
        if(isNaN(_missionTime)) {
            return "00:00:00"
        }
        var t = new Date(0, 0, 0, 0, 0, Number(_missionTime))
        return Qt.formatTime(t, 'hh:mm:ss')
    }

Gus Grubba's avatar
Gus Grubba committed
86
    //-- Eat mouse events, preventing them from reaching toolbar, which is underneath us.
87 88
    DeadMouseArea {
        anchors.fill: parent
Gus Grubba's avatar
Gus Grubba committed
89 90
    }

91 92
    //-- The reason for this Row to be here is so the Logo (Home) button is in the same
    //   location as the one in the main toolbar.
93
    Row {
94
        id:                     logoRow
95 96 97 98
        anchors.bottomMargin:   1
        anchors.left:           parent.left
        anchors.top:            parent.top
        anchors.bottom:         parent.bottom
99 100 101 102 103 104 105 106 107
        QGCToolBarButton {
            id:                 settingsButton
            anchors.top:        parent.top
            anchors.bottom:     parent.bottom
            source:             "/qmlimages/PaperPlane.svg"
            logo:               true
            checked:            false
            onClicked: {
                checked = false
108
                showFlyView()
109 110
            }
        }
111 112
    }

113 114 115 116
    // Progress bar

    on_ControllerProgressPctChanged: {
        if (_controllerProgressPct === 1) {
117 118
            missionStats.visible = false
            uploadCompleteText.visible = true
119 120 121 122 123 124 125 126
            resetProgressTimer.start()
        } else if (_controllerProgressPct > 0) {
            progressBar.visible = true
        }
    }

    Timer {
        id:             resetProgressTimer
127 128 129 130 131 132
        interval:       5000
        onTriggered: {
            missionStats.visible = true
            uploadCompleteText.visible = false
            progressBar.visible = false
        }
133 134 135 136 137 138
    }

    Rectangle {
        id:             progressBar
        anchors.left:   parent.left
        anchors.bottom: parent.bottom
139
        height:         4
140 141 142 143 144
        width:          _controllerProgressPct * parent.width
        color:          qgcPal.colorGreen
        visible:        false
    }

145 146 147 148 149 150 151 152 153 154 155 156 157
    QGCLabel {
        id:                     uploadCompleteText
        anchors.top:            parent.top
        anchors.bottom:         parent.bottom
        anchors.left:           logoRow.right
        anchors.right:          uploadButton.left
        font.pointSize:         ScreenTools.largeFontPointSize
        horizontalAlignment:    Text.AlignHCenter
        verticalAlignment:      Text.AlignVCenter
        text:                   "Done"
        visible:                false
    }

158
    GridLayout {
159 160 161
        id:                     missionStats
        anchors.top:            parent.top
        anchors.bottom:         parent.bottom
162 163
        anchors.leftMargin:     _margins
        anchors.rightMargin:    _margins
164 165
        anchors.left:           logoRow.right
        anchors.right:          uploadButton.visible ? uploadButton.left : parent.right
166 167
        columnSpacing:          0
        columns:                3
168 169

        GridLayout {
170
            anchors.verticalCenter: parent.verticalCenter
171
            columns:                8
172
            rowSpacing:             _rowSpacing
173
            columnSpacing:          _labelToValueSpacing
174
            Layout.alignment:       Qt.AlignHCenter
175 176

            QGCLabel {
177
                text:               qsTr("Selected Waypoint")
178
                Layout.columnSpan:  8
Donald Gagne's avatar
Donald Gagne committed
179
                font.pointSize:     ScreenTools.smallFontPointSize
180 181
            }

182
            QGCLabel { text: qsTr("Alt diff:"); font.pointSize: _dataFontSize; }
183
            QGCLabel {
184
                text:                   _altDifferenceText
185
                font.pointSize:         _dataFontSize
186
                Layout.minimumWidth:    _mediumValueWidth
187
            }
188

Donald Gagne's avatar
Donald Gagne committed
189 190
            Item { width: 1; height: 1 }

191
            QGCLabel { text: qsTr("Azimuth:"); font.pointSize: _dataFontSize; }
192
            QGCLabel {
193
                text:                   _azimuthText
194
                font.pointSize:         _dataFontSize
195 196
                Layout.minimumWidth:    _smallValueWidth
            }
197

198 199 200
            Item { width: 1; height: 1 }

            QGCLabel { text: qsTr("Distance:"); font.pointSize: _dataFontSize; }
201
            QGCLabel {
202
                text:                   _distanceText
203
                font.pointSize:         _dataFontSize
204
                Layout.minimumWidth:    _largeValueWidth
205 206 207 208 209 210 211
            }

            QGCLabel { text: qsTr("Gradient:"); font.pointSize: _dataFontSize; }
            QGCLabel {
                text:                   _gradientText
                font.pointSize:         _dataFontSize
                Layout.minimumWidth:    _mediumValueWidth
212
            }
213

Donald Gagne's avatar
Donald Gagne committed
214 215
            Item { width: 1; height: 1 }

216
            QGCLabel { text: qsTr("Heading:"); font.pointSize: _dataFontSize; }
217
            QGCLabel {
218
                text:                   _headingText
219
                font.pointSize:         _dataFontSize
220 221
                Layout.minimumWidth:    _smallValueWidth
            }
222 223 224
        }

        GridLayout {
225 226
            anchors.verticalCenter: parent.verticalCenter
            columns:                5
227
            rowSpacing:             _rowSpacing
228
            columnSpacing:          _labelToValueSpacing
229
            Layout.alignment:       Qt.AlignHCenter
230 231

            QGCLabel {
232
                text:               qsTr("Total Mission")
Donald Gagne's avatar
Donald Gagne committed
233 234
                Layout.columnSpan:  5
                font.pointSize:     ScreenTools.smallFontPointSize
235 236
            }

237
            QGCLabel { text: qsTr("Distance:"); font.pointSize: _dataFontSize; }
238 239
            QGCLabel {
                text:                   _missionDistanceText
240
                font.pointSize:         _dataFontSize
241 242
                Layout.minimumWidth:    _largeValueWidth
            }
243

Donald Gagne's avatar
Donald Gagne committed
244 245
            Item { width: 1; height: 1 }

246
            QGCLabel { text: qsTr("Max telem dist:"); font.pointSize: _dataFontSize; }
247 248
            QGCLabel {
                text:                   _missionMaxTelemetryText
249
                font.pointSize:         _dataFontSize
250 251
                Layout.minimumWidth:    _largeValueWidth
            }
252

253
            QGCLabel { text: qsTr("Time:"); font.pointSize: _dataFontSize; }
254
            QGCLabel {
255 256
                text:                   getMissionTime()
                font.pointSize:         _dataFontSize
257 258
                Layout.minimumWidth:    _largeValueWidth
            }
259
        }
Donald Gagne's avatar
Donald Gagne committed
260 261

        GridLayout {
262 263
            anchors.verticalCenter: parent.verticalCenter
            columns:                3
264
            rowSpacing:             _rowSpacing
265
            columnSpacing:          _labelToValueSpacing
266
            Layout.alignment:       Qt.AlignHCenter
267
            visible:                _batteryInfoAvailable
Donald Gagne's avatar
Donald Gagne committed
268 269 270 271 272 273 274

            QGCLabel {
                text:               qsTr("Battery")
                Layout.columnSpan:  3
                font.pointSize:     ScreenTools.smallFontPointSize
            }

275
            QGCLabel { text: qsTr("Batteries required:"); font.pointSize: _dataFontSize; }
276 277
            QGCLabel {
                text:                   _batteriesRequiredText
278
                font.pointSize:         _dataFontSize
279
                Layout.minimumWidth:    _mediumValueWidth
280
            }
Donald Gagne's avatar
Donald Gagne committed
281 282

            Item { width: 1; height: 1 }
283 284
/*
            FIXME: Swap point display is currently hidden since the code which calcs it doesn't work correctly
285
            QGCLabel { text: qsTr("Swap waypoint:"); font.pointSize: _dataFontSize; }
286 287
            QGCLabel {
                text:                   _batteryChangePointText
288
                font.pointSize:         _dataFontSize
289
                Layout.minimumWidth:    _mediumValueWidth
290
            }
291
*/
Donald Gagne's avatar
Donald Gagne committed
292
        }
293
    }
294 295 296 297 298 299

    QGCButton {
        id:                     uploadButton
        anchors.rightMargin:    _margins
        anchors.right:          parent.right
        anchors.verticalCenter: parent.verticalCenter
Don Gagne's avatar
Don Gagne committed
300
        text:                   _controllerDirty ? qsTr("Upload Required") : qsTr("Upload")
301
        enabled:                !_controllerSyncInProgress
302 303
        visible:                !_controllerOffline && !_controllerSyncInProgress && !uploadCompleteText.visible
        primary:                _controllerDirty
304
        onClicked:              planMasterController.upload()
305 306 307 308 309 310

        PropertyAnimation on opacity {
            easing.type:    Easing.OutQuart
            from:           0.5
            to:             1
            loops:          Animation.Infinite
311
            running:        _controllerDirty && !_controllerSyncInProgress
312 313 314
            alwaysRunToEnd: true
            duration:       2000
        }
315
    }
316 317
}