blob: a733e9e6a97f6fcee5dae97e44bf007ae969255c (
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
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
|
// Copyright (C) 2019 Julian Sherollari <jdotsh@gmail.com>
// Copyright (C) 2019 The Qt Company Ltd.
// SPDX-License-Identifier: LicenseRef-Qt-Commercial OR BSD-3-Clause
import QtQuick
import QtPositioning
import QtLocation
import Qt.labs.qmlmodels 1.0
DelegateChooser {
id: dc
role: "type"
property color defaultColor: "grey"
property real defaultOpacity: 0.6
DelegateChoice {
roleValue: "Point"
delegate: MapCircle {
property string geojsonType: "Point"
property var props: modelData.properties
geoShape: modelData.data
radius: 20*1000
border.width: 3
opacity: dc.defaultOpacity
/* The expression below is equivalent to:
((props !== undefined && props["color"] !== undefined) ? props["color"] :
((parent && parent.props !== undefined && parent.props["color"] !== undefined) ? parent.props["color"] : dc.defaultColor))
*/
color: (props && props.color) || (parent && parent.props && parent.props.color) || dc.defaultColor
}
}
DelegateChoice {
roleValue: "LineString"
delegate: MapPolyline {
property string geojsonType: "LineString"
property var props: modelData.properties
geoShape: modelData.data
line.width: 4
opacity: dc.defaultOpacity
line.color: (props && props.color) || (parent && parent.props && parent.props.color) || dc.defaultColor
}
}
DelegateChoice {
roleValue: "Polygon"
delegate: MapPolygon {
property string geojsonType: "Polygon"
property var props: modelData.properties
geoShape: modelData.data
opacity: dc.defaultOpacity
color: (props && props.color) || (parent && parent.props && parent.props.color) || dc.defaultColor
border.width: 4
border.color: 'black'
MouseArea {
anchors.fill: parent
onClicked: {
if (props !== undefined)
console.log(props.name)
else if (parent.parent.geojsonType == "MultiPolygon")
console.log(parent.parent.props.name)
else
console.log("NO NAME!", props)
}
}
}
}
DelegateChoice {
roleValue: "MultiPoint"
delegate: MapItemView {
property string geojsonType: "MultiPoint"
property var props: modelData.properties
model: modelData.data
delegate: dc
}
}
DelegateChoice {
roleValue: "MultiLineString"
delegate: MapItemView {
property string geojsonType: "MultiLineString"
property var props: modelData.properties
model: modelData.data
delegate: dc
}
}
DelegateChoice {
roleValue: "MultiPolygon"
delegate: MapItemView {
property string geojsonType: "MultiPolygon"
property var props: modelData.properties
model: modelData.data
delegate: dc
}
}
DelegateChoice {
roleValue: "GeometryCollection"
delegate: MapItemView {
property string geojsonType: "GeometryCollection"
property var props: modelData.properties
model: modelData.data
delegate: dc
}
}
// Features are explicitly not generated by the parser, but converted straight to their content + the properties.
DelegateChoice {
roleValue: "FeatureCollection"
delegate: MapItemView {
property string geojsonType: "FeatureCollection"
property var props: modelData.properties
model: modelData.data
delegate: dc
}
}
}
|