5

我在调用 fitBounds() 之后直接调用 getBounds(),并且我认为当地图居中并缩放以适应边界时,我会得到一个有效的边界。不幸的是,getBounds() 返回 nil。

重现此的代码如下:

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd"> 
<html xmlns="http://www.w3.org/1999/xhtml" xmlns:v="urn:schemas-microsoft-com:vml"> 
    <head> 
        <meta http-equiv="content-type" content="text/html; charset=utf-8"/> 
        <script type="text/javascript" src="http://maps.google.com/maps/api/js?sensor=true"></script>

        <style>
            #map {
                width: 800px;
                height: 400px;
            }
        </style>

    </head>
    <body>
        <div id='map'></div>

        <script>
            var myLatlng1 = new google.maps.LatLng(-38.397, 150.644);
            var myLatlng2 = new google.maps.LatLng(-34.897, 150.844);
            var myLatLngBounds = new google.maps.LatLngBounds(myLatlng1, myLatlng2);

            var myOptions = {
                  mapTypeId: google.maps.MapTypeId.ROADMAP,
                  center: new google.maps.LatLng(0, 0),
                  zoom: 0
            }

            var map = new google.maps.Map(document.getElementById("map"), myOptions);

            map.fitBounds(myLatLngBounds);

            console.log(map.getMapTypeId());
            console.log(map.getZoom());
            console.log(map.getBounds());
        </script>
    </body>
</html>

有什么我想念的吗?我无法在文档中找到有关这种情况的任何内容。我得到的最接近的是 getBounds 上的注释,上面写着:

如果地图尚未初始化(即 mapType 仍为 null),或者尚未设置中心和缩放,则结果为 null。

请注意,getZoom 也返回 undefined。fitBounds() 没有设置这个值吗?

编辑 根据 Marcelo 的建议,我已经使用默认缩放和中心更新了代码。

4

4 回答 4

8

正如@CrazyEnigma 建议bounds_changed的那样,您可以在事件触发后获得边界:

map.fitBounds(myLatLngBounds);

google.maps.event.addListener(map, 'bounds_changed', function() {
  console.log(map.getMapTypeId());
  console.log(map.getZoom());
  console.log(map.getBounds());
});

以上会将以下内容打印到您的控制台:

roadmap
6
Object

请注意,如果您只想getBounds做某事一次,则应替换addListeneraddListenerOnce(谢谢,@Tomas)。

于 2010-08-18T09:09:49.673 回答
7

在 bounds_changed 事件之后,您必须获得边界。

于 2010-08-17T21:23:38.560 回答
0

加载瓦片时使用 addListenerOnce

google.maps.event.addListenerOnce(map, 'tilesloaded', function(){ 
map.setCenter(myLatLngBounds)
});
于 2013-07-23T00:34:40.710 回答
-1

答案在您自己的报价中。您必须为要初始化的地图设置中心和缩放。

请注意,在 MapOptions 对象规范的文档中, center 和 zoom 的值被标记为required

http://code.google.com/apis/maps/documentation/javascript/reference.html#MapOptions

于 2010-08-18T04:23:11.207 回答