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最大液化天然气){
最大液化天然气=液化天然气;
};
如果(纬度)