【发布时间】:2015-04-15 08:00:39
【问题描述】:
问题陈述
radarSearch 仅在初始加载时返回靠近地图中心的位置,并且仅返回大约 140 个(不是 200 个)。我将请求对象的边界成员设置为 map.getBounds ... 当我移动地图的中心时,会添加更多位置...
问题
为什么我得到的位置少于宣传的 200 个?如何获得地图区域的详尽搜索结果?
代码
HTML
<!DOCTYPE html>
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<title></title>
<script src="//code.jquery.com/jquery-1.11.2.min.js"></script>
<style type="text/css">
html, body, #map-canvas {
height: 100%;
margin: 0;
padding: 0;
}
</style>
<script src="JavaScriptMin.js"></script>
</head>
<body>
<div id="map-canvas"></div>
</body>
</html>
Javascript
var map;
var infoWindow;
var service;
function initialize() {
var mapOptions = {
zoom: 5,
center: new google.maps.LatLng(-27.984113, 153.411076)
};
map = new google.maps.Map(document.getElementById('map-canvas'),
mapOptions);
google.maps.event.addListener(map, 'bounds_changed', performSearch);
}
function loadScript() {
var script = document.createElement('script'),
myScript = 'https://maps.googleapis.com/maps/api/js?signed_in=true&v=2.exp' +
'&libraries=weather,places&sensor;=true_or_false&signed_in=true&callback=initialize®ion=au'
script.type = 'text/javascript';
script.src = myScript;
document.body.appendChild(script);
}
window.onload = loadScript;
function performSearch() {
var request = {
bounds: map.getBounds(),
keyword: 'caravan parks'
};
if (!infoWindow) { infoWindow = new google.maps.InfoWindow() };
if (!service) { service = new google.maps.places.PlacesService(map) };
service.radarSearch(request, searchCallback);
}
function searchCallback(results, status, pagination) {
if (results) { console.log('searchCallback, results count is ' + results.length) };
if (status == google.maps.places.PlacesServiceStatus.OK) {
for (var i = 0; i < results.length; i++) {
var place = results[i];
createMarker(results[i]);
}
} else {
console.log('search failed')
}
}
function createMarker(place) {
var placeLoc = place.geometry.location;
var marker = new google.maps.Marker({
map: map,
icon: {
path: google.maps.SymbolPath.CIRCLE,
scale: 2,
opacity: 1,
fillColor: 'red',
fillOpacity: 1,
strokeColor: 'red',
strokeWeight: 1
},
position: place.geometry.location
});
}
注意事项:
- 如果我包含有效的 API 密钥,这没有任何区别。
- 如果我使用半径参数,它返回 148 个位置,但边界设置为 map.getBounds 我只得到 145。我在这个阶段的猜测是,当使用边界参数时,搜索区域是一个包含在 50公里半径圆。根据文档,这对我来说并不清楚。
【问题讨论】:
-
请提供一个Minimal, Complete, Tested and Readable example 来证明这个问题。
-
我看到your example 的问题,但无法解释。不过,您关于搜索区域大小的理论是有道理的。 60 km circle centered on the results
标签: javascript google-maps search