Java JTS 多边形包含另一个多边形

Java JTS Polygon contains Another Polgyon

我正在尝试使用 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))

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

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