InstrumentValueEditDialog.qml 21.7 KB
Newer Older
1 2 3 4 5 6 7 8 9 10 11 12 13 14
/****************************************************************************
 *
 * (c) 2009-2020 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.
 *
 ****************************************************************************/

import QtQuick          2.12
import QtQuick.Dialogs  1.3
import QtQuick.Layouts  1.2
import QtQuick.Controls 2.5

15
import QGroundControl               1.0
16 17 18 19 20 21 22 23 24 25 26 27
import QGroundControl.Controls      1.0
import QGroundControl.ScreenTools   1.0
import QGroundControl.FactSystem    1.0
import QGroundControl.FactControls  1.0
import QGroundControl.Controllers   1.0
import QGroundControl.Palette       1.0

QGCPopupDialog {
    id:         root
    title:      qsTr("Value Display")
    buttons:    StandardButton.Close

28 29
    property var instrumentValueData: dialogProperties.instrumentValueData

30 31 32 33 34 35 36 37 38 39 40 41
    QGCPalette { id: qgcPal;            colorGroupEnabled: parent.enabled }
    QGCPalette { id: qgcPalDisabled;    colorGroupEnabled: false }

    Loader {
        sourceComponent: instrumentValueData.fact ? editorComponent : noFactComponent
    }

    Component {
        id: noFactComponent

        QGCLabel {
            text: qsTr("Valuec requires a connected vehicle for setup.")
42
        }
43
    }
44

45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67
    Component {
        id: editorComponent

        GridLayout {
            rowSpacing:     _margins
            columnSpacing:  _margins
            columns:        2

            QGCComboBox {
                id:                     factGroupCombo
                Layout.fillWidth:       true
                model:                  instrumentValueData.factGroupNames
                sizeToContents:         true
                Component.onCompleted:  currentIndex = find(instrumentValueData.factGroupName)
                onActivated: {
                    instrumentValueData.setFact(currentText, "")
                    instrumentValueData.icon = ""
                    instrumentValueData.text = instrumentValueData.fact.shortDescription
                }
                Connections {
                    target: instrumentValueData
                    onFactGroupNameChanged: factGroupCombo.currentIndex = factGroupCombo.find(instrumentValueData.factGroupName)
                }
68 69
            }

70 71 72 73 74 75 76 77 78 79 80 81 82 83 84
            QGCComboBox {
                id:                     factNamesCombo
                Layout.fillWidth:       true
                model:                  instrumentValueData.factValueNames
                sizeToContents:         true
                Component.onCompleted:  currentIndex = find(instrumentValueData.factName)
                onActivated: {
                    instrumentValueData.setFact(instrumentValueData.factGroupName, currentText)
                    instrumentValueData.icon = ""
                    instrumentValueData.text = instrumentValueData.fact.shortDescription
                }
                Connections {
                    target: instrumentValueData
                    onFactNameChanged: factNamesCombo.currentIndex = factNamesCombo.find(instrumentValueData.factName)
                }
85 86
            }

87 88 89 90
            QGCRadioButton {
                id:                     iconRadio
                text:                   qsTr("Icon")
                Component.onCompleted:  checked = instrumentValueData.icon != ""
91
                onClicked: {
92 93
                    instrumentValueData.text = ""
                    instrumentValueData.icon = instrumentValueData.factValueGrid.iconNames[0]
94
                    var updateFunction = function(icon){ instrumentValueData.icon = icon }
95
                    mainWindow.showPopupDialogFromComponent(iconPickerDialog, { iconNames: instrumentValueData.factValueGrid.iconNames, icon: instrumentValueData.icon, updateIconFunction: updateFunction })
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
            QGCColoredImage {
                id:                 valueIcon
                Layout.alignment:   Qt.AlignHCenter
                height:             ScreenTools.implicitComboBoxHeight
                width:              height
                source:             "/InstrumentValueIcons/" + (instrumentValueData.icon ? instrumentValueData.icon : instrumentValueData.factValueGrid.iconNames[0])
                sourceSize.height:  height
                fillMode:           Image.PreserveAspectFit
                mipmap:             true
                smooth:             true
                color:              enabled ? qgcPal.text : qgcPalDisabled.text
                enabled:            iconRadio.checked

                MouseArea {
                    anchors.fill:   parent
                    onClicked: {
                        var updateFunction = function(icon){ instrumentValueData.icon = icon }
                        mainWindow.showPopupDialogFromComponent(iconPickerDialog, { iconNames: instrumentValueData.factValueGrid.iconNames, icon: instrumentValueData.icon, updateIconFunction: updateFunction })
                    }
                }

                Rectangle {
                    anchors.fill:   valueIcon
                    color:          qgcPal.text
                    visible:        valueIcon.status === Image.Error
                }
125
            }
126

127 128 129 130 131 132 133 134
            QGCRadioButton {
                id:                     textRadio
                text:                   qsTr("Text")
                Component.onCompleted:  checked = instrumentValueData.icon == ""
                onClicked: {
                    instrumentValueData.icon = ""
                    instrumentValueData.text = instrumentValueData.fact ? instrumentValueData.fact.shortDescription : qsTr("Label")
                }
135 136
            }

137 138 139 140 141 142 143 144
            QGCTextField {
                id:                     labelTextField
                Layout.fillWidth:       true
                Layout.preferredWidth:  ScreenTools.defaultFontPixelWidth * 10
                text:                   instrumentValueData.text
                enabled:                textRadio.checked
                onEditingFinished:      instrumentValueData.text = text
            }
145

146
            QGCLabel { text: qsTr("Size") }
147

148 149 150 151 152 153 154 155
            QGCComboBox {
                id:                 fontSizeCombo
                Layout.fillWidth:   true
                model:              instrumentValueData.factValueGrid.fontSizeNames
                currentIndex:       instrumentValueData.factValueGrid.fontSize
                sizeToContents:     true
                onActivated:        instrumentValueData.factValueGrid.fontSize = index
            }
156

157 158 159 160 161 162
            QGCCheckBox {
                Layout.columnSpan:  2
                text:               qsTr("Show Units")
                checked:            instrumentValueData.showUnits
                onClicked:          instrumentValueData.showUnits = checked
            }
163

164
            QGCLabel { text: qsTr("Range") }
165

166 167 168 169 170 171 172 173
            QGCComboBox {
                id:                 rangeTypeCombo
                Layout.fillWidth:   true
                model:              instrumentValueData.rangeTypeNames
                currentIndex:       instrumentValueData.rangeType
                sizeToContents:     true
                onActivated:        instrumentValueData.rangeType = index
            }
174

175 176 177 178 179 180 181 182 183 184 185 186 187 188 189 190 191 192 193 194 195 196 197 198
            Loader {
                id:                     rangeLoader
                Layout.columnSpan:      2
                Layout.fillWidth:       true
                Layout.preferredWidth:  item ? item.width : 0
                Layout.preferredHeight: item ? item.height : 0

                property var instrumentValueData: root.instrumentValueData

                function updateSourceComponent() {
                    switch (instrumentValueData.rangeType) {
                    case InstrumentValueData.NoRangeInfo:
                        sourceComponent = undefined
                        break
                    case InstrumentValueData.ColorRange:
                        sourceComponent = colorRangeDialog
                        break
                    case InstrumentValueData.OpacityRange:
                        sourceComponent = opacityRangeDialog
                        break
                    case InstrumentValueData.IconSelvalueedectRange:
                        sourceComponent = iconRangeDialog
                        break
                    }
199 200
                }

201
                Component.onCompleted: updateSourceComponent()
202

203 204 205 206
                Connections {
                    target:             instrumentValueData
                    onRangeTypeChanged: rangeLoader.updateSourceComponent()
                }
207

208
            }
209 210 211 212 213 214 215 216 217 218 219
        }
    }

    Component {
        id: colorRangeDialog

        Item {
            width:  childrenRect.width
            height: childrenRect.height

            function updateRangeValue(index, text) {
220
                var newValues = instrumentValueData.rangeValues
221
                newValues[index] = parseFloat(text)
222
                instrumentValueData.rangeValues = newValues
223 224 225
            }

            function updateColorValue(index, color) {
226
                var newColors = instrumentValueData.rangeColors
227
                newColors[index] = color
228
                instrumentValueData.rangeColors = newColors
229 230 231 232 233
            }

            ColorDialog {
                id:             colorPickerDialog
                modality:       Qt.ApplicationModal
234
                currentColor:   instrumentValueData.rangeColors.length ? instrumentValueData.rangeColors[colorIndex] : "white"
235 236 237 238 239 240 241 242 243 244 245 246 247 248 249 250 251 252 253 254 255 256 257 258
                onAccepted:     updateColorValue(colorIndex, color)

                property int colorIndex: 0
            }

            Column {
                id:         mainColumn
                spacing:    ScreenTools.defaultFontPixelHeight / 2

                QGCLabel {
                    width:      rowLayout.width
                    text:       qsTr("Specify the color you want to apply based on value ranges. The color will be applied to the icon if available, otherwise to the value itself.")
                    wrapMode:   Text.WordWrap
                }

                Row {
                    id:         rowLayout
                    spacing:    _margins

                    Column {
                        anchors.verticalCenter: parent.verticalCenter
                        spacing:                _margins

                        Repeater {
259
                            model: instrumentValueData.rangeValues.length
260 261 262 263 264

                            QGCButton {
                                width:      ScreenTools.implicitTextFieldHeight
                                height:     width
                                text:       qsTr("-")
265
                                onClicked:  instrumentValueData.removeRangeValue(index)
266 267 268 269 270 271 272 273 274
                            }
                        }
                    }

                    Column {
                        anchors.verticalCenter: parent.verticalCenter
                        spacing:                _margins

                        Repeater {
275
                            model: instrumentValueData.rangeValues.length
276 277

                            QGCTextField {
278
                                text:               instrumentValueData.rangeValues[index]
279 280 281 282 283 284 285 286
                                onEditingFinished:  updateRangeValue(index, text)
                            }
                        }
                    }

                    Column {
                        spacing: _margins
                        Repeater {
287
                            model: instrumentValueData.rangeColors
288 289 290

                            QGCCheckBox {
                                height:     ScreenTools.implicitTextFieldHeight
291 292
                                checked:    instrumentValueData.isValidColor(instrumentValueData.rangeColors[index])
                                onClicked:  updateColorValue(index, checked ? "green" : instrumentValueData.invalidColor())
293 294 295 296 297 298 299
                            }
                        }
                    }

                    Column {
                        spacing: _margins
                        Repeater {
300
                            model: instrumentValueData.rangeColors
301 302 303 304 305

                            Rectangle {
                                width:          ScreenTools.implicitTextFieldHeight
                                height:         width
                                border.color:   qgcPal.text
306
                                color:          instrumentValueData.isValidColor(modelData) ? modelData : qgcPal.text
307 308 309 310 311 312 313 314 315 316 317 318 319 320 321

                                MouseArea {
                                    anchors.fill: parent
                                    onClicked: {
                                        colorPickerDialog.colorIndex = index
                                        colorPickerDialog.open()
                                    }
                                }
                            }
                        }
                    }
                }

                QGCButton {
                    text:       qsTr("Add Row")
322
                    onClicked:  instrumentValueData.addRangeValue()
323 324 325 326 327 328 329 330 331
                }
            }
        }
    }

    Component {
        id: iconRangeDialog

        Item {
332
            width:  childrenRect.widthvalueed
333 334 335
            height: childrenRect.height

            function updateRangeValue(index, text) {
336
                var newValues = instrumentValueData.rangeValues
337
                newValues[index] = parseFloat(text)
338
                instrumentValueData.rangeValues = newValues
339 340 341
            }

            function updateIconValue(index, icon) {
342
                var newIcons = instrumentValueData.rangeIcons
343
                newIcons[index] = icon
344
                instrumentValueData.rangeIcons = newIcons
345 346 347 348 349 350 351 352 353 354 355 356 357 358 359 360 361 362 363 364 365
            }

            Column {
                id:         mainColumn
                spacing:    ScreenTools.defaultFontPixelHeight / 2

                QGCLabel {
                    width:      rowLayout.width
                    text:       qsTr("Specify the icon you want to display based on value ranges.")
                    wrapMode:   Text.WordWrap
                }

                Row {
                    id:         rowLayout
                    spacing:    _margins

                    Column {
                        anchors.verticalCenter: parent.verticalCenter
                        spacing:                _margins

                        Repeater {
366
                            model: instrumentValueData.rangeValues.length
367 368 369 370 371

                            QGCButton {
                                width:      ScreenTools.implicitTextFieldHeight
                                height:     width
                                text:       qsTr("-")
372
                                onClicked:  instrumentValueData.removeRangeValue(index)
373 374 375 376 377 378 379 380 381
                            }
                        }
                    }

                    Column {
                        anchors.verticalCenter: parent.verticalCenter
                        spacing:                _margins

                        Repeater {
382
                            model: instrumentValueData.rangeValues.length
383 384

                            QGCTextField {
385
                                text:               instrumentValueData.rangeValues[index]
386 387 388 389 390 391 392 393 394
                                onEditingFinished:  updateRangeValue(index, text)
                            }
                        }
                    }

                    Column {
                        spacing: _margins

                        Repeater {
395
                            model: instrumentValueData.rangeIcons
396 397 398 399 400 401 402 403 404 405 406 407 408 409 410

                            QGCColoredImage {
                                height:             ScreenTools.implicitTextFieldHeight
                                width:              height
                                source:             "/InstrumentValueIcons/" + modelData
                                sourceSize.height:  height
                                fillMode:           Image.PreserveAspectFit
                                mipmap:             true
                                smooth:             true
                                color:              qgcPal.text

                                MouseArea {
                                    anchors.fill:   parent
                                    onClicked: {
                                        var updateFunction = function(icon){ updateIconValue(index, icon) }
411
                                        mainWindow.showPopupDialogFromComponent(iconPickerDialog, { iconNames: instrumentValueData.factValueGrid.iconNames, icon: modelData, updateIconFunction: updateFunction })
412 413 414 415 416 417 418 419 420
                                    }
                                }
                            }
                        }
                    }
                }

                QGCButton {
                    text:       qsTr("Add Row")
421
                    onClicked:  instrumentValueData.addRangeValue()
422 423 424 425 426 427 428 429 430 431 432 433 434
                }
            }
        }
    }

    Component {
        id: opacityRangeDialog

        Item {
            width:  childrenRect.width
            height: childrenRect.height

            function updateRangeValue(index, text) {
435
                var newValues = instrumentValueData.rangeValues
436
                newValues[index] = parseFloat(text)
437
                instrumentValueData.rangeValues = newValues
438 439 440
            }

            function updateOpacityValue(index, opacity) {
441
                var newOpacities = instrumentValueData.rangeOpacities
442
                newOpacities[index] = opacity
443
                instrumentValueData.rangeOpacities = newOpacities
444 445 446 447 448 449 450 451 452 453 454 455 456 457 458 459 460 461 462 463 464
            }

            Column {
                id:         mainColumn
                spacing:    ScreenTools.defaultFontPixelHeight / 2

                QGCLabel {
                    width:      rowLayout.width
                    text:       qsTr("Specify the icon opacity you want based on value ranges.")
                    wrapMode:   Text.WordWrap
                }

                Row {
                    id:         rowLayout
                    spacing:    _margins

                    Column {
                        anchors.verticalCenter: parent.verticalCenter
                        spacing:                _margins

                        Repeater {
465
                            model: instrumentValueData.rangeValues.length
466 467 468 469 470

                            QGCButton {
                                width:      ScreenTools.implicitTextFieldHeight
                                height:     width
                                text:       qsTr("-")
471
                                onClicked:  instrumentValueData.removeRangeValue(index)
472 473 474 475 476 477 478 479 480
                            }
                        }
                    }

                    Column {
                        anchors.verticalCenter: parent.verticalCenter
                        spacing:                _margins

                        Repeater {
481
                            model: instrumentValueData.rangeValues
482 483 484 485 486 487 488 489 490 491 492 493

                            QGCTextField {
                                text:               modelData
                                onEditingFinished:  updateRangeValue(index, text)
                            }
                        }
                    }

                    Column {
                        spacing: _margins

                        Repeater {
494
                            model: instrumentValueData.rangeOpacities
495 496 497 498 499 500 501 502 503 504 505

                            QGCTextField {
                                text:               modelData
                                onEditingFinished:  updateOpacityValue(index, text)
                            }
                        }
                    }
                }

                QGCButton {
                    text:       qsTr("Add Row")
506
                    onClicked:  instrumentValueData.addRangeValue()
507 508 509 510 511 512 513 514 515 516 517 518 519 520 521 522 523 524 525 526 527 528 529 530 531 532 533 534 535 536 537 538 539 540 541 542 543 544 545 546 547 548 549 550 551 552 553 554 555 556 557 558 559 560 561 562 563
                }
            }
        }
    }

    Component {
        id: iconPickerDialog

        QGCPopupDialog {
            property var     iconNames:             dialogProperties.iconNames
            property string  icon:                  dialogProperties.icon
            property var     updateIconFunction:    dialogProperties.updateIconFunction

            title:      qsTr("Select Icon")
            buttons:    StandardButton.Close

            GridLayout {
                columns:        10
                columnSpacing:  0
                rowSpacing:     0

                Repeater {
                    model: iconNames

                    Rectangle {
                        height: ScreenTools.minTouchPixels
                        width:  height
                        color:  currentSelection ? qgcPal.text  : qgcPal.window

                        property bool currentSelection: icon == modelData

                        QGCColoredImage {
                            anchors.centerIn:   parent
                            height:             parent.height * 0.75
                            width:              height
                            source:             "/InstrumentValueIcons/" + modelData
                            sourceSize.height:  height
                            fillMode:           Image.PreserveAspectFit
                            mipmap:             true
                            smooth:             true
                            color:              currentSelection ? qgcPal.window : qgcPal.text

                            MouseArea {
                                anchors.fill:   parent
                                onClicked:  {
                                    icon = modelData
                                    updateIconFunction(modelData)
                                    hideDialog()
                                }
                            }
                        }
                    }
                }
            }
        }
    }
}