Sto iniziando a conoscere PHP e JavaScript, mescolandoli in HTML e utilizzando l'API di Google Maps (versione 3).'Uncaught InvalidValueError' (: setCenter: non un oggetto LatLng o LatLngLiteral)
ho pensato come 'mettere' diversi marcatori ma la console mi genera un errore:
"InvalidValueError Uncaught: setCenter: non un LatLng o un oggetto LatLngLiteral".
Penso che sia perché la var creata nel ciclo non è esattamente l'oggetto necessario ma invece una stringa, anche se questo mi confonde, non so se ho ragione. Lo apprezzerei molto se qualcuno potesse mettermi sulla strada giusta.
Grazie in anticipo.
Questo è il mio codice: (A proposito, l'array sto loop è una matrice con un array con una matrice, ecco alcune delle quali si segue il modello, ci sono in totale 6 'posti'.) :
$locations = array(
array(
'Location' => array(
'Title'=>'Place',
'Description'=>'Some Place',
'Image'=>'pin1.png',
'Latitude'=>'20.681775',
'Longitude'=>'-103.351479'
)
),…
(Continua ...).
<!DOCTYPE html>
<html>
<head>
<meta name="viewport" content="initial-scale=1.0, user-scalable=no" />
<style type="text/css">
html { height: 100% }
body { height: 100%; margin: 0; padding: 0 }
#map-canvas { height: 100% }
</style>
<script type="text/javascript"
src="https://maps.googleapis.com/maps/api/js?AIzaSyBVfO8LckdOHAot1a8rZW0bmJIoWO2A3os=API_KEY&sensor=true">
</script>
<script type="text/javascript">
function initialize() {
var mapOptions = {
center: (20.68177501, -103.3514794),
zoom: 15,
mapTypeId: google.maps.MapTypeId.ROADMAP
};
var map = new google.maps.Map(document.getElementById("map-canvas"),
mapOptions);
// To add the marker to the map, use the 'map' property
<?php $i = 0; ?>
<?php foreach($locations as $key => $value): ?>
<?php foreach($value as $key => $value): ?>
<?php foreach($value as $key => $value): ?>
<?php if($key == "Latitude"): ?>
<?php $myLatLng = "$value, "; endif;?>
<?php if($key == "Longitude"): ?>
<?php $myLatLng .="$value"; ?>
var myLatlng<?php echo $i; ?> = new google.maps.LatLng(<?php echo $myLatLng; ?>);
var marker<?php echo $i; ?> = new google.maps.Marker({
position: (myLatlng<?php echo $i; ?>),
title:"Hello World!"
});
marker<?php echo $i; ?>.setMap(map);
<?php $i++; ?>
<?php endif; ?>
<?php endforeach; ?>
<?php endforeach; ?>
<?php endforeach; ?>
}
google.maps.event.addDomListener(window, 'load', initialize);
</script>
</head>
<body>
<div id="map-canvas"/>
</body>
</html>
Ed ecco uno screenshot di che var assegnazione di parte: "http://cl.ly/image/1d3e2J360t3y"
questo sarà solo rimuovere le mappe di Google sceneggiatura, rendendo tutto il suo codice che fa riferimento all'API, rotto. Non vedo come questo possa aiutare in alcun modo. –