1

我正在尝试使用 JTS 来判断一个多边形是否包含另一个多边形。

我这里有资源。如何使用语法?这给了我错误。下一步是应用包含。如果有人对 JTS 有经验,那将很有帮助。

https://gis.stackexchange.com/questions/368520/jts-geometry-contains-not-detecting-point-of-an-inner-polygon-on-edge-of-outer

https://gis.stackexchange.com/questions/262751/how-to-determine-if-one-polygon-is-contained-in-another

https://locationtech.github.io/jts/javadoc/org/locationtech/jts/geom/Polygon.html

Polygon item1 = ((0 0, 1000 0, 1000 1000, 0 1000, 0 0))
Polygon item2 = ((500 500, 1000 500, 600 600, 500 600, 500 500))

在此处输入图像描述

在此处输入图像描述

4

1 回答 1

1

你不能像那样创建一个多边形。JTS 是一个相当沉重的框架,所以你需要走完整的路线。

  1. 一切都从GeometryFactorydocs开始。它负责创建所有几何图形,这是必要的,因为它考虑了一些事情PrecisionModel,例如。
  2. 您需要了解几何的层次结构,Polygon由一条线描述 -LineRigLineString(差异超出了此问题的范围)。
  3. 您需要意识到每条线都由点组成,可以用Point或来描述Coordinate。所以如果你想创建一个Polygon

代码如下所示:

 GeometryFactory factory = new GeometryFactory(); //default
 Coordinate[] coordinates1 = {
        new CoordinateXY(0,0),
        new CoordinateXY(1000,0),
        new CoordinateXY(1000, 1000),
        new CoordinateXY(0, 1000),
        new CoordinateXY(0, 0)
 };
 Coordinate[] coordinates2 = {
        new CoordinateXY(500,500),
        new CoordinateXY(1000,500),
        new CoordinateXY(600, 600),
        new CoordinateXY(500, 600),
        new CoordinateXY(500, 500)
 };
 LinearRing linearRing1 = factory.createLinearRing(coordinates1);
 LinearRing linearRing2 = factory.createLinearRing(coordinates2);
 Polygon polygon1 = factory.createPolygon(linearRing1);
 Polygon polygon2 = factory.createPolygon(linearRing2);
 assertTrue(polygon1.contains(polygon2));
于 2021-03-24T14:40:47.970 回答