EDIT: Now it works, but does not load if the user does not allow or use location-based services. See the accepted comment response for a jsfiddle example.
I looked through a few lessons and questions, but I canβt understand what is happening (or doesnβt happen in this case). I load my map when the user clicks on the link. This loads a map with the current location of the users in the center and a marker at the location of the user. However, any tokens outside if (navigation.location)
do not seem to load. Below is my current code:
function initialize() { // Check if user support geo-location if (navigator.geolocation) { navigator.geolocation.getCurrentPosition(function(position) { var point = new google.maps.LatLng(position.coords.latitude, position.coords.longitude); var userLat = position.coords.latitude; var userLong = position.coords.longitude; var mapOptions = { zoom: 8, center: point, mapTypeId: google.maps.MapTypeId.HYBRID } // Initialize the Google Maps API v3 var map = new google.maps.Map(document.getElementById("map"), mapOptions); // Place a marker new google.maps.Marker({ position: point, map: map, title: 'Your GPS Location' }); }); } else { var userLat = 53; var userLong = 0; var mapOptions = { zoom: 8, center: new google.maps.LatLng(userLat, userLong), mapTypeId: google.maps.MapTypeId.HYBRID } // Place a marker new google.maps.Marker({ position: point, map: map, title: 'Default Location' }); // Initialize the Google Maps API v3 var map = new google.maps.Map(document.getElementById("map"), mapOptions); } <? for ($i = 0; $i < sizeof($userLocations); $i++) { ?> var userLatLong = new google.maps.LatLng(<? echo $userLocations[$i]['lat']; ?>, <? echo $userLocations[$i]['long']; ?>); new google.maps.Marker({ position: userLatLong, map: map, title:"<? echo $userLocations[$i]['displayName'] . ', ' . $userLocations[$i]['usertype']; ?>" }); <? } ?> } function loadMapScript() { if (typeof(loaded) == "undefined") { $("#showMap").css("display", "none"); $("#showMapLink").removeAttr("href"); $("#map").css("height", "600px"); $("#map").css("width", "600px"); var script = document.createElement("script"); script.type = "text/javascript"; script.src = "http://maps.googleapis.com/maps/api/js?key=MY_API_KEY&sensor=true&callback=initialize"; document.body.appendChild(script); loaded = true; } else { alert("Map already loaded!"); } }
loadMapScript () is called when the user clicks the link. The PHP loop for the loop goes through a pre-created array with all the information.
I assume that I do not quite understand this, as if I set:
var userLatLong = new google.maps.LatLng(53, 0); new google.maps.Marker({ position: userLatLong, map: map, title:"Title" });
in the console (Google Chrome), I get an error message:
Error: Invalid value for property <map>: [object HTMLDivElement]
However, I am not getting any errors. Any help is appreciated! :)