![]() |
![]() |
![]()
Post
#1
|
|
Grupa: Nieautoryzowani Postów: 11 Pomógł: 0 Dołączył: 25.09.2017 Ostrzeżenie: (0%) ![]() ![]() |
Witam! Potrzebuję pomocy do napisania kodu do google map, który będzie wyświetlał klika lokalizacji na raz z pobranych adresów bazy sql. Struktura bazy wygląda następująco:
id, city, post_code, street, house_number, flat_number. Tak jak pisałem wcześniej, lokalizację pobierane są po nazwach (Nie współrzędnych). Gotowy kod ma wyglądać następująco ( to jest skopiowany kod z https://developers.google.com/maps/document...rker-clustering tylko różnica jest taka, że u mnie lokalizację muszą pobierać się z bazy) Kod <!DOCTYPE html> <html> <head> <meta name="viewport" content="initial-scale=1.0, user-scalable=no"> <meta charset="utf-8"> <title>Google Map</title> <style> /* Always set the map height explicitly to define the size of the div * element that contains the map. */ #map { height: 50%; width: 30%; } /* Optional: Makes the sample page fill the window. */ html, body { height: 100%; margin: 0; padding: 0; } </style> </head> <body> <div id="map"></div> <script> function initMap() { var map = new google.maps.Map(document.getElementById('map'), { zoom: 8, center: {lat: 50.0614300, lng: 19.9365800} }); var markers = locations.map(function(location, i) { return new google.maps.Marker({ position: location, }); }); var markerCluster = new MarkerClusterer(map, markers, {imagePath: 'https://developers.google.com/maps/documentation/javascript/examples/markerclusterer/m'}); } var locations = [ {lat: 49.9873800, lng: 20.0647300}, {lat: 49.9752400, lng: 19.8286900}, {lat: 49.8338300, lng: 19.9383000}, {lat: 50.0614300, lng: 19.9365800} ] </script> <script src="https://developers.google.com/maps/documentation/javascript/examples/markerclusterer/markerclusterer.js"> </script> <script async defer src="https://maps.googleapis.com/maps/api/js?key=&callback=initMap"> </script> </body> </html> Mój kod, aktualnie wyświetla tylko 1 adres z bazy Kod ****PHP****
<?php $link = mysqli_connect("localhost", "root", "", "google_map"); $id = 2; if (mysqli_connect_errno()) { printf("Connect failed: %s", mysqli_connect_error()); exit(); } $query = "SELECT `city`, `post_code`, `street`, `house_number`, `flat_number` FROM `map` WHERE `id`= $id"; $result = mysqli_query($link, $query); $row = mysqli_fetch_row($result); echo printf("%s, %s, %s, %s, %s", $row[0], $row[1], $row[2], $row[3], $row[4]); if($row[4]== "") { $address = $row[0].', '.$row[1].', '.$row[2].', '.$row[3]; } else { $address = $row[0].', '.$row[1].', '.$row[2].', '.$row[3].', '.$row[4]; } include("maps.php"); ?> ****HTML**** <!DOCTYPE html> <html> <head> <title>Google Maps</title> <meta name="viewport" content="initial-scale=1.0, user-scalable=no"> <meta charset="UTF-8"> <style> #map { height: 50%; width: 30%; } html, body { height: 100%; margin: 0; padding: 0; } </style> </head> <body> <input id="address" type="hidden" value="<?php echo $address; ?>"> <input id="submit" type="hidden" value="Geocode"> <div id="map"></div> <script src="geo.js"></script> <script async defer src="https://maps.googleapis.com/maps/api/js?key=&callback=initMap"> </script> </body> </html> ****JS**** function initMap() { var map = new google.maps.Map(document.getElementById('map'), { zoom: 10, center: {lat: 51.297, lng: 22.886} }); var geocoder = new google.maps.Geocoder(); geocodeAddress(geocoder, map); } function geocodeAddress(geocoder, resultsMap) { var address = document.getElementById('address').value; geocoder.geocode({'address': address}, function(results, status) { if (status === 'OK') { resultsMap.setCenter(results[0].geometry.location); var marker = new google.maps.Marker({ map: resultsMap, position: results[0].geometry.location }); var infowindow = new google.maps.InfoWindow({ content: document.getElementById('address').value, maxWidth: 300 }); marker.addListener("click", function() { infowindow.open(map, marker); }); } }); } Ten post edytował STR13 25.09.2017, 18:20:20 |
|
|
![]() |
![]()
Post
#2
|
|
Grupa: Zarejestrowani Postów: 6 806 Pomógł: 1828 Dołączył: 11.03.2014 Ostrzeżenie: (0%) ![]() ![]() |
Dla funkcji geocodeAddress musisz dostarczyć tablicę adresów lub wywoływać ją dla każdego adresu z osobna (trzeba ją zmodyfikować, aby nie pobierała adresu z input).
Geolokalizację możesz przeprowadzić również na poziomie PHP, a do skryptu JS dostarczyć tylko współrzędne. |
|
|
![]()
Post
#3
|
|
Grupa: Nieautoryzowani Postów: 11 Pomógł: 0 Dołączył: 25.09.2017 Ostrzeżenie: (0%) ![]() ![]() |
Dla funkcji geocodeAddress musisz dostarczyć tablicę adresów lub wywoływać ją dla każdego adresu z osobna (trzeba ją zmodyfikować, aby nie pobierała adresu z input). Czyli jak ma to wyglądać, bo jestem jeszcze w tym trochę zielony... Cytat Geolokalizację możesz przeprowadzić również na poziomie PHP, a do skryptu JS dostarczyć tylko współrzędne. Ale adresy mają być pobierane po nazwach, nie po współrzędnych |
|
|
![]()
Post
#4
|
|
Grupa: Zarejestrowani Postów: 6 806 Pomógł: 1828 Dołączył: 11.03.2014 Ostrzeżenie: (0%) ![]() ![]() |
https://stackoverflow.com/questions/9052393...w-do-i-know-whe
Zdaję sobie sprawę, że lokalizacje są pobierane po nazwach. |
|
|
![]()
Post
#5
|
|
Grupa: Nieautoryzowani Postów: 11 Pomógł: 0 Dołączył: 25.09.2017 Ostrzeżenie: (0%) ![]() ![]() |
sory za moją nie wiedzę, ale jestem jeszcze nie co zielony w programowaniu, ten kod, który jest na stacku mam go zamienić ze swoim js czy po prostu go dodać do reszty?
|
|
|
![]() ![]() |
![]() |
Aktualny czas: 23.08.2025 - 00:06 |