MainToolBar.qml 22.9 KB
Newer Older
dogmaphobic's avatar
dogmaphobic committed
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29
/*=====================================================================

QGroundControl Open Source Ground Control Station

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

This file is part of the QGROUNDCONTROL project

    QGROUNDCONTROL is free software: you can redistribute it and/or modify
    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.

    QGROUNDCONTROL is distributed in the hope that it will be useful,
    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
    along with QGROUNDCONTROL. If not, see <http://www.gnu.org/licenses/>.

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

/**
 * @file
 *   @brief QGC Main Tool Bar
 *   @author Gus Grubba <mavlink@grubba.com>
 */

dogmaphobic's avatar
dogmaphobic committed
30
import QtQuick 2.5
31
import QtQuick.Layouts 1.2
dogmaphobic's avatar
dogmaphobic committed
32 33 34
import QtQuick.Controls 1.2
import QtQuick.Controls.Styles 1.2

Don Gagne's avatar
Don Gagne committed
35
import QGroundControl                       1.0
36 37 38 39
import QGroundControl.Controls              1.0
import QGroundControl.Palette               1.0
import QGroundControl.MultiVehicleManager   1.0
import QGroundControl.ScreenTools           1.0
40
import QGroundControl.Controllers           1.0
dogmaphobic's avatar
dogmaphobic committed
41

42
Rectangle {
dogmaphobic's avatar
dogmaphobic committed
43
    id:     toolBar
dogmaphobic's avatar
dogmaphobic committed
44
    color:  opaqueBackground ? "#404040" : Qt.rgba(0,0,0,0.75)
dogmaphobic's avatar
dogmaphobic committed
45

Don Gagne's avatar
Don Gagne committed
46
    QGCPalette { id: qgcPal; colorGroupEnabled: true }
47

dogmaphobic's avatar
dogmaphobic committed
48
    property var  activeVehicle:        multiVehicleManager.activeVehicle
dogmaphobic's avatar
dogmaphobic committed
49
    property var  mainWindow:           null
dogmaphobic's avatar
dogmaphobic committed
50 51
    property bool isMessageImportant:   activeVehicle ? !activeVehicle.messageTypeNormal && !activeVehicle.messageTypeNone : false
    property bool isBackgroundDark:     true
dogmaphobic's avatar
dogmaphobic committed
52
    property bool opaqueBackground:     false
53

dogmaphobic's avatar
dogmaphobic committed
54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139
    /*
        Dev System (Mac OS)

        qml: Main Window Width:   1008
        qml: Toolbar height:      51.2
        qml: Default font:        12.8
        qml: Font (.75):          9.600000000000001
        qml: Font (.85):          10.88
        qml: Font 1.5):           19.200000000000003
        qml: Default Font Width:  8.328125
        qml: Default Font Height: 12.8
        qml: --
        qml: Real Font Height:    16
        qml: fontHRatio:          1
        qml: --
        qml: cellHeight:          38
        qml: tbFontSmall:         10
        qml: tbFontNormal:        12
        qml: tbFontLarge:         18
        qml: tbSpacing:           9.54

        Nexus 9

        qml: Main Window Width:   2048
        qml: Toolbar height:      90.9312
        qml: Default font:        38
        qml: Font (.75):          28.5
        qml: Font (.85):          32.3
        qml: Font 1.5):           57
        qml: Default Font Width:  20.0625
        qml: Default Font Height: 38
        qml: --
        qml: Real Font Height:    38
        qml: fontHRatio:          2.375
        qml: --
        qml: cellHeight:          68
        qml: tbFontSmall:         23.75
        qml: tbFontNormal:        28.5
        qml: tbFontLarge:         42.75
        qml: tbSpacing:           16.87552

        Nexus 7

        qml: Main Window Width:   1920
        qml: Toolbar height:      85.248
        qml: Default font:        38
        qml: Font (.75):          28.5
        qml: Font (.85):          32.3
        qml: Font 1.5):           57
        qml: Default Font Width:  20.140625
        qml: Default Font Height: 38
        qml: --
        qml: Real Font Height:    38
        qml: fontHRatio:          2.375
        qml: --
        qml: cellHeight:          63
        qml: tbFontSmall:         23.75
        qml: tbFontNormal:        28.5
        qml: tbFontLarge:         42.75
        qml: tbSpacing:           15.820800000000002

        Nexus 4

        qml: Main Window Width:   1196
        qml: Toolbar height:      79.65360000000001
        qml: Default font:        38
        qml: Font (.75):          28.5
        qml: Font (.85):          32.3
        qml: Font 1.5):           57
        qml: Default Font Width:  20.140625
        qml: Default Font Height: 38
        qml: --
        qml: Real Font Height:    38
        qml: fontHRatio:          2.375
        qml: --
        qml: cellHeight:          59
        qml: tbFontSmall:         23.75
        qml: tbFontNormal:        28.5
        qml: tbFontLarge:         42.75
        qml: tbSpacing:           9.85504

    */

    readonly property real  tbFontSmall:    10 * ScreenTools.fontHRatio
    readonly property real  tbFontNormal:   12 * ScreenTools.fontHRatio
    readonly property real  tbFontLarge:    18 * ScreenTools.fontHRatio
dogmaphobic's avatar
dogmaphobic committed
140

dogmaphobic's avatar
dogmaphobic committed
141 142 143 144 145 146
    readonly property var   colorGreen:     "#05f068"
    readonly property var   colorOrange:    "#f0ab06"
    readonly property var   colorRed:       "#fc4638"
    readonly property var   colorGrey:      "#7f7f7f"
    readonly property var   colorBlue:      "#636efe"
    readonly property var   colorWhite:     "#ffffff"
147

Don Gagne's avatar
Don Gagne committed
148 149 150 151
    signal showSetupView()
    signal showPlanView()
    signal showFlyView()

152
    MainToolBarController { id: _controller }
dogmaphobic's avatar
dogmaphobic committed
153

Don Gagne's avatar
Don Gagne committed
154 155 156 157 158 159 160 161 162 163 164 165
    function checkSetupButton() {
        setupButton.checked = true
    }

    function checkPlanButton() {
        planButton.checked = true
    }

    function checkFlyButton() {
        flyButton.checked = true
    }

166 167 168 169 170 171 172 173 174 175 176 177 178 179 180
    function getBatteryColor() {
        if(activeVehicle) {
            if(activeVehicle.batteryPercent > 75) {
                return colorGreen
            }
            if(activeVehicle.batteryPercent > 50) {
                return colorOrange
            }
            if(activeVehicle.batteryPercent > 0.1) {
                return colorRed
            }
        }
        return colorGrey
    }

dogmaphobic's avatar
dogmaphobic committed
181 182 183 184 185 186 187 188 189 190
    function getRSSIColor(value) {
        if(value >= 0)
            return colorGrey;
        if(value > -60)
            return colorGreen;
        if(value > -90)
            return colorOrange;
        return colorRed;
    }

dogmaphobic's avatar
dogmaphobic committed
191 192
    function getGpsLockStatus() {
        if(activeVehicle) {
dogmaphobic's avatar
dogmaphobic committed
193 194
            if(activeVehicle.satelliteLock < 2) {
                return "No Satellite Lock"
dogmaphobic's avatar
dogmaphobic committed
195 196 197 198
            }
            if(activeVehicle.satelliteLock == 2) {
                return "2D Lock"
            }
dogmaphobic's avatar
dogmaphobic committed
199 200 201 202
            if(activeVehicle.satelliteLock == 3) {
                return "3D Lock"
            }
            if(activeVehicle.satelliteLock == 4) {
203
                return "3D DGPS Lock"
dogmaphobic's avatar
dogmaphobic committed
204 205
            }
            if(activeVehicle.satelliteLock == 5) {
206
                return "3D RTK GPS Lock"
dogmaphobic's avatar
dogmaphobic committed
207 208
            }
            return "Unkown Lock Type (" + activeVehicle.satelliteLock + ")"
dogmaphobic's avatar
dogmaphobic committed
209 210 211 212
        }
        return "N/A"
    }

dogmaphobic's avatar
dogmaphobic committed
213 214 215 216
    Component.onCompleted: {
        //-- TODO: Get this from the actual state
        flyButton.checked = true
    }
217

dogmaphobic's avatar
dogmaphobic committed
218 219 220 221 222 223 224 225 226 227 228 229 230 231 232 233 234
    //---------------------------------------------
    // GPS Info
    Component {
        id: gpsInfo
        Rectangle {
            color:          Qt.rgba(0,0,0,0.75)
            width:          gpsCol.width   + ScreenTools.defaultFontPixelWidth  * 3
            height:         gpsCol.height  + ScreenTools.defaultFontPixelHeight * 2
            radius:         ScreenTools.defaultFontPixelHeight * 0.5
            Column {
                id:                 gpsCol
                spacing:            ScreenTools.defaultFontPixelHeight * 0.5
                width:              Math.max(gpsGrid.width, gpsLabel.width)
                anchors.margins:    ScreenTools.defaultFontPixelHeight
                anchors.centerIn:   parent
                QGCLabel {
                    id:         gpsLabel
dogmaphobic's avatar
dogmaphobic committed
235
                    text:       (activeVehicle && activeVehicle.satelliteCount >= 0) ? "GPS Status" : "GPS Data Unavailable"
dogmaphobic's avatar
dogmaphobic committed
236
                    font.weight:Font.DemiBold
237
                    color:      colorWhite
dogmaphobic's avatar
dogmaphobic committed
238 239 240 241
                    anchors.horizontalCenter: parent.horizontalCenter
                }
                GridLayout {
                    id:                 gpsGrid
dogmaphobic's avatar
dogmaphobic committed
242
                    visible:            (activeVehicle && activeVehicle.satelliteCount >= 0)
dogmaphobic's avatar
dogmaphobic committed
243 244 245 246 247 248
                    anchors.margins:    ScreenTools.defaultFontPixelHeight
                    columnSpacing:      ScreenTools.defaultFontPixelWidth
                    anchors.horizontalCenter: parent.horizontalCenter
                    columns: 2
                    QGCLabel {
                        text:   "GPS Count:"
249
                        color:  colorWhite
dogmaphobic's avatar
dogmaphobic committed
250 251 252
                    }
                    QGCLabel {
                        text:   activeVehicle ? (activeVehicle.satelliteCount) : "N/A"
253
                        color:  colorWhite
dogmaphobic's avatar
dogmaphobic committed
254 255 256
                    }
                    QGCLabel {
                        text:   "GPS Lock:"
257
                        color:  colorWhite
dogmaphobic's avatar
dogmaphobic committed
258 259 260
                    }
                    QGCLabel {
                        text:   getGpsLockStatus()
261
                        color:  colorWhite
dogmaphobic's avatar
dogmaphobic committed
262
                    }
263 264 265 266 267
                    QGCLabel {
                        text:   "HDOP:"
                        color:  colorWhite
                    }
                    QGCLabel {
268
                        text:   activeVehicle ? (activeVehicle.satRawHDOP < 10000 ? activeVehicle.satRawHDOP.toFixed(0) : "N/A") : "N/A"
269 270 271 272 273 274 275
                        color:  colorWhite
                    }
                    QGCLabel {
                        text:   "VDOP:"
                        color:  colorWhite
                    }
                    QGCLabel {
276
                        text:   activeVehicle ? (activeVehicle.satRawVDOP < 10000 ? activeVehicle.satRawVDOP.toFixed(0) : "N/A") : "N/A"
277 278 279 280 281 282 283 284 285 286
                        color:  colorWhite
                    }
                    QGCLabel {
                        text:   "Course Over Ground:"
                        color:  colorWhite
                    }
                    QGCLabel {
                        text:   activeVehicle ? (activeVehicle.satRawCOG).toFixed(2) : "N/A"
                        color:  colorWhite
                    }
dogmaphobic's avatar
dogmaphobic committed
287 288 289 290 291 292 293 294 295 296
                }
            }
            Component.onCompleted: {
                var pos = mapFromItem(toolBar, centerX - (width / 2), toolBar.height)
                x = pos.x
                y = pos.y + ScreenTools.defaultFontPixelHeight
            }
        }
    }

297 298 299 300 301 302 303 304 305 306 307 308 309 310 311 312 313 314
    //---------------------------------------------
    // Battery Info
    Component {
        id: batteryInfo
        Rectangle {
            color:          Qt.rgba(0,0,0,0.75)
            width:          battCol.width   + ScreenTools.defaultFontPixelWidth  * 3
            height:         battCol.height  + ScreenTools.defaultFontPixelHeight * 2
            radius:         ScreenTools.defaultFontPixelHeight * 0.5
            Column {
                id:                 battCol
                spacing:            ScreenTools.defaultFontPixelHeight * 0.5
                width:              Math.max(battGrid.width, battLabel.width)
                anchors.margins:    ScreenTools.defaultFontPixelHeight
                anchors.centerIn:   parent
                QGCLabel {
                    id:         battLabel
                    text:       (activeVehicle && (activeVehicle.batteryVoltage > 0)) ? "Battery Status" : "Battery Data Unavailable"
315
                    color:      colorWhite
316 317 318 319 320 321 322 323 324 325 326 327
                    font.weight:Font.DemiBold
                    anchors.horizontalCenter: parent.horizontalCenter
                }
                GridLayout {
                    id:                 battGrid
                    visible:            (activeVehicle && (activeVehicle.batteryVoltage > 0))
                    anchors.margins:    ScreenTools.defaultFontPixelHeight
                    columnSpacing:      ScreenTools.defaultFontPixelWidth
                    anchors.horizontalCenter: parent.horizontalCenter
                    columns: 2
                    QGCLabel {
                        text:   "Voltage:"
328
                        color:  colorWhite
329 330 331 332 333 334 335 336 337 338 339 340 341 342 343 344 345
                    }
                    QGCLabel {
                        text:   activeVehicle ? (activeVehicle.batteryVoltage.toFixed(1) + " V") : "N/A"
                        color:  getBatteryColor()
                    }
                    // TODO: What "controller" provides "Facts"?
                    /*
                    QGCLabel {
                        text:   "Cell Voltage:"
                    }
                    QGCLabel {
                        text:   (activeVehicle.batteryVoltage / controller.getParameterFact(-1, "BAT_N_CELLS").value) + "V"
                        color:  getBatteryColor()
                    }
                    */
                    QGCLabel {
                        text:   "Accumulated Consumption:"
346
                        color:  colorWhite
347 348 349 350 351 352 353 354 355 356 357 358 359 360 361 362 363 364 365 366 367
                    }
                    QGCLabel {
                        text:   activeVehicle ? (activeVehicle.batteryConsumed + " mA") : "N/A"
                        color:  getBatteryColor()
                    }
                }
            }
            Component.onCompleted: {
                var pos = mapFromItem(toolBar, centerX - (width / 2), toolBar.height)
                x = pos.x
                y = pos.y + ScreenTools.defaultFontPixelHeight
            }
        }
    }

    //---------------------------------------------
    // RC RSSI Info
    Component {
        id: rcRSSIInfo
        Rectangle {
            color:          Qt.rgba(0,0,0,0.75)
dogmaphobic's avatar
dogmaphobic committed
368 369
            width:          rcrssiCol.width   + ScreenTools.defaultFontPixelWidth  * 3
            height:         rcrssiCol.height  + ScreenTools.defaultFontPixelHeight * 2
370 371
            radius:         ScreenTools.defaultFontPixelHeight * 0.5
            Column {
dogmaphobic's avatar
dogmaphobic committed
372
                id:                 rcrssiCol
373
                spacing:            ScreenTools.defaultFontPixelHeight * 0.5
dogmaphobic's avatar
dogmaphobic committed
374
                width:              Math.max(rcrssiGrid.width, rssiLabel.width)
375 376 377 378
                anchors.margins:    ScreenTools.defaultFontPixelHeight
                anchors.centerIn:   parent
                QGCLabel {
                    id:         rssiLabel
dogmaphobic's avatar
dogmaphobic committed
379
                    text:       activeVehicle ? (activeVehicle.rcRSSI > 0 ? "RC RSSI Status" : "RC RSSI Data Unavailable") : "N/A"
380
                    color:      colorWhite
381 382 383 384
                    font.weight:Font.DemiBold
                    anchors.horizontalCenter: parent.horizontalCenter
                }
                GridLayout {
dogmaphobic's avatar
dogmaphobic committed
385 386
                    id:                 rcrssiGrid
                    visible:            activeVehicle && activeVehicle.rcRSSI > 0
387 388 389 390 391 392
                    anchors.margins:    ScreenTools.defaultFontPixelHeight
                    columnSpacing:      ScreenTools.defaultFontPixelWidth
                    anchors.horizontalCenter: parent.horizontalCenter
                    columns: 2
                    QGCLabel {
                        text:   "RSSI:"
393
                        color:  colorWhite
394 395 396
                    }
                    QGCLabel {
                        text:   activeVehicle ? (activeVehicle.rcRSSI + "%") : 0
397
                        color:  colorWhite
398 399 400 401 402 403 404 405 406 407 408
                    }
                }
            }
            Component.onCompleted: {
                var pos = mapFromItem(toolBar, centerX - (width / 2), toolBar.height)
                x = pos.x
                y = pos.y + ScreenTools.defaultFontPixelHeight
            }
        }
    }

dogmaphobic's avatar
dogmaphobic committed
409 410 411 412 413 414 415 416 417 418 419 420 421 422 423 424 425 426
    //---------------------------------------------
    // Telemetry RSSI Info
    Component {
        id: telemRSSIInfo
        Rectangle {
            color:          Qt.rgba(0,0,0,0.75)
            width:          telemCol.width   + ScreenTools.defaultFontPixelWidth  * 3
            height:         telemCol.height  + ScreenTools.defaultFontPixelHeight * 2
            radius:         ScreenTools.defaultFontPixelHeight * 0.5
            Column {
                id:                 telemCol
                spacing:            ScreenTools.defaultFontPixelHeight * 0.5
                width:              Math.max(telemGrid.width, telemLabel.width)
                anchors.margins:    ScreenTools.defaultFontPixelHeight
                anchors.centerIn:   parent
                QGCLabel {
                    id:         telemLabel
                    text:       "Telemetry RSSI Status"
427
                    color:      colorWhite
dogmaphobic's avatar
dogmaphobic committed
428 429 430 431 432 433 434 435 436 437 438
                    font.weight:Font.DemiBold
                    anchors.horizontalCenter: parent.horizontalCenter
                }
                GridLayout {
                    id:                 telemGrid
                    anchors.margins:    ScreenTools.defaultFontPixelHeight
                    columnSpacing:      ScreenTools.defaultFontPixelWidth
                    anchors.horizontalCenter: parent.horizontalCenter
                    columns: 2
                    QGCLabel {
                        text:   "Local RSSI:"
439
                        color:  colorWhite
dogmaphobic's avatar
dogmaphobic committed
440 441 442
                    }
                    QGCLabel {
                        text:   _controller.telemetryLRSSI + " dBm"
443
                        color:  colorWhite
dogmaphobic's avatar
dogmaphobic committed
444 445 446
                    }
                    QGCLabel {
                        text:   "Remote RSSI:"
447
                        color:  colorWhite
dogmaphobic's avatar
dogmaphobic committed
448 449 450
                    }
                    QGCLabel {
                        text:   _controller.telemetryRRSSI + " dBm"
451
                        color:  colorWhite
dogmaphobic's avatar
dogmaphobic committed
452 453 454
                    }
                    QGCLabel {
                        text:   "RX Errors:"
455
                        color:  colorWhite
dogmaphobic's avatar
dogmaphobic committed
456 457 458
                    }
                    QGCLabel {
                        text:   _controller.telemetryRXErrors
459
                        color:  colorWhite
dogmaphobic's avatar
dogmaphobic committed
460 461 462
                    }
                    QGCLabel {
                        text:   "Errors Fixed:"
463
                        color:  colorWhite
dogmaphobic's avatar
dogmaphobic committed
464 465 466
                    }
                    QGCLabel {
                        text:   _controller.telemetryFixed
467
                        color:  colorWhite
dogmaphobic's avatar
dogmaphobic committed
468 469 470
                    }
                    QGCLabel {
                        text:   "TX Buffer:"
471
                        color:  colorWhite
dogmaphobic's avatar
dogmaphobic committed
472 473 474
                    }
                    QGCLabel {
                        text:   _controller.telemetryTXBuffer
475
                        color:  colorWhite
dogmaphobic's avatar
dogmaphobic committed
476 477 478
                    }
                    QGCLabel {
                        text:   "Local Noise:"
479
                        color:  colorWhite
dogmaphobic's avatar
dogmaphobic committed
480 481 482
                    }
                    QGCLabel {
                        text:   _controller.telemetryLNoise
483
                        color:  colorWhite
dogmaphobic's avatar
dogmaphobic committed
484 485 486
                    }
                    QGCLabel {
                        text:   "Remote Noise:"
487
                        color:  colorWhite
dogmaphobic's avatar
dogmaphobic committed
488 489 490
                    }
                    QGCLabel {
                        text:   _controller.telemetryRNoise
491
                        color:  colorWhite
dogmaphobic's avatar
dogmaphobic committed
492 493 494 495 496 497 498 499 500 501 502
                    }
                }
            }
            Component.onCompleted: {
                var pos = mapFromItem(toolBar, centerX - (width / 2), toolBar.height)
                x = pos.x
                y = pos.y + ScreenTools.defaultFontPixelHeight
            }
        }
    }

503 504
    //---------------------------------------------
    // Toolbar Row
dogmaphobic's avatar
dogmaphobic committed
505 506
    Row {
        id:             viewRow
dogmaphobic's avatar
dogmaphobic committed
507 508
        height:         mainWindow.tbCellHeight
        spacing:        mainWindow.tbSpacing
dogmaphobic's avatar
dogmaphobic committed
509
        anchors.left:   parent.left
dogmaphobic's avatar
dogmaphobic committed
510
        anchors.leftMargin:     mainWindow.tbSpacing
dogmaphobic's avatar
dogmaphobic committed
511 512 513 514
        anchors.verticalCenter: parent.verticalCenter

        ExclusiveGroup { id: mainActionGroup }

dogmaphobic's avatar
dogmaphobic committed
515 516 517 518 519 520 521 522 523 524 525 526 527 528 529 530 531
        QGCToolBarButton {
            id:                 preferencesButton
            width:              mainWindow.tbButtonWidth
            height:             mainWindow.tbCellHeight
            source:             "/qmlimages/Hamburger.svg"
            onClicked: {
                mainWindow.showLeftMenu();
                preferencesButton.checked = false;
            }
        }

        Rectangle {
            height: mainWindow.tbCellHeight
            width:  1
            color: Qt.rgba(1,1,1,0.45)
        }

dogmaphobic's avatar
dogmaphobic committed
532 533
        QGCToolBarButton {
            id:                 setupButton
dogmaphobic's avatar
dogmaphobic committed
534 535
            width:              mainWindow.tbButtonWidth
            height:             mainWindow.tbCellHeight
dogmaphobic's avatar
dogmaphobic committed
536
            exclusiveGroup:     mainActionGroup
dogmaphobic's avatar
dogmaphobic committed
537
            source:             "/qmlimages/Gears.svg"
Don Gagne's avatar
Don Gagne committed
538
            onClicked:          toolBar.showSetupView()
dogmaphobic's avatar
dogmaphobic committed
539
        }
540

dogmaphobic's avatar
dogmaphobic committed
541
        Rectangle {
dogmaphobic's avatar
dogmaphobic committed
542
            height: mainWindow.tbCellHeight
dogmaphobic's avatar
dogmaphobic committed
543 544 545
            width:  1
            color: Qt.rgba(1,1,1,0.45)
        }
546

dogmaphobic's avatar
dogmaphobic committed
547 548
        QGCToolBarButton {
            id:                 planButton
dogmaphobic's avatar
dogmaphobic committed
549 550
            width:              mainWindow.tbButtonWidth
            height:             mainWindow.tbCellHeight
dogmaphobic's avatar
dogmaphobic committed
551
            exclusiveGroup:     mainActionGroup
dogmaphobic's avatar
dogmaphobic committed
552
            source:             "/qmlimages/Plan.svg"
Don Gagne's avatar
Don Gagne committed
553
            onClicked:          toolBar.showPlanView()
dogmaphobic's avatar
dogmaphobic committed
554
        }
Don Gagne's avatar
Don Gagne committed
555

dogmaphobic's avatar
dogmaphobic committed
556
        Rectangle {
dogmaphobic's avatar
dogmaphobic committed
557
            height: mainWindow.tbCellHeight
dogmaphobic's avatar
dogmaphobic committed
558 559
            width:  1
            color: Qt.rgba(1,1,1,0.45)
Don Gagne's avatar
Don Gagne committed
560
        }
dogmaphobic's avatar
dogmaphobic committed
561

dogmaphobic's avatar
dogmaphobic committed
562 563
        QGCToolBarButton {
            id:                 flyButton
dogmaphobic's avatar
dogmaphobic committed
564 565
            width:              mainWindow.tbButtonWidth
            height:             mainWindow.tbCellHeight
dogmaphobic's avatar
dogmaphobic committed
566
            exclusiveGroup:     mainActionGroup
dogmaphobic's avatar
dogmaphobic committed
567
            source:             "/qmlimages/PaperPlane.svg"
Don Gagne's avatar
Don Gagne committed
568
            onClicked:          toolBar.showFlyView()
Don Gagne's avatar
Don Gagne committed
569
        }
570

Don Gagne's avatar
Don Gagne committed
571
        Rectangle {
dogmaphobic's avatar
dogmaphobic committed
572
            height: mainWindow.tbCellHeight
dogmaphobic's avatar
dogmaphobic committed
573 574
            width:  1
            color: Qt.rgba(1,1,1,0.45)
Don Gagne's avatar
Don Gagne committed
575
        }
576

dogmaphobic's avatar
dogmaphobic committed
577
    }
578

dogmaphobic's avatar
dogmaphobic committed
579
    Item {
dogmaphobic's avatar
dogmaphobic committed
580
        id:                     vehicleIndicators
dogmaphobic's avatar
dogmaphobic committed
581 582
        height:                 mainWindow.tbCellHeight
        anchors.leftMargin:     mainWindow.tbSpacing * 2
Don Gagne's avatar
Don Gagne committed
583 584
        anchors.left:           viewRow.right
        anchors.right:          parent.right
dogmaphobic's avatar
dogmaphobic committed
585
        anchors.verticalCenter: parent.verticalCenter
Don Gagne's avatar
Don Gagne committed
586

587
        property bool vehicleConnectionLost: activeVehicle ? activeVehicle.connectionLost : false
Don Gagne's avatar
Don Gagne committed
588

dogmaphobic's avatar
dogmaphobic committed
589
        Loader {
590
            source:                 activeVehicle && !parent.vehicleConnectionLost ? "MainToolBarIndicators.qml" : ""
Don Gagne's avatar
Don Gagne committed
591 592
            anchors.left:           parent.left
            anchors.verticalCenter: parent.verticalCenter
Don Gagne's avatar
Don Gagne committed
593
        }
dogmaphobic's avatar
dogmaphobic committed
594

Don Gagne's avatar
Don Gagne committed
595 596 597 598 599 600 601 602
        QGCLabel {
            id:                     connectionLost
            text:                   "CONNECTION LOST"
            font.pixelSize:         tbFontLarge
            font.weight:            Font.DemiBold
            color:                  colorRed
            anchors.left:           parent.left
            anchors.verticalCenter: parent.verticalCenter
603
            visible:                parent.vehicleConnectionLost
Don Gagne's avatar
Don Gagne committed
604 605 606 607 608 609 610 611

        }

        QGCButton {
            anchors.rightMargin:     mainWindow.tbSpacing * 2
            anchors.right:          parent.right
            anchors.verticalCenter: parent.verticalCenter
            text:                   "Disconnect"
612
            visible:                parent.vehicleConnectionLost
Don Gagne's avatar
Don Gagne committed
613 614
            onClicked:              activeVehicle.disconnectInactiveVehicle()
        }
dogmaphobic's avatar
dogmaphobic committed
615
    }
dogmaphobic's avatar
dogmaphobic committed
616

617 618
    // Progress bar
    Rectangle {
Don Gagne's avatar
Don Gagne committed
619
        id:             progressBar
dogmaphobic's avatar
dogmaphobic committed
620 621
        anchors.bottom: parent.bottom
        height:         toolBar.height * 0.05
622
        width:          parent.width * _controller.progressBarValue
dogmaphobic's avatar
dogmaphobic committed
623
        color:          colorGreen
624
    }
dogmaphobic's avatar
dogmaphobic committed
625

626
}