1

我在我的网站上使用谷歌地图 API。地图从 xml 中获取数据,然后使用经度和纬度在各个位置上显示标记。但是,我在 xml 中有 500 多个条目,但地图并未显示所有条目。谁能帮帮我。我需要地图上整个 xml 的标记。地图显示在“ http://saleon.com.pk/ ”上,地图使用的 xml 文件是“ http://saleon.com.pk/test/generate.php ”。对于谷歌地图,我的代码是这样的:

    <script type="text/javascript">
  var infowindow;
  var map;
  function initialize(str,category,city,minprice,maxprice,flag) {

var myLatlng = new google.maps.LatLng(30.55538, 73.13690);
    var myOptions = {
      zoom: 5,
      center: myLatlng,
      mapTypeId: google.maps.MapTypeId.ROADMAP
    }
    map = new google.maps.Map(document.getElementById("map_canvas"), myOptions);

    downloadUrl("<?php echo WEB_PATH;?>test/generate.php", function(data){
      var markers = data.documentElement.getElementsByTagName("marker");
      for (var i = 0; i < markers.length; i++) {
        var latlng = new google.maps.LatLng(parseFloat(markers[i].getAttribute("lat")),
                                    parseFloat(markers[i].getAttribute("lng")));
        var marker = createMarker(markers[i].getAttribute("name1"),markers[i].getAttribute("name2"), markers[i].getAttribute("img"), markers[i].getAttribute("description"), markers[i].getAttribute("id"), latlng);
       }
     });

    function createMarker(name1,name2, img, description, id, latlng) {
    var marker = new google.maps.Marker({position: latlng, map: map});
    google.maps.event.addListener(marker, "click", function() {
      if (infowindow) infowindow.close();
      infowindow = new google.maps.InfoWindow({content: '<div style="float:left;"><img src="<?php echo WEB_PATH;?>'+img+'" width="75px" height="75px" /></div><div style="float:left; margin-left:10px; font:Arial;"><div style="font-weight:bold;">'+name1+'<br/>'+name2+'</div><div style="width:200px;">'+description+'</div><div><a href="<?php echo WEB_PATH;?>index.php?page=item&id='+id+'">View Product</a></div></div>'});
      infowindow.open(map, marker);
    });
    return marker;
}
</script>
4

1 回答 1

1

您在 xml 文件中为这么多标记定义了相同的纬度和经度。例如 lat="33.718151" lng="73.060547" 出现在 52 个条目中。您的标记将被覆盖,因为它们位于同一位置。对于在同一位置有多个标记的情况,您可以在距离实际点的半径范围内稍微偏移标记(例如 0.001 度)。这也应该产生一个很好的视觉效果。

于 2013-03-15T11:01:25.567 回答