使用google places api自定义nearbuy地方

时间:2016-03-04 18:43:42

标签: javascript google-maps google-places-api

我是从网上得到的。

// <script src="https://maps.googleapis.com/maps/api/js?key=YOUR_API_KEY&libraries=places">

var map;
var infowindow;

function initMap() {
  var pyrmont = {lat: -33.867, lng: 151.195};

  map = new google.maps.Map(document.getElementById('map'), {
    center: pyrmont,
    zoom: 15
  });

  infowindow = new google.maps.InfoWindow();
  var service = new google.maps.places.PlacesService(map);
  service.nearbySearch({
    location: pyrmont,
    radius: 500,
    type: ['store']
  }, callback);
}

function callback(results, status) {
  if (status === google.maps.places.PlacesServiceStatus.OK) {
    for (var i = 0; i < results.length; i++) {
      createMarker(results[i]);
    }
  }
}

function createMarker(place) {
  var placeLoc = place.geometry.location;
  var marker = new google.maps.Marker({
    map: map,
    position: place.geometry.location
  });

  google.maps.event.addListener(marker, 'click', function() {
    infowindow.setContent(place.name);
    infowindow.open(map, this);
  });
}  

如何搜索CVS药店等自定义位置,而不是半径5英里?您还可以提供有关附近搜索的全套属性的参考吗?

1 个答案:

答案 0 :(得分:0)

nearbySearch()方法访问Google服务器。所以你无法添加你的数据。

替代方式是融合表。 如果您有自己的数据,请将其导入Google Fusion Table,并使用FusionTablesLayer实施您的数据。 您可以使用SQL搜索数据。 https://developers.google.com/fusiontables/docs/samples/nn_example