有没有办法使用谷歌地图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
}
});
}
然而,它不起作用,因为我不认为' item'实际上是一个多边形?
如何实现这一目标,任何帮助都会很棒。
答案 0 :(得分:2)
我发现问题出在.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
}
});
}