QGCSpeedWidget.qml 2.89 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
dogmaphobic's avatar
dogmaphobic committed
32 33 34

Rectangle {
    id: root
dogmaphobic's avatar
dogmaphobic committed
35
    property ScreenTools screenTools: ScreenTools { }
dogmaphobic's avatar
dogmaphobic committed
36
    property real speed:           0
dogmaphobic's avatar
dogmaphobic committed
37 38
    property real _reticleSpacing: 10
    property real _reticleHeight:  2
dogmaphobic's avatar
dogmaphobic committed
39 40 41 42
    property real _reticleSlot:    _reticleSpacing + _reticleHeight

    anchors.verticalCenter: parent.verticalCenter

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