Я использую Google Maps API v2. Я добавляю маркеры на карту, а затем увеличиваю масштаб, чтобы соответствовать этим маркерам. Это хорошо работает, если карта видна, я делаю это. Но если нет - например, если у меня есть вкладка, а вкладка карты не выбирается при загрузке страницы, - тогда, когда я показываю карту, уровень масштабирования и центр неверны.
Вот простой тестовый пример (использует jQuery):
<script type="text/javascript">
var scale = Math.random() * 20;
$(document).ready(function() {
var $container = $('#container');
// $container.hide();
var map = new GMap2($('#map')[0]);
$container.show();
var markerBounds = new GLatLngBounds();
for (var i = 0; i < 10; i++) {
var randomPoint = new GLatLng(38.935394 + (Math.random() - 0.5) * scale, -77.061382 + (Math.random() - 0.5) * scale);
map.addOverlay(new GMarker(randomPoint));
markerBounds.extend(randomPoint);
}
map.setCenter(markerBounds.getCenter(), map.getBoundsZoomLevel(markerBounds));
});
</script>
<div id="container">
<div id="map" style="margin: 100px; width: 450px; height: 300px;"></div>
</div>
Это работает нормально, как есть, но если вы раскомментируете $container.hide()
, это все вырублено.
Есть ли способ заставить API Карт Google работать должным образом на невидимом элементе div?