How to get the formatted address from a dragged marker in Google Version Maps

前端 未结 1 1884
自闭症患者
自闭症患者 2020-11-29 04:30

I have made a Google map that lets you input an address into a text field. It then navigates you to the address that you entered into the text field and leaves a draggable

相关标签:
1条回答
  • 2020-11-29 05:11

    You need to use the reverse geocoding service (as demonstrated in the example you link to) to retrieve the formatted address.

    This code from that example calls the reverse geocoder and uses the response to display the formatted_address that is returned by it:

    function geocodePosition(pos) {
      geocoder.geocode({
        latLng: pos
      }, function(responses) {
        if (responses && responses.length > 0) {
          updateMarkerAddress(responses[0].formatted_address);
        } else {
          updateMarkerAddress('Cannot determine address at this location.');
        }
      });
    }
    

    This is the dragend listener that calls it:

      google.maps.event.addListener(marker, 'dragend', function() {
        updateMarkerStatus('Drag ended');
        geocodePosition(marker.getPosition());
      });
    

    Here is a working example (puts the address received from the reverse geocoder in the infowindow)

    code snippet:

    var geocoder;
    var map;
    var marker;
    var infowindow = new google.maps.InfoWindow({
      size: new google.maps.Size(150, 50)
    });
    
    function initialize() {
      geocoder = new google.maps.Geocoder();
      var latlng = new google.maps.LatLng(-34.397, 150.644);
      var mapOptions = {
        zoom: 8,
        center: latlng,
        mapTypeId: google.maps.MapTypeId.ROADMAP
      }
      map = new google.maps.Map(document.getElementById('map_canvas'), mapOptions);
      google.maps.event.addListener(map, 'click', function() {
        infowindow.close();
      });
    }
    
    function geocodePosition(pos) {
      geocoder.geocode({
        latLng: pos
      }, function(responses) {
        if (responses && responses.length > 0) {
          marker.formatted_address = responses[0].formatted_address;
        } else {
          marker.formatted_address = 'Cannot determine address at this location.';
        }
        infowindow.setContent(marker.formatted_address + "<br>coordinates: " + marker.getPosition().toUrlValue(6));
        infowindow.open(map, marker);
      });
    }
    
    function codeAddress() {
      var address = document.getElementById('address').value;
      geocoder.geocode({
        'address': address
      }, function(results, status) {
        if (status == google.maps.GeocoderStatus.OK) {
          map.setCenter(results[0].geometry.location);
          if (marker) {
            marker.setMap(null);
            if (infowindow) infowindow.close();
          }
          marker = new google.maps.Marker({
            map: map,
            draggable: true,
            position: results[0].geometry.location
          });
          google.maps.event.addListener(marker, 'dragend', function() {
            geocodePosition(marker.getPosition());
          });
          google.maps.event.addListener(marker, 'click', function() {
            if (marker.formatted_address) {
              infowindow.setContent(marker.formatted_address + "<br>coordinates: " + marker.getPosition().toUrlValue(6));
            } else {
              infowindow.setContent(address + "<br>coordinates: " + marker.getPosition().toUrlValue(6));
            }
            infowindow.open(map, marker);
          });
          google.maps.event.trigger(marker, 'click');
        } else {
          alert('Geocode was not successful for the following reason: ' + status);
        }
      });
    }
    
    google.maps.event.addDomListener(window, "load", initialize);
    html,
    body {
      height: 100%;
      margin: 0;
      padding: 0;
    }
    
    #map_canvas {
      height: 100%;
    }
    
    @media print {
      html,
      body {
        height: auto;
      }
      #map_canvas {
        height: 650px;
      }
    }
    <script src="https://maps.googleapis.com/maps/api/js?key=AIzaSyCkUOdZ5y7hMm0yrcCQoCvLwzdM6M8s5qk"></script>
    <div>
      <input id="address" type="textbox" value="Sydney, NSW">
      <input type="button" value="Geocode" onclick="codeAddress()">
    </div>
    <div id="map_canvas" style="height:90%;top:30px"></div>

    0 讨论(0)
提交回复
热议问题