我一直在寻找一种方法来检索地图中多边形内的所有地址(谷歌地图?)。我在this post看到有人说这是不可能的.. 我问这个问题:如果可以从地图上的某个点重新检索地址,为什么不能在多边形中执行相同的操作?你不能只是: - 在多边形区域设置一个hypoteticl网格 - 为网格的每个交叉点检索位置地址 - 存储地址(如果已经存储,则删除它)。
Wouln这种方法可行吗?谢谢弗朗切斯科
答案 0 :(得分:0)
环顾四周,我几乎找到了一种方法,合并各种方法..我是js的新手,所以我的代码可能充满了愚蠢的东西.. 无论如何,我达到了一个点,我设法将我的唯一地址转换为数组,但由于我总是得到OVER_QUERY_LIMIT的错误,因此无法完成工作,因为我发送的请求过多in this page < / p>
所以我认为没有办法做到这一点,除非你想花很多钱购买计费以解锁更高的配额,这将是一个非常大的打击,因为这样的方法将需要每次通话数千请求。 无论如何,这是代码,插入here找到的代码,我从Polygon Drawing and Getting Coordinates with Google Map API v3获得 对不起,你会发现其中的各种新手。
var arrAddress=[]; //global
var arrCoord=[]; //global
function selPoly(shape) { //after create polygon do the job
var latlngStr=[];
var lat,lng;
var polCoords = [];
posstr = "" + selectedShape.position;
if (typeof selectedShape.position == 'object') {
posstr = selectedShape.position.toUrlValue();
}
if (typeof selectedShape.getPath == 'function') {
var mycoord="";
var partlng, partlng;
for (var i = 0; i < selectedShape.getPath().getLength(); i++) {
// .toUrlValue(5) limits number of decimals, default is 6 but can do more
mycoord=selectedShape.getPath().getAt(i).toUrlValue();
latlngStr = mycoord.split(',');
//create array with polygon path
polCoords.push(new google.maps.LatLng(latlngStr[0] , latlngStr[1]));
//add 0s to lat
lat=latlngStr[0];
partlat = latlngStr[0].substring(latlngStr[0].indexOf(".") + 1);
switch(partlat.length) {
case 4:
lat =lat +"00";
break;
case 5:
lat =lat +"0";
break;
}
//add 0s to lng
lng=latlngStr[1];
partlng = latlngStr[1].substring(latlngStr[1].indexOf(".") + 1);
switch(partlng.length) {
case 4:
lng =lng +"00";
break;
case 5:
lng =lng +"0";
break;
}
arrCoord.push(lat+","+lng);
}
};
//find higher and lower lat and lng in the polygon, converting lan e lng to number
var maxlat=0, maxlng=0;minlat=99999999,minlng=9999999;
var latlngStr=[];
for(var i=0;i<arrCoord.length;i++) {
latlngStr = arrCoord[i].split(',');
console.log(latlngStr);
lat = parseInt(latlngStr[0].replace(".", ""));
console.log(lat);
lng = parseInt(latlngStr[1].replace(".", ""));
if (lat>maxlat){
maxlat=lat;
};
if (lng>maxlng){
maxlng=lng;
};
if (lat<minlat){
minlat=lat;
};
if (lng<maxlng){
minlng=lng;
};
};
//create new polygon with that path
var polygon = new google.maps.Polygon({
paths: polCoords,
strokeColor: '#FF0000',
strokeOpacity: 0.8,
strokeWeight: 2,
fillColor: '#FF0000',
fillOpacity: 0.35
});
//move from (minlan,minlng) every 100 horizontal until reach maxlan, then add 200 to lng and star again.
var coordinate;
var newlat="",newlng="";
for (var i=minlat;i<maxlat;i+=100){
for (var j=minlng;j<maxlng;j+=200){
//reconvert lat e lng from number to string
newlat=i.toString();
newlng=j.toString();
newlat=newlat.substring(0,newlat.length-6) + "." +newlat.substring(newlat.length-6,6);
newlng=newlng.substring(0,newlng.length-6) + "." +newlng.substring(newlng.length-6,6);
coordinate=newlat +"," + newlng;
//for every point find out if is inside the polygon
var isWithinPolygon = polygon.containsLatLng(parseFloat(newlat),parseFloat(newlng));
if(isWithinPolygon){
newgeocodeLatLng(function(addr){
if (arrAddress.length==0){arrAddress.push(addr);} else{
for (var i =0; i<arrAddress.length;i++){
var ok=0;
///if address (retrive only the street name) found from point is already in the array, don't put in it. i'm sure there is a better ay to do it....
if (arrAddress[i].split(',')[0]==addr.split(',')[0]){
ok=1;};
};
if(ok==0){arrAddress.push(addr);
};
};
},coordinate); //end newgeocodelatlng
}; //end if iswithpolygon
};//end for j
};//end for i
};
function newgeocodeLatLng(callback,mycoord) {
var address;
var latlngStr = mycoord.split(',');
getReverseGeocodingData(function(addr){
address=addr;
callback(address);
// console.log("address4=" + address);
},latlngStr[0], latlngStr[1]);
};
function getReverseGeocodingData(callback,lat, lng) {
var address="";
var latlng = new google.maps.LatLng(lat, lng);
// This is making the Geocode request
var geocoder = new google.maps.Geocoder();
geocoder.geocode({ 'latLng': latlng }, function (results, status) {
if (status !== google.maps.GeocoderStatus.OK) {
alert(status);
}
// This is checking to see if the Geoeode Status is OK before proceeding
if (status == google.maps.GeocoderStatus.OK) {
callback(results[0].formatted_address);
}
});
}