WimaServiceAreaMapVisual.qml 5.54 KB
Newer Older
1 2 3 4 5 6 7 8
/****************************************************************************
 *
 *   (c) 2009-2016 QGROUNDCONTROL PROJECT <http://www.qgroundcontrol.org>
 *
 * QGroundControl is licensed according to the terms in the file
 * COPYING.md in the root of the source code directory.
 *
 ****************************************************************************/
9

10 11 12 13 14 15 16 17 18 19 20
import QtQuick          2.3
import QtQuick.Controls 1.2
import QtLocation       5.3
import QtPositioning    5.3

import QGroundControl               1.0
import QGroundControl.ScreenTools   1.0
import QGroundControl.Palette       1.0
import QGroundControl.Controls      1.0
import QGroundControl.FlightMap     1.0

21
Item {
22 23 24 25 26
    id: _root

    property var map        ///< Map control to place item in
    property var qgcView    ///< QGCView to use for popping dialogs

27 28
    property var areaItem:          object
    property var _polygon:          areaItem
29 30 31 32 33 34 35 36 37 38 39 40 41 42 43
    property var _depot
    property bool showDepot: 		areaItem.interactive || areaItem.borderPolygon.interactive
    property bool _depotVisible:     false

    onShowDepotChanged: {
        if (showDepot){
            if (!_depotVisible){
               _addDepot()
            }
        } else {
            if (_depotVisible){
                _destroyDepot()
            }
        }
    }
44 45 46

    signal clicked(int sequenceNumber)

47 48 49 50 51 52 53 54 55 56 57 58 59
    function _addDepot() {
        _depot = depotPointComponent.createObject(map)
        map.addMapItem(_depot)
        _depotVisible = true
    }

    function _destroyDepot() {
        if (_depot){
            _depot.destroy()
        }
        _depotVisible = false
    }

60 61
    /// Add an initial 4 sided polygon if there is none
    function _addInitialPolygon() {
62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101

        // Initial polygon is inset to take 2/3rds space
        var rect = Qt.rect(map.centerViewport.x, map.centerViewport.y, map.centerViewport.width, map.centerViewport.height)
        rect.x += (rect.width * 0.25) / 2
        rect.y += (rect.height * 0.25) / 2
        rect.width *= 0.75
        rect.height *= 0.75

        var centerCoord =       map.toCoordinate(Qt.point(rect.x + (rect.width / 2), rect.y + (rect.height / 2)),   false /* clipToViewPort */)
        var topLeftCoord =      map.toCoordinate(Qt.point(rect.x, rect.y),                                          false /* clipToViewPort */)
        var topRightCoord =     map.toCoordinate(Qt.point(rect.x + rect.width, rect.y),                             false /* clipToViewPort */)
        var bottomLeftCoord =   map.toCoordinate(Qt.point(rect.x, rect.y + rect.height),                            false /* clipToViewPort */)
        var bottomRightCoord =  map.toCoordinate(Qt.point(rect.x + rect.width, rect.y + rect.height),               false /* clipToViewPort */)

        // Adjust polygon to max size
        var maxSize = 100
        var halfWidthMeters =   Math.min(topLeftCoord.distanceTo(topRightCoord), maxSize) / 2
        var halfHeightMeters =  Math.min(topLeftCoord.distanceTo(bottomLeftCoord), maxSize) / 2
        topLeftCoord =      centerCoord.atDistanceAndAzimuth(halfWidthMeters, -90).atDistanceAndAzimuth(halfHeightMeters, 0)
        topRightCoord =     centerCoord.atDistanceAndAzimuth(halfWidthMeters, 90).atDistanceAndAzimuth(halfHeightMeters, 0)
        bottomLeftCoord =   centerCoord.atDistanceAndAzimuth(halfWidthMeters, -90).atDistanceAndAzimuth(halfHeightMeters, 180)
        bottomRightCoord =  centerCoord.atDistanceAndAzimuth(halfWidthMeters, 90).atDistanceAndAzimuth(halfHeightMeters, 180)

        if (areaItem.showBorderPolygon.rawValue === true) {

            if (areaItem.borderPolygon.count < 3) {

                areaItem.borderPolygon.appendVertex(topLeftCoord)
                areaItem.borderPolygon.appendVertex(topRightCoord)
                areaItem.borderPolygon.appendVertex(bottomRightCoord)
                areaItem.borderPolygon.appendVertex(bottomLeftCoord)
            }
        } else {
            if (_polygon.count < 3) {

                _polygon.appendVertex(topLeftCoord)
                _polygon.appendVertex(topRightCoord)
                _polygon.appendVertex(bottomRightCoord)
                _polygon.appendVertex(bottomLeftCoord)
            }
102
        }
103
    }
104

105 106
    Component.onCompleted: {
        _addInitialPolygon()
107
        if (showDepot){
108 109
            _addDepot()
        }
110 111 112
    }

    Component.onDestruction: {
113
        _destroyDepot()
114 115 116 117 118 119 120 121 122 123 124 125
    }

    WimaMapPolygonVisuals {
        qgcView:            _root.qgcView
        mapControl:         map
        mapPolygon:         _polygon
        borderWidth:        1
        borderColor:        "black"
        interiorColor:      "yellow"
        interiorOpacity:    0.25
    }

126
    WimaMapPolygonVisuals {
127 128
        qgcView:            _root.qgcView
        mapControl:         map
129 130 131 132 133 134 135
        mapPolygon:         areaItem.borderPolygon
        borderWidth:        1
        borderColor:        areaItem.borderPolygon.interactive ? "white" : "transparent"
        interiorColor:      "transparent"
        interiorOpacity:    1
    }

136 137 138 139
    // Depot Point.
    Component {
        id: depotPointComponent
        DragCoordinate {
140 141
            property var depot: areaItem.depot

142 143 144
            map:        _root.map
            qgcView:    _root.qgcView
            z:          QGroundControl.zOrderMapItems
145 146 147
            checked:    showDepot
            coordinate: depot
            label: 		"Depot"
148 149

            onDragReleased: {
150 151 152 153
                if (areaItem.containsCoordinate(coordinate)){
                    areaItem.depot = coordinate
                }
                coordinate = Qt.binding(function() { return areaItem.depot; })
154 155 156 157
            }
        }
    }

158
}