QGCCompassWidget.qml 2.67 KB
Newer Older
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
/*=====================================================================

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
26
 *   @brief QGC Compass Widget
27 28 29 30
 *   @author Gus Grubba <mavlink@grubba.com>
 */

import QtQuick 2.4
31
import QGroundControl.Controls 1.0
32 33
import QGroundControl.ScreenTools 1.0

34
QGCMovableItem {
35 36
    id:                     root
    property real heading:  0
Don Gagne's avatar
Don Gagne committed
37 38
    property real size:     ScreenTools.defaultFontPixelSize * (10)
    property int _fontSize: ScreenTools.defaultFontPixelSize
39 40 41 42 43 44 45 46 47
    width:                  size
    height:                 size
    Rectangle {
        id:                 compassBack
        anchors.fill:       parent
        color:              "#212121"
    }
    Image {
        id:                 pointer
48
        source:             "/qmlimages/compassInstrumentAirplane.svg"
49
        mipmap:             true
50
        width:              size * 0.75
51 52 53 54 55
        fillMode:           Image.PreserveAspectFit
        anchors.centerIn:   parent
        transform: Rotation {
            origin.x:   pointer.width  / 2
            origin.y:   pointer.height / 2
56
            angle:      heading
57 58 59 60
        }
    }
    Image {
        id:                 compassDial
61
        source:             "/qmlimages/compassInstrumentDial.svg"
62 63
        mipmap:             true
        fillMode:           Image.PreserveAspectFit
64
        anchors.fill:       parent
65 66 67 68 69 70 71
    }
    Rectangle {
        anchors.centerIn:   root
        width:              size * 0.35
        height:             size * 0.2
        border.color:       Qt.rgba(1,1,1,0.15)
        color:              Qt.rgba(0,0,0,0.65)
72
        QGCLabel {
73 74
            text:           heading.toFixed(0)
            font.weight:    Font.DemiBold
75
            font.pixelSize: _fontSize < 1 ? 1 : _fontSize;
76 77 78 79 80 81 82
            color: "white"
            anchors.centerIn: parent
        }
    }
}