QGCSpeedWidget.qml 2.82 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 31 32 33 34 35 36 37 38 39 40 41 42 43
/*=====================================================================

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

Rectangle {
    id: root
    property real speed:           0
    property real _reticleSpacing: 14
    property real _reticleHeight:  1
    property real _reticleSlot:    _reticleSpacing + _reticleHeight

    anchors.verticalCenter: parent.verticalCenter

    height: parent.height * 0.75 > 280 ? 280 : parent.height * 0.75
    clip:   true
    smooth: true
44
    radius: 5
dogmaphobic's avatar
dogmaphobic committed
45 46
    border.color: Qt.rgba(1,1,1,0.25)
    gradient: Gradient {
47 48 49
        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
50 51
    }
    Column{
52 53
        width: parent.width
        anchors.verticalCenter: parent.verticalCenter
dogmaphobic's avatar
dogmaphobic committed
54 55 56 57
        spacing: _reticleSpacing
        Repeater {
            model: 40
            Rectangle {
58 59 60
                property int _speed: -(index - 20)
                width:  (_speed % 5 === 0) ? 15 : 30
                anchors.right: parent.right
dogmaphobic's avatar
dogmaphobic committed
61
                height: _reticleHeight
62
                color:  Qt.rgba(1,1,1,0.35)
dogmaphobic's avatar
dogmaphobic committed
63 64 65
                Text {
                    visible: (_speed % 5 === 0)
                    anchors.horizontalCenter: parent.horizontalCenter
66
                    anchors.horizontalCenterOffset: -25
dogmaphobic's avatar
dogmaphobic committed
67 68 69 70 71 72 73 74 75 76 77 78 79 80 81
                    anchors.verticalCenter:   parent.verticalCenter
                    antialiasing: true
                    font.weight: _speed < 0 ? Font.Light : Font.DemiBold
                    text: _speed < 0 ? -_speed : _speed
                    color: _speed < 0 ? "#ef2526" : "white"
                    style: Text.Outline
                    styleColor: Qt.rgba(0,0,0,0.25)
                }
            }
        }
        transform: Translate {
            y: (speed * _reticleSlot) - (_reticleSlot / 2)
        }
    }
}