当尝试将多个infowindows添加到折线时,infowindow不会显示。
已经尝试过这个问题: Multiple polylines and infowindows with Google Maps V3
正如您所看到的,我尝试在给定的答案中使用建议的功能,但它仍然不起作用。
这是我的代码:
var center = new google.maps.LatLng(51.97559, 4.12565);
var map = new google.maps.Map(document.getElementById('map'), {
center: center,
zoom: 6,
mapTypeId: google.maps.MapTypeId.ROADMAP
});
var bounds = new google.maps.LatLngBounds();
// start coordinates
var start = ['51.97559, 4.12565',
'55.46242, 8.43872',
'49.49259, 0.1065',
'50.36862, -4.13412']
// end coordinates
var end = ['51.94784, 1.2539',
'51.94784, 1.2539',
'50.79726, -1.11048',
'43.45846, -3.80685']
function initialize() {
// Make clickable tooltip
/*
*/
for (var i=0; i < end.length; i++){
calcRoute(start[i], end [i]);
}
}
function calcRoute(source,destination){
var poly = new google.maps.Polyline({
path: [],
strokeColor: '#FF0000',
strokeWeight: 5,
strokeOpacity: 0.5
});
var directionsService = new google.maps.DirectionsService();
var request = {
origin:source,
destination: destination,
travelMode: google.maps.DirectionsTravelMode.WALKING
};
directionsService.route(request, function(result, status) {
if (status == google.maps.DirectionsStatus.OK) {
path = result.routes[0].overview_path;
$(path).each(function(index, item) {
poly.getPath().push(item);
bounds.extend(item);
})
// Custom infoWindow
var toolTip = '<div id="map-box">'+
'<div id="siteNotice">'+
'</div>'+
'<h1 id="firstHeading" class="firstHeading">Route</h1>'+
'<div id="bodyContent">'+
'<p>Lorem ipsum dolor sit amet</p>'+
'</div>'+
'</div>';
poly.setMap(map);
createInfoWindow(poly,toolTip);
map.fitBounds(bounds);
}
});
}
function createInfoWindow(poly,content) {
google.maps.event.addListener(poly, 'click', function(event) {
infowindow.content = content;
//infowindow.position = event.latLng;
infowindow.setPosition(event.latLng);
infowindow.open(map);
});
}
google.maps.event.addDomListener(window, 'load', initialize);
这里是jsfiddle链接: http://jsfiddle.net/cnwMG/7/
任何有关在折线上显示信息窗口的帮助都会非常感激。
答案 0 :(得分:3)
你缺乏最基本的东西:实例化infowindow:)
然后,设置infowindow属性的正确方法就是这样
infowindow.setContent(toolTip);
infowindow.setPosition(event.latLng);
不
infowindow.content = toolTip;
调用信息窗的逻辑也存在一些问题 这是一个清理过的分叉小提琴http://jsfiddle.net/b7FHV/