寻找多边形中心谷歌地图API 3

时间:2018-10-17 08:04:10

标签: google-maps google-maps-api-3 polygon

我想在Google地图中找到多边形的中心,我尝试了几种解决方案,但是对于直角三角形多边形,它们都无法正常工作,这是示例代码:

var path = new Array(new google.maps.LatLng(1, 1), new google.maps.LatLng(1, 10), new google.maps.LatLng(10, 10), new google.maps.LatLng(1, 1));

var mapOptions = {
    zoom: 4,
    center: new google.maps.LatLng(40, 9),
    mapTypeId: google.maps.MapTypeId.ROADMAP
};

var map = new google.maps.Map(document.getElementById("map-canvas"), mapOptions);

var polygon = new google.maps.Polygon({
    path: path,
    map: map
});

var bounds = new google.maps.LatLngBounds();

for (var i=0; i<polygon.getPath().length; i++) {

    var point = new google.maps.LatLng(path[i].lat(), path[i].lng());
    bounds.extend(point);
}

map.fitBounds(bounds);
    const marker = new google.maps.Marker({
  position: {
    lat: bounds.getCenter().lat(),
    lng: bounds.getCenter().lng()
  },
  map: this.map,
  title: "Hello World!"
});
marker.setMap(map);

我使用google.maps.LatLngBounds();查找三角形的中心,并在地图上标记了中心,但是结果中心实际上不是三角形的真实中心jsfiddle example of this code
我使用了另一种解决方案which is discussed here来查找多边形的中心,但是该方法也不起作用,所以还有其他解决方案可以找到多边形的准确中心,而与多边形类型无关吗?

1 个答案:

答案 0 :(得分:0)

points是多边形点的数组,调用getCenter以获取中心坐标。

var points = [[1,1],[1,10],[10,10]];
function getCenter(){
    var sumX = 0, sumY = 0;
    for(var i = 0; i < points.length; i++){
        var point = points[i];
        var x = point[0];
        var y = point[1];
        sumX += x;
        sumY += y;
    }
    return {x:sumX / points.length,y:sumY / points.length};
}

var centerOfPoints = getCenter();