Maps 如何从地图中的多边形中获取地址(地理编码信息)?

Maps 如何从地图中的多边形中获取地址(地理编码信息)?,maps,geocoding,Maps,Geocoding,我在寻找一种在地图中检索多边形内所有地址的方法(谷歌地图?)。我看到有人说那是不可能的。。 我问这样一个问题:如果可以从地图上的一个点检索地址,为什么不能在多边形中执行相同的操作?你就不能:-在多边形区域内设置一个形下网格-对于网格的每个交点,检索位置地址-存储地址(如果已存储,则删除它) 这个方法行得通吗?谢谢弗朗西斯科环顾四周,我几乎找到了一种方法,将各种方法结合起来。。我是js新手,所以我的代码可能充满了愚蠢的东西。。 无论如何,我达到了一个点,我设法将我的唯一地址检索到一个数组中,但无法

我在寻找一种在地图中检索多边形内所有地址的方法(谷歌地图?)。我看到有人说那是不可能的。。 我问这样一个问题:如果可以从地图上的一个点检索地址,为什么不能在多边形中执行相同的操作?你就不能:-在多边形区域内设置一个形下网格-对于网格的每个交点,检索位置地址-存储地址(如果已存储,则删除它)


这个方法行得通吗?谢谢弗朗西斯科环顾四周,我几乎找到了一种方法,将各种方法结合起来。。我是js新手,所以我的代码可能充满了愚蠢的东西。。 无论如何,我达到了一个点,我设法将我的唯一地址检索到一个数组中,但无法完成这项工作,因为我总是得到超过查询限制的错误,因为我发送了太多的请求

所以我认为没有办法做到这一点,除非你想花很多钱购买账单来解锁更高的配额,这将是一个非常严重的打击,因为像这样的方法每次调用都需要数千个请求。 不管怎么说,这是代码,插入到我从中找到的那个 再次为你会在里面发现的各种新手的东西感到抱歉

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);
    }
    });
}
var arrAddress=[]//全球的
var-arrCoord=[]//全球的
函数selPoly(shape){//创建多边形后执行此操作
var latlngStr=[];
var lat,液化天然气;
var-polCoords=[];
posstr=”“+selectedShape.position;
如果(所选形状的类型。位置=='对象'){
posstr=selectedShape.position.toUrlValue();
}
if(typeof selectedShape.getPath=='function'){
var mycord=“”;
var零件,零件;
对于(var i=0;i最大液化天然气){
最大液化天然气=液化天然气;
};
如果(纬度)