我正在尝试显示Google Fusion Table中的点数,这些点会根据地理编码事件呈现它们。事件使地图居中,显示标记,但我希望它能够根据新地图中心和固定半径在桌面上进行新选择。我的尝试是将一个变量传递给空间查询,但我不知道在哪里放它或者我正在调用它。
就此而言,即使只使用onClick事件来触发新查询也会很酷,但它也是同样的问题。
提前致谢...拉法
<!DOCTYPE html>
<html>
<head>
<meta name="viewport" content="initial-scale=1.0, user-scalable=no" />
<meta http-equiv="content-type" content="text/html; charset=UTF-8"/>
<title>Selected Records from Google Fusion Table based on Geocoded Location</title>
<style>
body { font-family: Arial, sans-serif; }
#map_canvas { height: 600px; width:700px; }
</style>
<script type="text/javascript" src="http://maps.google.com/maps/api/js?sensor=false"></script>
<script type="text/javascript">
var layer;
var geocoder;
var map;
var tableid = 411675;
// initialize the map =====================
function initialize() {
geocoder = new google.maps.Geocoder();
var latlng = new google.maps.LatLng(45.526, -122.6684);
var myOptions = {
zoom: 8,
center: latlng,
mapTypeId: google.maps.MapTypeId.ROADMAP
}
map = new google.maps.Map(document.getElementById('map_canvas'), myOptions);
layer = new google.maps.FusionTablesLayer(tableid);
layer.setMap(map);
}
// operates geocoder =====================
function codeAddress() {
var gcAddress = document.getElementById("gcAddress").value;
geocoder.geocode( { 'address': gcAddress}, function(results, status) {
if (status == google.maps.GeocoderStatus.OK) {
map.setCenter(results[0].geometry.location);
var marker = new google.maps.Marker({
map: map,
position: results[0].geometry.location
});
layer.setQuery("SELECT Address FROM " + tableid + " WHERE ST_INTERSECTS(Address, CIRCLE(LATLNG(" + position + "), 5000))");
} else {
alert("Geocode was not successful for the following reason: " + status);
}
});
}
</script>
</head>
<body onload="initialize();">
<div>
<input id="gcAddress" type="textbox" value="Hillsboro, OR">
<input type="button" value="Geocode" onclick="codeAddress()">
</div>
<div id="map_canvas"></div>
</body>
答案 0 :(得分:0)
我想你的表情可能有些不对。
var query = "SELECT Address FROM " + tableid + " WHERE ST_INTERSECTS(Address, CIRCLE(LATLNG" + marker.position + ", 20000))";
我更新了位置以读取marker.position,删除了它自带的括号。然后我将半径扩展到20000以进行测试。
这对我有用。如果您需要测试查询,可以使用
等示例http://kh-samples.googlecode.com/svn/trunk/talks/samples/fusiontableslayer.html
作为测试的基础(只需保存并修改它的表),希望能帮助捆绑:)
希望这有帮助。
马特