有没有办法使用 google 地图 v3 循环遍历多多边形特征以提取每个子多边形,然后使用 containsLocation(( 找出子多边形内的位置是否与我存储的拉特和长坐标匹配?
我希望能够使用这样的循环:
//check if multipolygon
if(e.feature.getGeometry().getType()==='MultiPolygon'){
//loop over sub polygons
var polygons = e.feature.getGeometry().getArray();
polygons.foreach(function(item, index){
//item is our polygon?
var coords = item.getAt(index).getArray();
var poly = new google.maps.Polygon({
paths: coords,
});
//check if the subpolygon contains my latlong
if(google.maps.geometry.poly.containsLocation(myLatLong, poly)){
// do something
}
});
}
但是,它不起作用,因为我认为"项目"实际上不是多边形?
任何帮助都会对我如何实现这一目标有很大帮助。
我发现问题出在.getAt(i(上,它必须是.getAt(0(
if (e.feature.getGeometry().getType() === 'MultiPolygon' ) {
var array = e.feature.getGeometry().getArray();
array.forEach(function(item,i){
var coords= item.getAt(0).getArray();
var poly = new google.maps.Polygon({
paths: coords
});
if (google.maps.geometry.poly.containsLocation(location, poly)) {
//do something
}
});
}