一般的答案是您需要将google.maps.Polygon对象转换为jsts.geom.Geometry对象,然后运行联合。如果要在Google Maps JavaScript API v3地图上显示结果,则需要将返回的jsts.geom.Geometry对象转换回google.maps.Polygon。
此代码(来自this question)转换的路径成jstsPolygon:
var coordinates = googleMaps2JTS(googlePolygonPath);
var geometryFactory = new jsts.geom.GeometryFactory();
var shell = geometryFactory.createLinearRing(coordinates);
var jstsPolygon = geometryFactory.createPolygon(shell);
像这样:
var geometryFactory = new jsts.geom.GeometryFactory();
var trito = bermudaTriangle.getPath();
var tritoCoor = googleMaps2JTS(trito);
var shell = geometryFactory.createLinearRing(tritoCoor);
var trito2 = secondBermuda.getPath();
var tritoCoor2 = googleMaps2JTS(trito2);
var shell2 = geometryFactory.createLinearRing(tritoCoor2);
var jstsPolygon = geometryFactory.createPolygon(shell);
var jstsPolygon2 = geometryFactory.createPolygon(shell2);
var intersection = jstsPolygon.intersection(jstsPolygon2);
jsfiddle
要使用computeArea方法的结果,虽然,您需要将其转换回数组或MVCrray的google.maps.LatLng对象(computeArea(path:Array.|MVCArray., radius?:number))
或者您可以使用[jsts.geom.Polygon.getArea](http://bjornharrtell.github.io/jsts/doc/api/symbols/jsts.geom.Polygon.html#getArea)方法。
working fiddle使用jsts方法的三角形,联合和交叉区域。
代码的结果转换回google.maps.LatLng和google.maps.Polygon对象:
var jsts2googleMaps = function (geometry) {
var coordArray = geometry.getCoordinates();
GMcoords = [];
for (var i = 0; i < coordArray.length; i++) {
GMcoords.push(new google.maps.LatLng(coordArray[i].x, coordArray[i].y));
}
return GMcoords;
}
var intersectionGMArray = jsts2googleMaps(intersection);
然后拿到区:
var intersectionGMarea = google.maps.geometry.spherical.computeArea(intersectionGMArray);
working fiddle
我得到2你的小提琴JavaScript错误'未捕获的ReferenceError:JavaScript未定义'和'未捕获的TypeError:未定义不是函数'。我会说你缺少jsts所需的外部JavaScript库。也许[这一个](http://bjornharrtell.github.io/jsts/lib/javascript.util.js)。更改包含的顺序[修复](http://jsfiddle.net/cbs2h59e/7/) – geocodezip 2014-09-25 12:57:57
jsts库不会将联合方法添加到Google Maps Polygon类。 – geocodezip 2014-09-25 13:04:12
这个问题的答案[Google Maps Polygons自相交检测](http://stackoverflow.com/questions/25017463/google-maps-polygons-self-intersecting-detection/25019306#25019306)可能是相关的。 – geocodezip 2014-09-25 13:06:11