我使用 OverlappingMarkerSpiderfier(不确定这是否相关)在地图上放置了 300 多个标记,因此相同位置的标记被聚集在一起。目前代码工作正常,除了标记都同时显示在下面代码中的“for(var key in addresses['ASRAddr'])”循环的末尾。
我想要的是绘制地图,然后开始看到标记“下雨”到它们的位置。使用 DROP 属性完成“下雨”部分,但我无法弄清楚如何在每个标记添加到地图时绘制它。
这是几乎从stackoverflow中的片段拼凑在一起的代码(感谢所有做出贡献的优秀人员。不确定没有S/O我会做什么):
<script>
function decodeAddr(callback, map) {
var jsonData = jQuery.ajax({
url: "static/data.json",
dataType: "json",
async: false
}).responseText;
var addresses = JSON.parse(jsonData);
callback(addresses, map);
};
function getHC(key) {
var hc = jQuery.ajax({
async: false,
dataType: "text",
cache: false,
url: "/static/periodicHC/" + key.substring(0,11)
}).responseText;
return(hc);
};
function initMap(addresses, map) {
var zColors = {"green" : 1, "yellow" : 2, "red" : 3};
var iw = new InfoBubble();
var oms = new OverlappingMarkerSpiderfier(map, {
markersWontMove: true,
markersWontHide: true,
basicFormatEvents: true
});
for (var key in addresses['ASRAddr']) {
var state = addresses['ASRAddr'][key]['state']
var position = new google.maps.LatLng(addresses['ASRAddr'][key]['latitude'], addresses['ASRAddr'][key]['longitude']);
marker = new google.maps.Marker({
position: position,
map: map,
title: key + '\n' + addresses['ASRAddr'][key]['phyAddr'] + '\n\n' + getHC(key),
zIndex: zColors[state],
icon: "/static/images/googleMaps/" + state + "_MarkerA.png"
});
google.maps.event.addListener(marker, 'spider_click', function(e) { // 'spider_click', not plain 'click'
marker.addListener('mouseover', () => iw.open(map, marker));
marker.addListener('mouseout', () => iw.close());
});
oms.addMarker(marker); // adds the marker to the spiderfier _and_ the map
}
}
function initPage() {
var map = new google.maps.Map(document.getElementById('map'), {
zoom: 5,
center: new google.maps.LatLng(38.0000, -97.0000)
});
google.maps.event.addListenerOnce(map, 'idle', function(){
decodeAddr(initMap, map);
});
}
</script>
功能如下:
decodeAddr:读取包含所有节点的站点地址的 JSON getHC:读取包含节点运行状况的文本文件
其余的是用于向地图添加标记/信息气泡的常用代码片段。