FactSliderPanel.qml 5.86 KB
Newer Older
Don Gagne's avatar
Don Gagne 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 30 31 32 33 34 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 64 65 66 67 68 69 70
/*=====================================================================

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

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

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

QGCView {
    viewPanel: panel

    property string panelTitle: "Title" ///< Title for panel

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

    FactPanelController { id: controller; factPanel: panel }

    QGCPalette { id: palette; colorGroupEnabled: enabled }
    property real _margins: ScreenTools.defaultFontPixelHeight

    property bool _loadComplete: false

    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
    }

    QGCViewPanel {
        id:             panel
        anchors.fill:   parent

Don Gagne's avatar
Don Gagne committed
71
        QGCFlickable {
Don Gagne's avatar
Don Gagne committed
72 73
            clip:               true
            anchors.fill:       parent
Don Gagne's avatar
Don Gagne committed
74
            contentHeight:      sliderOuterColumn.y + sliderOuterColumn.height
Don Gagne's avatar
Don Gagne committed
75 76 77 78 79
            flickableDirection: Flickable.VerticalFlick

            QGCLabel {
                id:             panelLabel
                text:           panelTitle
80
                font.family:    ScreenTools.demiboldFontFamily
Don Gagne's avatar
Don Gagne committed
81 82
            }

Don Gagne's avatar
Don Gagne committed
83 84

            Column {
Don Gagne's avatar
Don Gagne committed
85
                id:                 sliderOuterColumn
Don Gagne's avatar
Don Gagne committed
86
                anchors.margins:    _margins
Don Gagne's avatar
Don Gagne committed
87 88 89
                anchors.left:       parent.left
                anchors.right:      parent.right
                anchors.top:        panelLabel.bottom
Don Gagne's avatar
Don Gagne committed
90
                spacing:            _margins
Don Gagne's avatar
Don Gagne committed
91

Don Gagne's avatar
Don Gagne committed
92 93 94
                Repeater {
                    id:     sliderRepeater
                    model:  sliderModel
Don Gagne's avatar
Don Gagne committed
95

Don Gagne's avatar
Don Gagne committed
96 97 98 99 100 101
                    Rectangle {
                        id:                 sliderRect
                        anchors.left:       parent.left
                        anchors.right:      parent.right
                        height:             sliderColumn.y + sliderColumn.height + _margins
                        color:              palette.windowShade
Don Gagne's avatar
Don Gagne committed
102

Don Gagne's avatar
Don Gagne committed
103 104
                        property alias sliderValue: slider.value

Don Gagne's avatar
Don Gagne committed
105
                        Column {
Don Gagne's avatar
Don Gagne committed
106 107 108 109 110
                            id:                 sliderColumn
                            anchors.margins:    _margins
                            anchors.left:       parent.left
                            anchors.right:      parent.right
                            anchors.top:        sliderRect.top
Don Gagne's avatar
Don Gagne committed
111 112 113

                            QGCLabel {
                                text:           title
114
                                font.family:    ScreenTools.demiboldFontFamily
Don Gagne's avatar
Don Gagne committed
115 116 117
                            }

                            QGCLabel {
Don Gagne's avatar
Don Gagne committed
118 119 120 121
                                text:           description
                                anchors.left:   parent.left
                                anchors.right:  parent.right
                                wrapMode:       Text.WordWrap
Don Gagne's avatar
Don Gagne committed
122 123 124 125 126 127 128 129
                            }

                            Slider {
                                id:                 slider
                                anchors.left:       parent.left
                                anchors.right:      parent.right
                                minimumValue:       min
                                maximumValue:       max
Don Gagne's avatar
Don Gagne committed
130
                                stepSize:           isNaN(fact.increment) ? step : fact.increment
Don Gagne's avatar
Don Gagne committed
131 132 133 134 135 136 137 138 139
                                tickmarksEnabled:   true

                                property Fact fact: controller.getParameterFact(-1, param)

                                onValueChanged: {
                                    if (_loadComplete) {
                                        fact.value = value
                                    }
                                }
Don Gagne's avatar
Don Gagne committed
140
                            } // Slider
Don Gagne's avatar
Don Gagne committed
141
                        } // Column
Don Gagne's avatar
Don Gagne committed
142 143 144
                    } // Rectangle
                } // Repeater
            } // Column
Don Gagne's avatar
Don Gagne committed
145
        } // QGCFlickable
Don Gagne's avatar
Don Gagne committed
146 147
    } // QGCViewPanel
} // QGCView