2014-09-25 61 views
3

我正在计算两个三角形之间的交点的面积。 我发现JSTS Topology Suite有一个Geometry class其中一种方法intersection()。 我试过JSFiddle和我的本地计算机,但我得到了Uncaught TypeError: undefined is not a function。 JSTS还有一个example。在这里你可以看到代码。 我的代码看起来的jsfiddle相同:如何使用JSTS Library计算Google Maps API中的交叉区域?

var union = triangleCoords.union(secondTriangleCoords); 
var intersection = triangleCoords.intersection(secondTriangleCoords); 
console.log('Intersection ' + intersection); 
google.maps.geometry.spherical.computeArea(intersection); 

有,我应该也做了转换?

+0

我得到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

+1

jsts库不会将联合方法添加到Google Maps Polygon类。 – geocodezip 2014-09-25 13:04:12

+0

这个问题的答案[Google Maps Polygons自相交检测](http://stackoverflow.com/questions/25017463/google-maps-polygons-self-intersecting-detection/25019306#25019306)可能是相关的。 – geocodezip 2014-09-25 13:06:11

回答

6

一般的答案是您需要将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

+1

发现问题,我创建了JSTS coordinates数组,但没有将它传递给LinearRing构造函数,JSTS库不满意它所期望的jsts.geom.Coordinate对象的google.maps.LatLng对象... – geocodezip 2014-09-26 03:23:19

+0

添加了用于将生成的jsts多边形转换回来的代码google.maps对象。 – geocodezip 2014-09-26 04:49:32

+0

非常感谢!这很棒!但是我仍然没有从JSTS获得[Area Method](http://bjornharrtell.github.io/jsts/doc/api/symbols/jsts.geom.Polygon.html#getArea),它返回什么?在文档中只提到'返回这个Polygon的区域'。 你可以请合并[与这个问题](http://stackoverflow.com/questions/24504068/how-to-show-the-intersecting-area-of-two-polygons-on-google-maps),我认为他们是相同的 谢谢 – xmux 2014-09-26 07:46:17

相关问题