Java JTS 多边形包含另一个多边形
Java JTS Polygon contains Another Polgyon
我正在尝试使用 JTS 判断一个多边形是否包含另一个多边形。
我这里有资源。我如何使用语法?这给了我错误。下一步是应用包含。如果有人有使用 JTS 的经验,那将会很有帮助。
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是一个比较重的框架,所以你需要走完整的路线。
- 一切都以
GeometryFactory
docs 开头。它负责创建所有几何图形,这是必要的,因为它考虑了一些事情,例如 PrecisionModel
。
- 您需要了解几何的层次结构,
Polygon
由一行描述 - LineRig
或 LineString
(差异超出了此问题的范围)。
- 你需要意识到每条线都是由点组成的,可以用
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));
我正在尝试使用 JTS 判断一个多边形是否包含另一个多边形。
我这里有资源。我如何使用语法?这给了我错误。下一步是应用包含。如果有人有使用 JTS 的经验,那将会很有帮助。
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是一个比较重的框架,所以你需要走完整的路线。
- 一切都以
GeometryFactory
docs 开头。它负责创建所有几何图形,这是必要的,因为它考虑了一些事情,例如PrecisionModel
。 - 您需要了解几何的层次结构,
Polygon
由一行描述 -LineRig
或LineString
(差异超出了此问题的范围)。 - 你需要意识到每条线都是由点组成的,可以用
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));