QGCSpeedWidget.qml 3.4 KB
Newer Older
dogmaphobic's avatar
dogmaphobic 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
/*=====================================================================

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

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

/**
 * @file
 *   @brief QGC Speed Indicator
 *   @author Gus Grubba <mavlink@grubba.com>
 */

import QtQuick 2.4
dogmaphobic's avatar
dogmaphobic committed
31
import QGroundControl.ScreenTools 1.0
32
import QGroundControl.Controls 1.0
dogmaphobic's avatar
dogmaphobic committed
33 34 35 36

Rectangle {
    id: root
    property real speed:           0
Don Gagne's avatar
Don Gagne committed
37 38
    property real _reticleSpacing: ScreenTools.defaultFontPixelSize * (0.83)
    property real _reticleHeight:  ScreenTools.defaultFontPixelSize * (0.166)
dogmaphobic's avatar
dogmaphobic committed
39 40
    property real _reticleSlot:    _reticleSpacing + _reticleHeight
    anchors.verticalCenter: parent.verticalCenter
dogmaphobic's avatar
dogmaphobic committed
41
    z:10
dogmaphobic's avatar
dogmaphobic committed
42
    smooth: true
Don Gagne's avatar
Don Gagne committed
43
    radius: ScreenTools.defaultFontPixelSize * (0.42)
dogmaphobic's avatar
dogmaphobic committed
44 45
    border.color: Qt.rgba(1,1,1,0.25)
    gradient: Gradient {
46 47 48
        GradientStop { position: 0.0; color: Qt.rgba(0,0,0,0.65) }
        GradientStop { position: 0.5; color: Qt.rgba(0,0,0,0.25) }
        GradientStop { position: 1.0; color: Qt.rgba(0,0,0,0.65) }
dogmaphobic's avatar
dogmaphobic committed
49
    }
50 51
    Rectangle {
        id:     clipRect
Don Gagne's avatar
Don Gagne committed
52
        height: parent.height - ScreenTools.defaultFontPixelSize * (0.42)
53 54 55
        width:  parent.width
        clip:   true
        color:  Qt.rgba(0,0,0,0);
56
        anchors.verticalCenter: parent.verticalCenter
57 58 59 60 61 62 63 64 65
        Column{
            id: col
            width: parent.width
            anchors.verticalCenter: parent.verticalCenter
            spacing: _reticleSpacing
            Repeater {
                model: 40
                Rectangle {
                    property int _speed: -(index - 20)
Don Gagne's avatar
Don Gagne committed
66
                    width:  (_speed % 5 === 0) ? ScreenTools.defaultFontPixelSize * (0.83) : ScreenTools.defaultFontPixelSize * (1.25)
67 68 69
                    anchors.right: parent.right
                    height: _reticleHeight
                    color:  Qt.rgba(1,1,1,0.35)
70
                    QGCLabel {
71 72
                        visible: (_speed % 5 === 0)
                        anchors.horizontalCenter: parent.horizontalCenter
Don Gagne's avatar
Don Gagne committed
73
                        anchors.horizontalCenterOffset: ScreenTools.defaultFontPixelSize * (-2.5)
74 75 76 77 78 79 80 81
                        anchors.verticalCenter:   parent.verticalCenter
                        antialiasing: true
                        font.weight: Font.DemiBold
                        text:  _speed
                        color: _speed < 0 ? "#f8983a" : "white"
                        style: Text.Outline
                        styleColor: Qt.rgba(0,0,0,0.25)
                    }
dogmaphobic's avatar
dogmaphobic committed
82 83
                }
            }
84 85 86
            transform: Translate {
                y: (speed * _reticleSlot) - (_reticleSlot / 2)
            }
dogmaphobic's avatar
dogmaphobic committed
87 88 89
        }
    }
}