/**************************************************************************** * * (c) 2009-2016 QGROUNDCONTROL PROJECT * * QGroundControl is licensed according to the terms in the file * COPYING.md in the root of the source code directory. * ****************************************************************************/ 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 /// QGCMapCircle map visuals Item { id: _root property var mapControl ///< Map control to place item in property var mapCircle ///< QGCMapCircle object property bool interactive: mapCircle.interactive /// true: user can manipulate polygon property color interiorColor: "transparent" property real interiorOpacity: 1 property int borderWidth: 0 property color borderColor: "black" property var _circleComponent property var _centerDragHandleComponent function addVisuals() { _circleComponent = circleComponent.createObject(mapControl) mapControl.addMapItem(_circleComponent) } function removeVisuals() { _circleComponent.destroy() } function addHandles() { if (!_centerDragHandleComponent) { _centerDragHandleComponent = centerDragHandleComponent.createObject(mapControl) } } function removeHandles() { if (_centerDragHandleComponent) { _centerDragHandleComponent.destroy() _centerDragHandleComponent = undefined } } onInteractiveChanged: { if (interactive) { addHandles() } else { removeHandles() } } Component.onCompleted: { addVisuals() if (interactive) { addHandles() } } Component.onDestruction: { removeVisuals() removeHandles() } Component { id: circleComponent MapCircle { color: interiorColor opacity: interiorOpacity border.color: borderColor border.width: borderWidth center: mapCircle.center radius: mapCircle.radius.rawValue } } Component { id: dragHandleComponent MapQuickItem { id: mapQuickItem anchorPoint.x: dragHandle.width / 2 anchorPoint.y: dragHandle.height / 2 z: QGroundControl.zOrderMapItems + 2 sourceItem: Rectangle { id: dragHandle width: ScreenTools.defaultFontPixelHeight * 1.5 height: width radius: width / 2 color: "white" opacity: .90 } } } Component { id: centerDragAreaComponent MissionItemIndicatorDrag { onItemCoordinateChanged: mapCircle.center = itemCoordinate } } Component { id: radiusDragAreaComponent MissionItemIndicatorDrag { onItemCoordinateChanged: mapCircle.radius.rawValue = mapCircle.center.distanceTo(itemCoordinate) } } Component { id: centerDragHandleComponent Item { property var centerDragHandle property var centerDragArea property var radiusDragHandle property var radiusDragArea property var radiusDragCoord: QtPositioning.coordinate() property var circleCenterCoord: mapCircle.center property real circleRadius: mapCircle.radius.rawValue function calcRadiusDragCoord() { radiusDragCoord = mapCircle.center.atDistanceAndAzimuth(circleRadius, 90) } onCircleCenterCoordChanged: calcRadiusDragCoord() onCircleRadiusChanged: calcRadiusDragCoord() Component.onCompleted: { calcRadiusDragCoord() radiusDragHandle = dragHandleComponent.createObject(mapControl) radiusDragHandle.coordinate = Qt.binding(function() { return radiusDragCoord }) mapControl.addMapItem(radiusDragHandle) radiusDragArea = radiusDragAreaComponent.createObject(mapControl, { "itemIndicator": radiusDragHandle, "itemCoordinate": radiusDragCoord }) centerDragHandle = dragHandleComponent.createObject(mapControl) centerDragHandle.coordinate = Qt.binding(function() { return circleCenterCoord }) mapControl.addMapItem(centerDragHandle) centerDragArea = centerDragAreaComponent.createObject(mapControl, { "itemIndicator": centerDragHandle, "itemCoordinate": circleCenterCoord }) } Component.onDestruction: { centerDragHandle.destroy() centerDragArea.destroy() radiusDragHandle.destroy() radiusDragArea.destroy() } } } }