谷歌地图 api 初始缩放错误

Posted

技术标签:

【中文标题】谷歌地图 api 初始缩放错误【英文标题】:google maps api initial zoom error 【发布时间】:2012-12-29 20:53:42 【问题描述】:

我有以下代码:

<?php if($_GET['postcode']) ?>

//alert(<?php echo $_GET['postcode'];?>)

<?php ?>

      function initialize() 
        var mapOptions = 
          zoom: 6,
          center: new google.maps.LatLng("<?php echo $_GET['postcode'];?>"),
          mapTypeId: google.maps.MapTypeId.ROADMAP
        ;

        var map = new google.maps.Map(document.getElementById('map_canvas'),mapOptions);
        map.setTilt(45);

        var addressArray = new Array("<?php echo $_GET['postcode'];?>");
        var geocoder = new google.maps.Geocoder();

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

        for (var i = 0; i < addressArray.length; i++) 
        geocoder.geocode(  'address': addressArray[i], function(results, status) 
        if (status == google.maps.GeocoderStatus.OK) 

        var contentString = '<div id="content">'+
        '<div id="siteNotice">'+
        '</div>'+
        '<h4 id="firstHeading" class="firstHeading">HELLO</h4>'+
        '<div id="bodyContent">'+
        '<p><b>Hello!!</b>' + <?php echo $_GET["order_id"];?> + '</p>'+
        '</div>'+
        '</div>';

        var infowindow = new google.maps.InfoWindow(
        content: contentString
        );

        var marker = new google.maps.Marker(
        map: map, 
        title:"Order Number",
        position: results[0].geometry.location
        );

        markerBounds.extend(results[0].geometry.location);
        map.fitBounds(markerBounds);

        google.maps.event.addListener(marker, 'click', function() 
        infowindow.open(map,marker);
        );

         else 
        alert("Geocode was not successful for the following reason: " + status);
        
        );
        
      

      function loadScript() 
        var script = document.createElement('script');
        script.type = 'text/javascript';
        script.src = 'https://maps.googleapis.com/maps/api/js?v=3.exp&sensor=false&' +
            'callback=initialize';
        document.body.appendChild(script);
      

      window.onload = loadScript;
    </script>

由于某种原因,当地图加载时,缩放级别已满,因此它会直接缩放到标记中。我尝试在初始化部分调整缩放级别,但我没有高兴。我的猜测是,它与标记边界有关。任何人都知道如何调整缩放以使其不会完全缩放到标记上?

【问题讨论】:

【参考方案1】:

由于某种原因,当地图加载时,缩放级别已满,所以它直接放大到 标记。

如果您有一个带有一个 LatLng 的 bounds 对象,它应该尽可能放大。来自文档:

fitBounds(bounds:LatLngBounds) 无 将视口设置为包含给定的边界。

如果你只有一个标记,不要使用 fitBounds,使用 .setCenter(在标记的坐标上,.setZoom(到你想要的缩放级别)。

如果您的代码需要处理这两种情况(一个标记或多个标记),请计算您添加到边界的标记,如果数字为 1,则使用 .setCenter/.setZoom,如果超过 1,请使用 .fitBounds .

【讨论】:

以上是关于谷歌地图 api 初始缩放错误的主要内容,如果未能解决你的问题,请参考以下文章

谷歌地图api没有刷新

谷歌地图 KML 图层初始缩放和居中

如何禁用滚动缩放。谷歌地图嵌入 API [重复]

Android 谷歌地图 API v2 中心缩放

如何在谷歌地图中设置缩放级别

如何计算适当的谷歌地图缩放级别