避免使用多个标记在自定义谷歌地图上进行地理编码限制

时间:2011-10-04 14:06:10

标签: google-maps google-maps-api-3 gis google-maps-markers

我创建了一个包含大约150个标记的自定义地图。它只能在达到地理编码限制之前大约20左右。

我可以在代码中加入哪些内容以避免达到限制?

更新 如何为每个请求添加时间延迟,例如0.25秒(或者我可以逃脱的最低值)?

我尝试了一些不同的建议,但我似乎无法让他们使用我的代码,所以请任何示例都使用我的代码。

2 个答案:

答案 0 :(得分:19)

因此,我不认为在for循环中几乎立即发送所有请求,而是认为当地理编码返回结果时,发送下一个结果可能会更好。如果返回的结果是OVER_QUERY_LIMIT,请重新发送请求,并增加延迟。我没有找到产生最少OVER_QUERY_LIMIT的甜点超时,但至少它会创建所有标记(对于有效地址)。在我的机器上完成大约需要45秒左右。

<!DOCTYPE html>
<html>
<head>
<link href="http://code.google.com/apis/maps/documentation/javascript/examples/default.css"
rel="stylesheet" type="text/css" />
<script type="text/javascript" src="http://maps.googleapis.com/maps/api/js?sensor=false"></script>
<script type="text/javascript">
var geocoder;
var map;
var infowindow = new google.maps.InfoWindow();

var places = [];
var popup_content = [ /* all your popup_content */];
var address = [/* all of your addresses */];
var address_position = 0;

var timeout = 600;

function initialize() {
    geocoder = new google.maps.Geocoder();
    var latlng = new google.maps.LatLng(52.40, -3.61);
    var myOptions = {
      zoom: 8,
      center: latlng,
      mapTypeId: 'roadmap'
    }
    map = new google.maps.Map(document.getElementById("map_canvas"), myOptions);
    addMarker(address_position);
}

function addMarker(position)
{
    geocoder.geocode({'address': address[position]}, function(results, status)
    {
        if (status == google.maps.GeocoderStatus.OK) {
            places[position] = results[0].geometry.location;

            var marker = new google.maps.Marker({
                position: places[position],
                map: map
            });

            google.maps.event.addListener(marker, 'click', function() {
                if (!infowindow) {
                    infowindow = new google.maps.InfoWindow();
                }
                infowindow.setContent(popup_content[position]);
                infowindow.open(map, marker);
            });
        }
        else
        {
            if (status == google.maps.GeocoderStatus.OVER_QUERY_LIMIT)
            {
                setTimeout(function() { addMarker(position); }, (timeout * 3));
            }
        }
        address_position++;
        if (address_position < address.length)
        {
            setTimeout(function() { addMarker(address_position); }, (timeout));
        }
    });
}
</script>
</head>
<body onload="initialize()">
<div id="map_canvas" style="height: 80%; top:10px; border: 1px solid black;"></div>
</body>
</html>

答案 1 :(得分:1)

我当然不是代码管理员,但是我没有使用超时,而是继续在函数内调用函数(资源占用我很确定)。如果我成功,我会遍历我的计数器,否则如果不成功,我会使用当前计数器值调用我的函数。按照这个速度,我可以为我的37折线循环1000次(或标记,如果那是你的图纸),但我相信它会在尽可能早的时候完成。这是一个例子 - 我首先调用我的情节函数onclick作为plot(0):

function plot(k)
{
...
if (status == google.maps.GeocoderStatus.OK)
        {
            draw(r.routes[0]);
            if(k<origArray.length) plot(k++);
        }
else plot(k)
...
}