Google Maps API v3 - 阵列和InfoWindows

时间:2012-06-10 06:59:53

标签: google-maps

我一直试图为我的每个标记做一段时间,但是不能让它工作。

这就是我提出的:

for(var i=0; i<markery.length; i++)
{
    var latt =  parseFloat(markery[i].attributes.getNamedItem("lat").nodeValue);
    var lon =   parseFloat(markery[i].attributes.getNamedItem("lon").nodeValue);
    var ikona_url = markery[i].attributes.getNamedItem("ikona").nodeValue;
    var nazwa = markery[i].attributes.getNamedItem("nazwa").nodeValue;
    var rozmiar = new google.maps.Size(30,23);
    var punkt_startowy = new google.maps.Point(0,0);
    var punkt_zaczepienia = new google.maps.Point(15,12);
    var ikona = new google.maps.MarkerImage(ikona_url, rozmiar, punkt_startowy, punkt_zaczepienia);
    markert.push(new google.maps.Marker({
                    position: new google.maps.LatLng(latt,lon),
                    title: nazwa,
                    icon: ikona,
                    map: map,
                    content: nazwa
                }));

    google.maps.event.addListener(marker, 'click', function() {
        var info = new google.maps.InfoWindow({content: this.content});
    });
}

完整的代码是:

<script type="text/javascript">

var map;
var marker1;
var markert = [];
var lati;
var loni;
var infowindow;

我开始了地图:

    function initialize() {

  lat = 50.42952;
  long = 15.60059;
  var latlng = new google.maps.LatLng(lat, long);
   var myOptions = {
        zoom: 5,
        center: latlng,
        mapTypeId: google.maps.MapTypeId.ROADMAP,
        draggableCursor:'crosshair',
                };

     map = new google.maps.Map(document.getElementById("map_canvas"), myOptions);
dymek = new google.maps.InfoWindow();

    google.maps.event.addListener(map, 'click', function(event) {
        add_marker(event.latLng, 'Your new marker', 'Your new marker' );
    });

}

此函数获取所点击点的地址:

     function findAddress(event) {
    var geocoder = new google.maps.Geocoder();
    geocoder.geocode({latLng: event.latLng}, function(results, status) {
      if (status == google.maps.GeocoderStatus.OK) {
        if (results[0]) {

          infoWindow.setContent(results[0].formatted_address);
          infoWindow.setPosition(event.latLng);
          infoWindow.open(map);
        }
      }
    });
  }

此功能在我点击的地图上添加了一个新标记:

function add_marker( pos, pos_title, pos_str ) {

    marker1 = new google.maps.Marker( {
        position: pos,
        map: map,
        draggable: true,
        title: pos_title
    });

    map.setZoom(15);
    map.setCenter(marker1.getPosition());
    LoadMarkers();
                    }

此函数加载我在上述函数中创建的标记附近的附近点:

function LoadMarkers()
        {

var adres='add.xml?lat='+lati+'&long='+loni;
            jx.load(adres, function(xml)
            {
                var markery = xml.getElementsByTagName("marker");
                for(var i=0; i<markery.length; i++)
                {
                    var latt            =   parseFloat(markery[i].attributes.getNamedItem("lat").nodeValue);
                    var lon         =   parseFloat(markery[i].attributes.getNamedItem("lon").nodeValue);
                    var ikona_url   =   markery[i].attributes.getNamedItem("ikona").nodeValue;
                    var nazwa       =   markery[i].attributes.getNamedItem("nazwa").nodeValue;
                var markert     =   addMarkers(latt,lon,ikona_url,nazwa);



                }

            },'xml','get');
        }

此功能实际上会在地图上标记附近的标记。这些标记是我希望infowindow显示的标记:

    function addMarkers(latt,lon,ikona_url,nazwa)
        {
            var rozmiar = new google.maps.Size(30,23);   
            var punkt_startowy = new google.maps.Point(0,0);   
            var punkt_zaczepienia = new google.maps.Point(15,12);     
            var ikona = new google.maps.MarkerImage(ikona_url, rozmiar, punkt_startowy, punkt_zaczepienia); 
            markert.push(new google.maps.Marker({
                         position: new google.maps.LatLng(latt,lon),
                         title: nazwa,
                         icon: ikona,
                         map: map,
                         animation: google.maps.Animation.DROP }));

 google.maps.event.addListener(markert, 'tilesloaded', function() {
    var info = new google.maps.InfoWindow({content: nazwa});
});

        }

1 个答案:

答案 0 :(得分:0)

你实际上并没有在任何时候打开信息窗口。请查看此documentation and example,并相应地调整您的代码。实际上,您需要对open使用infowindow方法。