Sunday, May 19, 2024
 Popular · Latest · Hot · Upcoming
59
rated 0 times [  62] [ 3]  / answers: 1 / hits: 41479  / 12 Years ago, mon, september 10, 2012, 12:00:00

I have a problem with a map on which I've used the fitBounds map methods, which should give the proper zoom and center the map giving it a latlon array. here's the code:



<script type=text/javascript
src=http://maps.googleapis.com/maps/api/js?sensor=false>
</script>


<div id=map_canvas>

<script type=text/javascript>
var map;
var bounds = new google.maps.LatLngBounds(null);

function initialize() {
var mapOptions = {

mapTypeId: google.maps.MapTypeId.ROADMAP
};

map = new google.maps.Map(document.getElementById(map_canvas), mapOptions);



<?php
foreach ($this->getProductCollection() as $_e):
$event = Mage::getModel('catalog/product')->load($_e->getId());
?>
var loc = new google.maps.LatLng(<?php echo $event->getEventLocationLatitude(); ?>,<?php echo $event->getEventLocationLongitude(); ?>);
bounds.extend(loc);
addMarker(loc, '<?php echo $event->getName(); ?>', active);
bounds.extend(loc);

<?php endforeach; ?>


map.fitBounds(bounds);
map.panToBounds(bounds);


}


function addMarker(location, name, active) {
var marker = new google.maps.Marker({
position: location,
map: map,
title: name,
status: active
});

}



jQuery.noConflict();

jQuery(document).ready(function(){
initialize();
});
</script>




The markers are correctly placed on the map, but I get the maximum zoom available:



enter



Any help?


More From » google-maps

 Answers
1

I've updated your fiddle here: http://jsfiddle.net/KwayW/1/



It works now as expected.



Here's the full code (save this as test.html and open in browser):



<style>#map_canvas { width:500px; height: 400px; }</style>
<script src=http://maps.googleapis.com/maps/api/js?sensor=false></script>
<script src=https://ajax.googleapis.com/ajax/libs/jquery/1.8.1/jquery.min.js></script>

<div id=map_canvas></div>

<script>
var map;
var markersArray = [];
var image = 'img/';
var bounds = new google.maps.LatLngBounds();
var loc;

function init(){
var mapOptions = { mapTypeId: google.maps.MapTypeId.ROADMAP };
map = new google.maps.Map(document.getElementById(map_canvas), mapOptions);

loc = new google.maps.LatLng(45.478294,9.123949);
bounds.extend(loc);
addMarker(loc, 'Event A', active);

loc = new google.maps.LatLng(50.83417876788752,4.298325777053833);
bounds.extend(loc);
addMarker(loc, 'Event B', active);

loc = new google.maps.LatLng(41.3887035,2.1807378);
bounds.extend(loc);
addMarker(loc, 'Event C', active);

map.fitBounds(bounds);
map.panToBounds(bounds);
}

function addMarker(location, name, active) {
var marker = new google.maps.Marker({
position: location,
map: map,
title: name,
status: active
});
}

$(function(){ init(); });
</script>

[#83157] Friday, September 7, 2012, 12 Years  [reply] [flag answer]
Only authorized users can answer the question. Please sign in first, or register a free account.
kinsley

Total Points: 352
Total Questions: 84
Total Answers: 94

Location: Denmark
Member since Tue, Jul 19, 2022
2 Years ago
;