开发者问题收集

使用位置自动完成时设置地图的初始位置-Google Places API

2013-05-01
5785

可以这样做吗?

这是我在 Google https://groups.google.com/forum/?fromgroups=#!topic/google-maps-js-api-v3/kdgueJzwvK4 中找到的。

我已经做到了:

  # TODO In case input has currently a value
  if autocomplete.getPlace()
    places.pin(autocomplete.getPlace(), map, input)

但是当用户没有触发某些事件时, autocomplete.getPlace() 会返回未定义。

用户输入一些数据后,我可以使用 places.pin(autocomplete.getPlace(), map, input) 而不会出现问题

我试图在输入中触发更改,但没有运气 $(input).trigger('change')

1个回答

这是我很久以前写的一些代码,可能会给你指明正确的方向。可能有一些空白需要你去填补。

<!DOCTYPE html>
     <html lang="en">
          <head>
          </head>
     <body>
         <input id="gmap_start_address" type="text" />
     </body>
</html>

initialize();
        // Handle enter button click event for start address input text field
        $("#gmap_start_address").keypress(function(event){
            if(event.keyCode == 13){
                event.preventDefault();
                goStartAddr();
            }
        });

/**
 * Handle initialization of google map
 * @params
 */
function initialize() {
    var gmapZoom = 4;
    geocoder = new google.maps.Geocoder();
    // Set default myLatLng to be used if google.loader.ClientLocation fails
    var myLatlng = new google.maps.LatLng(40.8802950337396, -102.21679674999996);
    // If ClientLocation was filled in by the loader, use that info instead
    if (google.loader.ClientLocation) {
        gmapZoom = 13;
        myLatlng = new google.maps.LatLng( google.loader.ClientLocation.latitude, google.loader.ClientLocation.longitude);
    }
    var myOptions = {
        zoom: gmapZoom,
        center: myLatlng,
        mapTypeId: google.maps.MapTypeId.ROADMAP
    }
    map = new google.maps.Map(document.getElementById("map_canvas"), myOptions);
    var polyOptions = {
        strokeColor: '#5F5CFA',
        strokeOpacity: 0.5,
        strokeWeight: 3
    }
    poly = new google.maps.Polyline(polyOptions);
    poly.setMap(map);
    // Add a listener for the click event
    google.maps.event.addListener(map, 'click', addLatLng);
}

/**
 * Handle GO button click to process start address
 * @params
 */
function goStartAddr(){
    var startAddr = $('#gmap_start_address').val();
    if(startAddr != '' && startAddr != 'Starting address, city, zip code'){
        placeStartMkr();
    } else {
        alert('Please enter start address.');
        $('#gmap_start_address').focus();
    }
}
/**
 * Handle marker placement from human address start point.
 * Originally this function placed a starting marker
 * Starting marker code is commented out and preserved for
 * ease of use in the future.
 * @params
 */
function placeStartMkr(){
    // Grab address
    var humanAddr = $('#gmap_start_address').val();
    geocoder.geocode( { 'address': humanAddr}, function(results, status) {
    if (status == google.maps.GeocoderStatus.OK) {
            map.setCenter(results[0].geometry.location);
            map.setZoom(16);
        } else {
            alert("Geocode was not successful for the following reason: " + status);
        }
    });
}
Dropzilla
2013-05-01