FactSliderPanel.qml 3.43 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
import QtQuick              2.3
import QtQuick.Controls     1.2
Don Gagne's avatar
Don Gagne committed
13 14

import QGroundControl.FactSystem    1.0
15
import QGroundControl.FactControls  1.0
Don Gagne's avatar
Don Gagne committed
16 17 18 19
import QGroundControl.Palette       1.0
import QGroundControl.Controls      1.0
import QGroundControl.ScreenTools   1.0

20
Column {
Don Gagne's avatar
Don Gagne committed
21 22 23 24 25 26 27 28 29 30 31
    /// 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

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

Don Gagne's avatar
Don Gagne committed
35 36
    Component.onCompleted: _loadComplete = true

37
    FactPanelController {
38
        id: controller
39 40 41
    }

    QGCPalette { id: palette; colorGroupEnabled: enabled }
Don Gagne's avatar
Don Gagne committed
42

43 44 45 46 47
    Column {
        id:                 sliderOuterColumn
        anchors.left:       parent.left
        anchors.right:      parent.right
        spacing:            _margins
Don Gagne's avatar
Don Gagne committed
48

49 50 51
        Repeater {
            id:     sliderRepeater
            model:  sliderModel
Don Gagne's avatar
Don Gagne committed
52

53 54
            Rectangle {
                id:                 sliderRect
Don Gagne's avatar
Don Gagne committed
55 56
                anchors.left:       parent.left
                anchors.right:      parent.right
57 58 59 60 61 62 63 64 65
                height:             sliderColumn.y + sliderColumn.height + _margins
                color:              palette.windowShade

                Column {
                    id:                 sliderColumn
                    anchors.margins:    _margins
                    anchors.left:       parent.left
                    anchors.right:      parent.right
                    anchors.top:        sliderRect.top
66
                    spacing:            _margins
67 68 69 70 71 72

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

Don Gagne's avatar
Don Gagne committed
73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88
                    Slider {
                        anchors.left:       parent.left
                        anchors.right:      parent.right
                        minimumValue:       min
                        maximumValue:       max
                        stepSize:           step
                        tickmarksEnabled:   true
                        value:              _fact.value

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

                        onValueChanged: {
                            if (_loadComplete) {
                                _fact.value = value
                            }
                        }
89 90
                    }

91 92 93 94 95 96
                    QGCLabel {
                        text:           description
                        anchors.left:   parent.left
                        anchors.right:  parent.right
                        wrapMode:       Text.WordWrap
                    }
97 98 99 100 101
                }
            }
        }
    }
}