1

JTS を使用して、あるポリゴンに別のポリゴンが含まれているかどうかを確認しようとしています。

ここにリソースがあります。構文を利用するにはどうすればよいですか? これは私にエラーを与えています。次のステップは、contains を適用することです。誰かが 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、線で記述されています -LineRigまたはLineString(違いはこの質問の範囲外です)。
  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 に答える