MissionItemIndexLabel.qml 4.93 KB
Newer Older
1 2
import QtQuick                  2.3
import QtQuick.Controls         1.2
3
import QtQuick.Controls.Styles  1.4
4 5

import QGroundControl.ScreenTools 1.0
6
import QGroundControl.Palette     1.0
7

8 9
Canvas {
    id:     root
10

DonLakeFlyer's avatar
DonLakeFlyer committed
11
    width:  _width
12
    height: _height
13

14 15
    signal clicked

16 17
    property string label                       ///< Label to show to the side of the index indicator
    property int    index:                  0   ///< Index to show in the indicator, 0 will show label instead
18 19 20
    property bool   checked:                false
    property bool   small:                  false
    property var    color:                  checked ? "green" : qgcPal.mapButtonHighlight
21 22
    property real   anchorPointX:           _height / 2
    property real   anchorPointY:           _height / 2
23
    property bool   specifiesCoordinate:    true
DonLakeFlyer's avatar
DonLakeFlyer committed
24 25 26
    property real   gimbalYaw
    property real   vehicleYaw
    property bool   showGimbalYaw:          false
27

DonLakeFlyer's avatar
DonLakeFlyer committed
28
    property real   _width:             showGimbalYaw ? Math.max(_gimbalYawWidth, labelControl.visible ? labelControl.width : indicator.width) : (labelControl.visible ? labelControl.width : indicator.width)
29 30 31 32 33 34 35 36 37
    property real   _height:            showGimbalYaw ? _gimbalYawWidth : (labelControl.visible ? labelControl.height : indicator.height)
    property real   _gimbalYawRadius:   ScreenTools.defaultFontPixelHeight
    property real   _gimbalYawWidth:    _gimbalYawRadius * 2
    property real   _indicatorRadius:   small ? (ScreenTools.defaultFontPixelHeight * ScreenTools.smallFontPointRatio * 1.25 / 2) : (ScreenTools.defaultFontPixelHeight * 0.66)
    property real   _gimbalRadians:     degreesToRadians(vehicleYaw + gimbalYaw - 90)
    property real   _labelMargin:       2
    property real   _labelRadius:       _indicatorRadius + _labelMargin
    property string _label:             index === 0 ? "" : label
    property string _index:             index === 0 ? label : index
38

DonLakeFlyer's avatar
DonLakeFlyer committed
39 40 41 42
    onColorChanged:         requestPaint()
    onShowGimbalYawChanged: requestPaint()
    onGimbalYawChanged:     requestPaint()
    onVehicleYawChanged:    requestPaint()
43 44 45

    QGCPalette { id: qgcPal }

DonLakeFlyer's avatar
DonLakeFlyer committed
46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63
    function degreesToRadians(degrees) {
        return (Math.PI/180)*degrees
    }

    function paintGimbalYaw(context) {
        if (showGimbalYaw) {
            context.save()
            context.globalAlpha = 0.75
            context.beginPath()
            context.moveTo(anchorPointX, anchorPointY)
            context.arc(anchorPointX, anchorPointY, _gimbalYawRadius,  _gimbalRadians + degreesToRadians(45), _gimbalRadians + degreesToRadians(-45), true /* clockwise */)
            context.closePath()
            context.fillStyle = "white"
            context.fill()
            context.restore()
        }
    }

64 65
    onPaint: {
        var context = getContext("2d")
DonLakeFlyer's avatar
DonLakeFlyer committed
66 67
        context.clearRect(0, 0, width, height)
        paintGimbalYaw(context)
68 69
    }

70 71 72 73 74 75 76 77 78 79 80 81 82 83 84
    Rectangle {
        id:                 labelControl
        anchors.leftMargin: -_labelMargin
        anchors.topMargin:  -_labelMargin
        anchors.left:       indicator.left
        anchors.top:        indicator.top
        height:             _labelRadius * 2
        width:              labelControlLabel.contentWidth + (_labelMargin * 3) + indicator.width
        color:              "white"
        opacity:            0.5
        radius:             _labelRadius
        visible:            _label.length !== 0
    }


85
    QGCLabel {
86 87 88 89 90 91 92
        id:                     labelControlLabel
        anchors.leftMargin:     indicator.width + _labelMargin
        anchors.left:           labelControl.left
        anchors.rightMargin:    _labelMargin
        anchors.right:          labelControl.right
        anchors.top:            labelControl.top
        anchors.bottom:         labelControl.bottom
DonLakeFlyer's avatar
DonLakeFlyer committed
93 94 95 96
        verticalAlignment:      Text.AlignVCenter
        color:                  "white"
        font.pointSize:         ScreenTools.defaultFontPointSize
        fontSizeMode:           Text.HorizontalFit
97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119
        text:                   _label
    }

    Rectangle {
        id:                             indicator
        anchors.horizontalCenter:       parent.left
        anchors.verticalCenter:         parent.top
        anchors.horizontalCenterOffset: anchorPointX
        anchors.verticalCenterOffset:   anchorPointY
        width:                          _indicatorRadius * 2
        height:                         width
        color:                          root.color
        radius:                         _indicatorRadius

        QGCLabel {
            anchors.fill:           parent
            horizontalAlignment:    Text.AlignHCenter
            verticalAlignment:      Text.AlignVCenter
            color:                  "white"
            font.pointSize:         ScreenTools.defaultFontPointSize
            fontSizeMode:           Text.HorizontalFit
            text:                   _index
        }
120
    }
121

122 123 124
    QGCMouseArea {
        fillItem:   parent
        onClicked:  parent.clicked()
125
    }
126
}