google maps api v3上的setbounds

时间:2010-03-18 08:40:46

标签: google-maps bounds fitbounds setbounds

我正在尝试设置地图的边界 fitbounds不起作用,因为它在边界周围放置了一些空间,因此做

{{{map.fitBounds(map.getBounds())}}}

几次会快速缩小地图

我需要能够做到

{{{map.setBounds(map.getBounds())}}}

并且没有任何事情发生

请注意我使用的是api的v3,因此无法访问getBoundsZoomLevel

3 个答案:

答案 0 :(得分:4)

如果我没弄错的话,我假设您希望所有的点都能在地图上以最高的缩放级别显示。我通过将地图的缩放级别初始化为16来完成此操作(不确定它是否是V3上可能的最高缩放级别)。

var map = new google.maps.Map(document.getElementById('map_canvas'), { zoom: 16
                                        , center: marker_point
                                        , mapTypeId: google.maps.MapTypeId.ROADMAP
});

之后我做了界限:

var bounds = new google.maps.LatLngBounds();

//you can have a loop here of all you marker points
//begin loop
bounds.extend(marker_point);
//end loop

map.fitBounds(bounds);

结果:成功!

答案 1 :(得分:0)

FitBounds就像你说的扩展边界超过第二张地图的界限,为了使边界完全相同,你可以设置中心和缩放。

map2.setCenter(map.getCenter());
map2.setZoom(map.getZoom());

就像在这个JSFiddle中一样 - http://jsfiddle.net/KmNaX/

答案 2 :(得分:0)

嘿Guyzz什么都没有为我工作我计划采取这种方法..它对我有用..我从视口接受坐标,然后将其映射到边界..这种方法有效..

function codeAddress() {
    var address = document.getElementById('address').value;
    if(address == null || address== "") {
        alert('Address field is Empty.. !');
    } else {
        geocoder.geocode({
            'address' : address
        }, function(results, status) {
            if (status == google.maps.GeocoderStatus.OK) {
                // If geocoder status is OK then locate the geometry,..
                var location = results[0].geometry.location
                // Obtaining the lat lang of new position on map.. 
                var latlng = new google.maps.LatLng(location.lat(),location.lng());

                map.setCenter(location);

                // view port gives us the map bounds for a particular location.. 
                **var viewportloc = String(results[0].geometry.viewport);
                var res = viewportloc.replace('((','').replace('))','').replace('(','').replace(')','').split(',');

                //alert(res[0]+" - "+res[1]+" - "+res[2]+" - "+res[3]);
                var sw = new google.maps.LatLng(res[0],res[1]);
                var ne = new google.maps.LatLng(res[2],res[3]);

                var bounds = new google.maps.LatLngBounds();
                bounds.extend(sw);
                bounds.extend(ne);

                map.fitBounds(bounds);**

                addMarker(location);
                setonMap(map);

            } else {
                document.getElementById('address').value = "";
                alert('Geocode was not successful for the following reason: ' + status);
            }
        });
    }
}