VehicleSummary.qml 6.11 KB
Newer Older
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23
/*=====================================================================

 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/>.

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

24 25 26
import QtQuick                  2.2
import QtQuick.Controls         1.2
import QtQuick.Controls.Styles  1.2
27

28 29 30 31
import QGroundControl.FactSystem            1.0
import QGroundControl.Controls              1.0
import QGroundControl.ScreenTools           1.0
import QGroundControl.MultiVehicleManager   1.0
32
import QGroundControl.Palette               1.0
33 34

Rectangle {
dogmaphobic's avatar
dogmaphobic committed
35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63
    id:             _summaryRoot
    anchors.fill:   parent
    color:          qgcPal.window

    property real _minSummaryW:     ScreenTools.defaultFontPixelWidth * 30
    property real _summaryBoxWidth: _minSummaryW
    property real _summaryBoxSpace: ScreenTools.defaultFontPixelWidth

    function computeSummaryBoxSize() {
        var sw  = 0
        var rw  = 0
        var idx = Math.floor(_summaryRoot.width / (_minSummaryW + ScreenTools.defaultFontPixelWidth))
        if(idx < 1) {
            _summaryBoxWidth = _summaryRoot.width
            _summaryBoxSpace = 0
        } else {
            _summaryBoxSpace = 0
            if(idx > 1) {
                _summaryBoxSpace = ScreenTools.defaultFontPixelWidth
                sw = _summaryBoxSpace * (idx - 1)
            }
            rw = _summaryRoot.width - sw
            _summaryBoxWidth = rw / idx
        }
    }

    function capitalizeWords(sentence) {
        return sentence.replace(/(?:^|\s)\S/g, function(a) { return a.toUpperCase(); });
    }
64

65 66 67 68 69
    QGCPalette {
        id:                 qgcPal
        colorGroupEnabled:  enabled
    }

dogmaphobic's avatar
dogmaphobic committed
70 71 72
    Component.onCompleted: {
        computeSummaryBoxSize()
    }
73

dogmaphobic's avatar
dogmaphobic committed
74 75 76
    onWidthChanged: {
        computeSummaryBoxSize()
    }
77

dogmaphobic's avatar
dogmaphobic committed
78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94
    Flickable {
        clip:               true
        anchors.fill:       parent
        contentHeight:      summaryColumn.height
        contentWidth:       _summaryRoot.width
        flickableDirection: Flickable.VerticalFlick
        boundsBehavior:     Flickable.StopAtBounds

        Column {
            id:             summaryColumn
            width:          _summaryRoot.width
            spacing:        ScreenTools.defaultFontPixelHeight

            QGCLabel {
                width:			parent.width
                wrapMode:		Text.WordWrap
                color:			setupComplete ? qgcPal.text : qgcPal.warningText
dogmaphobic's avatar
dogmaphobic committed
95
                font.weight:    Font.DemiBold
dogmaphobic's avatar
dogmaphobic committed
96
                text:           setupComplete ?
dogmaphobic's avatar
dogmaphobic committed
97 98
                    "Below you will find a summary of the settings for your vehicle. To the left are the setup menus for each component." :
                    "WARNING: Your vehicle requires setup prior to flight. Please resolve the items marked in red using the menu on the left."
dogmaphobic's avatar
dogmaphobic committed
99 100
                property bool setupComplete: multiVehicleManager.activeVehicle.autopilot.setupComplete
            }
101

dogmaphobic's avatar
dogmaphobic committed
102 103 104 105
            Flow {
                id:         _flowCtl
                width:      _summaryRoot.width
                spacing:    _summaryBoxSpace
106

dogmaphobic's avatar
dogmaphobic committed
107 108
                Repeater {
                    model: multiVehicleManager.activeVehicle.autopilot.vehicleComponents
109

dogmaphobic's avatar
dogmaphobic committed
110
                    // Outer summary item rectangle
Don Gagne's avatar
Don Gagne committed
111
                    Rectangle {
dogmaphobic's avatar
dogmaphobic committed
112 113 114 115 116
                        width:  _summaryBoxWidth
                        height: ScreenTools.defaultFontPixelHeight * 13
                        color:  qgcPal.window

                        readonly property real titleHeight: ScreenTools.defaultFontPixelHeight * 2
117

dogmaphobic's avatar
dogmaphobic committed
118
                        // Title bar
119
                        Rectangle {
dogmaphobic's avatar
dogmaphobic committed
120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143
                            id:     titleBar
                            width:  parent.width
                            height: titleHeight
                            color:  qgcPal.windowShade

                            // Title text
                            QGCLabel {
                                anchors.fill:           parent
                                verticalAlignment:      TextEdit.AlignVCenter
                                horizontalAlignment:    TextEdit.AlignHCenter
                                text:                   capitalizeWords(modelData.name)
                            }

                            // Setup indicator
                            Rectangle {
                                anchors.rightMargin:    ScreenTools.defaultFontPixelWidth / 3
                                anchors.right:          parent.right
                                anchors.verticalCenter: parent.verticalCenter
                                width:                  ScreenTools.defaultFontPixelWidth
                                height:                 width
                                radius:                 width / 2
                                color:                  modelData.setupComplete ? "#00d932" : "red"
                                visible:                modelData.requiresSetup
                            }
144
                        }
145

dogmaphobic's avatar
dogmaphobic committed
146 147 148 149 150 151 152 153
                        // Summary Qml
                        Rectangle {
                            anchors.top:    titleBar.bottom
                            width:          parent.width
                            Loader {
                                anchors.fill:   parent
                                source:         modelData.summaryQmlSource
                            }
154 155 156 157 158 159 160
                        }
                    }
                }
            }
        }
    }
}