好的,我有这个代码,它为我从数据库中获取的每个位置调用,问题是每当我点击一个标记时,信息窗口都会显示相应的标记信息,但信息窗口的位置总是最后一个添加了标记,简而言之,信息很好,但没有显示它应该在哪里。
这两个是在地图初始化时声明的,并且是全局的。
var infowindow = new google.maps.InfoWindow();
var geocoder=new google.maps.Geocoder
这是脚本
function addRoleMarker(lat,lng,rumbo,codigo,velocidad,nE,referer,utc,fecha)
{
var myLatLng = new google.maps.LatLng(lat, lng);
var title='No.'+nE+' '+utc;
baseMarker = new google.maps.Marker({
position: myLatLng,
map: map,
title: title,
zIndex: 1
});
google.maps.event.addListener(baseMarker,'click',function(){
geocoder.geocode({'latLng': myLatLng}, function(results, status) {
if (status == google.maps.GeocoderStatus.OK) {
if (results[0]) {
switch(rumbo)
{
case 0:
rumbo='N';
break;
case 1:
rumbo='NE';
break;
case 2:
rumbo='E';
break;
case 3:
rumbo='SE';
break;
case 4:
rumbo='S';
break;
case 5:
rumbo='SO';
break;
case 6:
rumbo='O';
break;
case 7:
rumbo='NO';
break;
}
var tablaR="<table><tr><td>Fecha:</td></tr><td>"+fecha;
tablaR+="</td><tr><td>Fecha UTC:</td></tr><td>"+utc;
tablaR+="</td><tr><td>Velocidad:</td></tr><td>"+velocidad;
tablaR+="</td><tr><td>Rumbo:</td></tr><td>"+rumbo;
tablaR+="</td><tr><td>Direccion:</td></tr><td>"+results[0].formatted_address;
infowindow.setContent(tablaR);
infowindow.open(map,baseMarker);
}else{
alert("No results found");
}
}else{
alert("Geocoder failed due to: " + status);
}});});
}
标记的数量取决于根据 sql 查询获取的数据这是 php 脚本
<?
$script="<script type='text/javascript'>";
for($i=0;$i<count($losDatos);$i++)
{
$script.="addRoleMarker(".$losDatos[$i]['latitud'].",".$losDatos[$i]['longitud'].",".$losDatos[$i]['rumbo'].",".$losDatos[$i]['codigo'].",".$losDatos[$i]['velocidad'].",".$losDatos[$i]['numeroEconomico'].",1,'".$losDatos[$i]['utcDate']."','".$losDatos[$i]['localDate']."');";
}
$script.='</script>';
echo $script;
?>