FactSliderPanel.qml 4.39 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.
 *
 ****************************************************************************/
Don Gagne's avatar
Don Gagne committed
9 10 11 12 13 14 15 16 17 18


import QtQuick              2.5
import QtQuick.Controls     1.4

import QGroundControl.FactSystem    1.0
import QGroundControl.Palette       1.0
import QGroundControl.Controls      1.0
import QGroundControl.ScreenTools   1.0

19
Column {
Don Gagne's avatar
Don Gagne committed
20 21 22 23 24 25 26 27 28 29 30
    /// ListModel must contains elements which look like this:
    ///     ListElement {
    ///         title:          "Roll sensitivity"
    ///         description:    "Slide to the left to make roll control faster and more accurate. Slide to the right if roll oscillates or is too twitchy."
    ///         param:          "MC_ROLL_TC"
    ///         min:            0
    ///         max:            100
    ///         step:           1
    ///     }
    property ListModel sliderModel

31
    property var qgcViewPanel
Don Gagne's avatar
Don Gagne committed
32

33 34
    property real _margins:         ScreenTools.defaultFontPixelHeight
    property bool _loadComplete:    false
Don Gagne's avatar
Don Gagne committed
35

36 37 38 39 40 41
    FactPanelController {
        id:         controller
        factPanel:  qgcViewPanel
    }

    QGCPalette { id: palette; colorGroupEnabled: enabled }
Don Gagne's avatar
Don Gagne committed
42 43 44 45 46 47 48 49 50 51 52 53 54

    Component.onCompleted: {
        // Qml Sliders have a strange behavior in which they first set Slider::value to some internal
        // setting and then set Slider::value to the bound properties value. If you have an onValueChanged
        // handler which updates your property with the new value, this first value change will trash
        // your bound values. In order to work around this we don't set the values into the Sliders until
        // after Qml load is done. We also don't track value changes until Qml load completes.
        for (var i=0; i<sliderModel.count; i++) {
            sliderRepeater.itemAt(i).sliderValue = controller.getParameterFact(-1, sliderModel.get(i).param).value
        }
        _loadComplete = true
    }

55 56 57 58 59
    QGCLabel {
        id:             panelLabel
        text:           panelTitle
        font.family:    ScreenTools.demiboldFontFamily
    }
Don Gagne's avatar
Don Gagne committed
60

61 62 63 64 65
    Column {
        id:                 sliderOuterColumn
        anchors.left:       parent.left
        anchors.right:      parent.right
        spacing:            _margins
Don Gagne's avatar
Don Gagne committed
66

67 68 69
        Repeater {
            id:     sliderRepeater
            model:  sliderModel
Don Gagne's avatar
Don Gagne committed
70

71 72
            Rectangle {
                id:                 sliderRect
Don Gagne's avatar
Don Gagne committed
73 74
                anchors.left:       parent.left
                anchors.right:      parent.right
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
                height:             sliderColumn.y + sliderColumn.height + _margins
                color:              palette.windowShade

                property alias sliderValue: slider.value

                Column {
                    id:                 sliderColumn
                    anchors.margins:    _margins
                    anchors.left:       parent.left
                    anchors.right:      parent.right
                    anchors.top:        sliderRect.top

                    QGCLabel {
                        text:           title
                        font.family:    ScreenTools.demiboldFontFamily
                    }

                    QGCLabel {
                        text:           description
                        anchors.left:   parent.left
                        anchors.right:  parent.right
                        wrapMode:       Text.WordWrap
                    }

                    Slider {
                        id:                 slider
Don Gagne's avatar
Don Gagne committed
101 102
                        anchors.left:       parent.left
                        anchors.right:      parent.right
103 104 105 106
                        minimumValue:       min
                        maximumValue:       max
                        stepSize:           isNaN(fact.increment) ? step : fact.increment
                        tickmarksEnabled:   true
Don Gagne's avatar
Don Gagne committed
107

108
                        property Fact fact: controller.getParameterFact(-1, param)
Don Gagne's avatar
Don Gagne committed
109

110 111 112
                        onValueChanged: {
                            if (_loadComplete) {
                                fact.value = value
Don Gagne's avatar
Don Gagne committed
113
                            }
114 115 116 117 118 119
                        }
                    } // Slider
                } // Column
            } // Rectangle
        } // Repeater
    } // Column
Don Gagne's avatar
Don Gagne committed
120
} // QGCView