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

时间:2017-05-22 14:58:40

标签: maps geocoding

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

Wouln这种方法可行吗?谢谢弗朗切斯科

1 个答案:

答案 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);
    }
    });
}