Подтвердить что ты не робот

Fitbounds() в картах Google api V3 не соответствует ограничениям

Я использую геокодер из Google API v3 для отображения карты страны. Я получаю рекомендуемое окно просмотра для страны, но когда я хочу сопоставить карту с этим окном просмотра, он не работает (см. Границы до и после вызова функции fitBounds в коде ниже).

Что я делаю неправильно?

Как настроить окно отображения моей карты на results[0].geometry.viewport?

var geocoder = new google.maps.Geocoder();
geocoder.geocode(
    {'address': '{{countrycode}}'},
    function(results, status) {
        var bounds = new google.maps.LatLngBounds();
        bounds = results[0].geometry.viewport;
        console.log(bounds);          // ((35.173, -12.524), (45.244, 5.098))
        console.log(map.getBounds()); // ((34.628, -14.683), (58.283, 27.503))
        map.fitBounds(bounds);               
        console.log(map.getBounds()); // ((25.740, -24.806), (52.442, 17.380))
    }
);
4b9b3361

Ответ 1

Это происходит потому, что fitBounds() необходимо привязать к окну просмотра, который подходит для холста карты, используя максимальный уровень масштабирования. С другой стороны, окно просмотра, возвращаемое геокодером, не зависит от размера, макета или уровня масштабирования холста карты. Поэтому метод fitBounds() настраивает окно просмотра карты, чтобы просмотреть пройденный LatLngBounds в полном объеме в центре карты.

Вы можете проверить следующий пример для более четкой демонстрации:

<!DOCTYPE html>
<html> 
<head> 
   <meta http-equiv="content-type" content="text/html; charset=UTF-8"/> 
   <title>Google Maps fitBounds Demo</title> 
   <script src="http://maps.google.com/maps/api/js?sensor=false" 
           type="text/javascript"></script> 
</head> 
<body> 
   <div id="map" style="width: 500px; height: 350px"></div> 

   <script type="text/javascript"> 
      var myOptions = { mapTypeId: google.maps.MapTypeId.ROADMAP };
      var map = new google.maps.Map(document.getElementById("map"), myOptions);
      var geocoder = new google.maps.Geocoder();

      geocoder.geocode({'address': 'RU'}, function (results, status) {
         var ne = results[0].geometry.viewport.getNorthEast();
         var sw = results[0].geometry.viewport.getSouthWest();

         map.fitBounds(results[0].geometry.viewport);               

         var boundingBoxPoints = [
            ne, new google.maps.LatLng(ne.lat(), sw.lng()),
            sw, new google.maps.LatLng(sw.lat(), ne.lng()), ne
         ];

         var boundingBox = new google.maps.Polyline({
            path: boundingBoxPoints,
            strokeColor: '#FF0000',
            strokeOpacity: 1.0,
            strokeWeight: 2
         });

         boundingBox.setMap(map);
      }); 
   </script> 
</body> 
</html>

Ниже приведены некоторые скриншоты для разных стран из приведенного выше примера. Красный ограничивающий прямоугольник - это окно просмотра, возвращаемое геокодером. Обратите внимание на разницу между ограничивающим прямоугольником и фактическим окном просмотра, настроенным с помощью fitBounds():

Страна: США

US

Страна: RU

RU

Страна: IT

IT

Ответ 2

Чтобы сообщить вам, каким образом это может быть настроено, я подготовил образец того, что вы можете сделать, если вы предпочитаете потерять некоторые из ограничивающих боксов в окне просмотра

  • образец с просто fitBounds: http://jsbin.com/cakuhaca/1/edit

  • образец, когда вам все равно, что все видовые окна видны и всегда увеличивают еще один уровень: http://jsbin.com/rofupidi/1/edit

  • образец, когда вы заботитесь только в том случае, если ограничение ограничивающей рамки, которое вы теряете, больше, чем X пикселей по горизонтали или по вертикали http://jsbin.com/rezapuye/1/edit