// SPDX-License-Identifier: GPL-2.0 import QtQuick 2.0 import QtLocation 5.3 import QtPositioning 5.3 import org.subsurfacedivelog.mobile 1.0 Item { readonly property var esriMapTypeIndexes: { "STREET": 0, "SATELLITE": 1 } Plugin { id: mapPlugin name: "esri" } MapWidgetHelper { id: mapHelper map: map } Map { id: map anchors.fill: parent plugin: mapPlugin zoomLevel: 1 readonly property var defaultCenter: QtPositioning.coordinate(0, 0) readonly property var defaultZoomIn: 17.0 readonly property var defaultZoomOut: 2.0 property var newCenter: defaultCenter property var newZoom: 1.0 Component.onCompleted: { activeMapType = supportedMapTypes[esriMapTypeIndexes.SATELLITE] } MapItemView { id: mapItemView model: mapHelper.model delegate: MapQuickItem { anchorPoint.x: 0 anchorPoint.y: mapItemImage.height coordinate: model.coordinate z: mapHelper.model.selectedUuid === model.uuid ? mapHelper.model.count - 1 : 0 sourceItem: Image { id: mapItemImage source: "qrc:///mapwidget-marker" + (mapHelper.model.selectedUuid === model.uuid ? "-selected" : "") SequentialAnimation { id: mapItemImageAnimation PropertyAnimation { target: mapItemImage; property: "scale"; from: 1.0; to: 0.7; duration: 120; } PropertyAnimation { target: mapItemImage; property: "scale"; from: 0.7; to: 1.0; duration: 80; } } } MouseArea { anchors.fill: parent onClicked: { mapHelper.model.selectedUuid = model.uuid mapItemImageAnimation.restart() } } } } ParallelAnimation { id: mapAnimation CoordinateAnimation { target: map; property: "center"; to: map.newCenter; duration: 2000; } NumberAnimation { target: map; property: "zoomLevel"; to: map.newZoom; duration: 3000; easing.type: Easing.InCubic; } } function animateMapTo(coord, zoom) { newCenter = coord newZoom = zoom mapAnimation.restart() } function centerOnMapLocation(mapLocation) { zoomLevel = defaultZoomOut animateMapTo(mapLocation.coordinate, defaultZoomIn) mapHelper.model.selectedUuid = mapLocation.uuid } function deselectMapLocation() { mapHelper.model.selectedUuid = 0 animateMapTo(defaultCenter, defaultZoomOut) } } }