blob: 8c548fd4346194919f58ad21be0eda585bffd4ea (
plain)
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
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
|
// Copyright (C) 2022 The Qt Company Ltd.
// SPDX-License-Identifier: LicenseRef-Qt-Commercial OR BSD-3-Clause
import QtQuick
import QtLocation
//! [mqi-top]
MapQuickItem {
id: marker
//! [mqi-top]
property alias lastMouseX: markerMouseArea.lastX
property alias lastMouseY: markerMouseArea.lastY
//! [mqi-anchor]
anchorPoint.x: image.width/4
anchorPoint.y: image.height
sourceItem: Image {
id: image
//! [mqi-anchor]
source: "../resources/marker.png"
opacity: markerMouseArea.pressed ? 0.6 : 1.0
MouseArea {
id: markerMouseArea
property int pressX : -1
property int pressY : -1
property int jitterThreshold : 10
property int lastX: -1
property int lastY: -1
anchors.fill: parent
hoverEnabled : false
drag.target: marker
preventStealing: true
onPressed : (mouse) => {
map.pressX = mouse.x
map.pressY = mouse.y
map.currentMarker = -1
for (var i = 0; i< map.markers.length; i++){
if (marker == map.markers[i]){
map.currentMarker = i
break
}
}
}
onPressAndHold: (mouse) => {
if (Math.abs(map.pressX - mouse.x ) < map.jitterThreshold
&& Math.abs(map.pressY - mouse.y ) < map.jitterThreshold) {
var p = map.fromCoordinate(marker.coordinate)
lastX = p.x
lastY = p.y
map.showMarkerMenu(marker.coordinate)
}
}
}
Text{
id: number
y: image.height/10
width: image.width
color: "white"
font.bold: true
font.pixelSize: 14
horizontalAlignment: Text.AlignHCenter
Component.onCompleted: {
text = map.markerCounter
}
}
//! [mqi-closeimage]
}
//! [mqi-closeimage]
Component.onCompleted: coordinate = map.toCoordinate(Qt.point(markerMouseArea.mouseX,
markerMouseArea.mouseY));
//! [mqi-close]
}
//! [mqi-close]
|