循环多多边形功能google maps api v 3

时间:2017-08-10 20:18:31

标签: javascript jquery arrays google-maps google-maps-api-3

有没有办法使用谷歌地图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'实际上是一个多边形?

如何实现这一目标,任何帮助都会很棒。

1 个答案:

答案 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

            }

          });
        }