Google Maps v3 getBounds超出了地图上可见的范围

时间:2010-08-21 03:36:43

标签: google-maps map mapping google-maps-api-3

出于某种原因,Google地图v3的getBounds()功能似乎比地图实际显示的功能延伸得更远。如果我错了,请纠正我,但不应该返回当前视图中显示的角落的NE(右上角)和SW(左下角)纬度和经度坐标?

我正在返回这些坐标之间的搜索结果(由lat和lng映射),并且返回的结果远远超出getBounds()返回的区域。关于可能会发生什么的任何想法?

仅供参考,我正在接受地图空闲事件的界限:

google.maps.event.addListener(map, 'idle', function() {

var bounds = map.getBounds();
var NE = bounds.getNorthEast();
var SW = bounds.getSouthWest();

...并使用.lat()和.lng()从各个角落获取坐标。然后我将它提供给SQL查询,该查询检查这些坐标之间的结果。结果在一般区域,但可能远远超出地图上实际显示的范围。

任何想法都表示赞赏!谢谢!

1 个答案:

答案 0 :(得分:18)

正确,map.getBounds()将返回可视区域的边界,如下例所示。在此示例中,当map.getBounds()事件触发时,使用idle的点绘制红色Polyline框。

您的SQL查询可能无法返回您要查找的结果,可能需要再次查看。

<!DOCTYPE html>
<html>
<head>
<title>Bounds Box</title>
<script type="text/javascript"
    src="http://maps.google.com/maps/api/js?sensor=false">
</script>
<script type="text/javascript">
      function initialize() {

        var latlng = new google.maps.LatLng(30.405865,-87.283362);
        var myOptions = {
          zoom: 8,
          center: latlng,
          mapTypeId: google.maps.MapTypeId.ROADMAP
        };
        var map = new google.maps.Map(document.getElementById("map_canvas"),
            myOptions);
        var viewportBox;

        google.maps.event.addListener(map, 'idle', function(event) {
            var bounds = map.getBounds();

            var ne = bounds.getNorthEast();
            var sw = bounds.getSouthWest();

            var viewportPoints = [
                ne, new google.maps.LatLng(ne.lat(), sw.lng()),
                sw, new google.maps.LatLng(sw.lat(), ne.lng()), ne
            ];
            /*strokeOpacity = 0 , if don't want to show the border moving. */
            if (viewportBox) {
                viewportBox.setPath(viewportPoints);
            } else {
                viewportBox = new google.maps.Polyline({
                    path: viewportPoints,
                    strokeColor: '#FF0000',
                    strokeOpacity: 1.0,
                    strokeWeight: 4 
                });
                viewportBox.setMap(map);
            };

            var info = document.getElementById('info');
            info.innerHTML = 'NorthEast: ' + ne.lat() + '   ' + ne.lng() + 
                '<br />' + 'SouthWest: ' + sw.lat() + '   ' + sw.lng();
        });
      };
</script>
</head>
<body onload="initialize()">
  <div id="map_canvas" style="width:500px; height:500px"></div>
  <div id="info"></div>
</body>
</html>