谷歌地图 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 初始缩放错误的主要内容,如果未能解决你的问题,请参考以下文章