MapDisplayer.kt
3.77 KB
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
package map
import application.model.observableVessel
fun clearMap(map: LeafletMapView) {
clearMapCanvas(map)
clearMapCluster(map)
clearHeatMap(map)
}
fun clearMapCluster(map: LeafletMapView) {
map.execScript(
"""
|myMap.removeLayer(markerClusters);
|var markerClusters = L.markerClusterGroup({spiderfyOnMaxZoom: false, disableClusteringAtZoom: 10});
""".trimMargin()
)
}
fun clearMapCanvas(map: LeafletMapView) {
map.execScript(
"""
|myRenderer.removeFrom(myMap);
|var myRenderer = L.canvas({ padding: 0.5 });
""".trimMargin()
)
}
fun clearHeatMap(map: LeafletMapView) {
map.execScript(
"""
|heatLayer.removeFrom(myMap);
|var heatLayer = L.heatLayer([]).addTo(myMap);
""".trimMargin()
)
}
fun displayAllMessageOnMap(map: LeafletMapView) {
clearMap(map)
observableVessel.vessels.forEach { (_, value) ->
value.messages.forEach { (_, message) ->
map.execScript("L.circleMarker([${message.latitude}, ${message.longitude}], {renderer: myRenderer, radius: 0.01, color: '#${message.getHexColorStroke()}'}).addTo(myMap)")
}
}
}
fun displayAllMessageOnMap(map: LeafletMapView, selectedMMSI: Int) {
clearMap(map)
observableVessel.vessels.forEach { (_, value) ->
value.messages.forEach { (_, message) ->
if (selectedMMSI == message.mmsi) {
map.execScript("L.circleMarker([${message.latitude}, ${message.longitude}], {renderer: myRenderer, radius: 2, color: '#ff4040'}).addTo(myMap)")
} else {
map.execScript("L.circleMarker([${message.latitude}, ${message.longitude}], {renderer: myRenderer, radius: 0.01, color: '#${message.getHexColorStroke()}'}).addTo(myMap)")
}
}
}
}
fun displayClusterMessageOnMap(map: LeafletMapView) {
clearMap(map)
observableVessel.vessels.forEach { (_, value) ->
value.messages.forEach { (_, message) ->
map.execScript("markerClusters.addLayer(L.circleMarker([${message.latitude}, ${message.longitude}], {renderer: myRenderer, radius: 0.01, color: '#${message.getHexColorStroke()}'}));")
}
}
map.execScript("myMap.addLayer(markerClusters);")
}
fun displayClusterMessageOnMap(map: LeafletMapView, selectedMMSI: Int) {
clearMap(map)
observableVessel.vessels.forEach { (_, value) ->
value.messages.forEach { (_, message) ->
if (selectedMMSI == message.mmsi) {
map.execScript("L.circleMarker([${message.latitude}, ${message.longitude}], {renderer: myRenderer, radius: 2, color: '#ff4040'}).addTo(myMap);")
} else {
map.execScript("markerClusters.addLayer(L.circleMarker([${message.latitude}, ${message.longitude}], {renderer: myRenderer, radius: 0.01, color: '#${message.getHexColorStroke()}'}));")
}
}
}
map.execScript("myMap.addLayer(markerClusters);")
}
fun displayHeatMapOnMap(map: LeafletMapView) {
clearMap(map)
observableVessel.vessels.forEach { (_, value) ->
value.messages.forEach { (_, message) ->
map.execScript("heatLayer.addLatLng([${message.latitude}, ${message.longitude}]);")
}
}
}
fun displayHeatMapOnMap(map: LeafletMapView, selectedMMSI: Int) {
clearMap(map)
observableVessel.vessels.forEach { (_, value) ->
value.messages.forEach { (_, message) ->
if (selectedMMSI == message.mmsi) {
map.execScript("L.circleMarker([${message.latitude}, ${message.longitude}], {renderer: myRenderer, radius: 2, color: '#ff4040'}).addTo(myMap);")
} else {
map.execScript("heatLayer.addLatLng([${message.latitude}, ${message.longitude}]);")
}
}
}
map.execScript("myMap.addLayer(markerClusters);")
}