我正在尝试使用 JTS 库检查 Multipolygon 是否与列表中的哪个 Polygon 相交。但是,该方法陷入无限循环并以堆空间不足错误结束。
该方法适用于显然不相交的对。当可能相交的第一对出现时,无限循环开始。
以下是两个有问题的 Geometry 对象的坐标序列,(GeoJson 格式):
编辑 1 - 添加代码:
多面体:
[ [ [ [ 24.899993263111575, 60.168590212519007, 0.0 ], [ 24.8921845577913, 60.170930189360085, 0.0 ], [ 24.906727352467691, 60.177129472862902, 0.0 ], [ 24.912750145776748, 60.178210672366426, 0.0 ], [ 24.915824674917332, 60.1759297188066, 0.0 ], [ 24.916581969097017, 60.175298383750082, 0.0 ], [ 24.921993683436096, 60.17592332951083, 0.0 ], [ 24.924298430649159, 60.176277074203171, 0.0 ], [ 24.925777801589089, 60.176578177900481, 0.0 ], [ 24.927069958749666, 60.176812746915481, 0.0 ], [ 24.934606301659603, 60.17770118209701, 0.0 ], [ 24.93829154797028, 60.17943631088842, 0.0 ], [ 24.943101975190991, 60.179746422785151, 0.0 ], [ 24.946157646983945, 60.177893553297686, 0.0 ], [ 24.949063929828164, 60.176872818864446, 0.0 ], [ 24.948884500413151, 60.176763003129317, 0.0 ], [ 24.947435273641268, 60.175810147107796, 0.0 ], [ 24.947645652172458, 60.174545608314318, 0.0 ], [ 24.953922745030216, 60.17465838879788, 0.0 ], [ 24.952114223411215, 60.172614801031834, 0.0 ], [ 24.952535692362105, 60.169038476544031, 0.0 ], [ 24.954301749734213, 60.168843140472724, 0.0 ], [ 24.954352635736257, 60.167875977512914, 0.0 ], [ 24.954382959437606, 60.167722794336058, 0.0 ], [ 24.94618172965189, 60.167514740158367, 0.0 ], [ 24.94537429422477, 60.167437294026875, 0.0 ], [ 24.946805477127789, 60.166445009469363, 0.0 ], [ 24.946239227186837, 60.166289851133151, 0.0 ], [ 24.94605715808019, 60.166369202625063, 0.0 ], [ 24.944895457595461, 60.165955522827154, 0.0 ], [ 24.943796685615666, 60.166732851647168, 0.0 ], [ 24.943804264808218, 60.16695638982231, 0.0 ], [ 24.94339656134855, 60.167013101789991, 0.0 ], [ 24.943005307041311, 60.1672873863494, 0.0 ], [ 24.942815762910648, 60.167233708186423, 0.0 ], [ 24.942650545385295, 60.167130925185603, 0.0 ], [ 24.9407231754085, 60.166436365685314, 0.0 ], [ 24.940722537913366, 60.166342333123318, 0.0 ], [ 24.940730039071539, 60.166232085046666, 0.0 ], [ 24.94054008676806, 60.166146432407373, 0.0 ], [ 24.940689883918264, 60.166032286309964, 0.0 ], [ 24.938850589801866, 60.165384512580708, 0.0 ], [ 24.938374768557253, 60.165445980685028, 0.0 ], [ 24.938302460409481, 60.165202578885371, 0.0 ], [ 24.937168766625486, 60.1648185467416, 0.0 ], [ 24.936325303890971, 60.164523435250963, 0.0 ], [ 24.935515249176746, 60.165055276075314, 0.0 ], [ 24.935162131372266, 60.165067012171299, 0.0 ], [ 24.935243484405692, 60.165243301611966, 0.0 ], [ 24.934771879418953, 60.165604942333808, 0.0 ], [ 24.935697179525107, 60.165921540021522, 0.0 ], [ 24.935678441330882, 60.16607022900051, 0.0 ], [ 24.93562630412751, 60.166223958343842, 0.0 ], [ 24.93432941740414, 60.16639906762866, 0.0 ], [ 24.934086151809726, 60.16643747924013, 0.0 ], [ 24.933996000970303, 60.166879775928571, 0.0 ], [ 24.933494220741714, 60.166503500060202, 0.0 ], [ 24.930639585658206, 60.166879026400828, 0.0 ], [ 24.930477360716871, 60.167021165775722, 0.0 ], [ 24.93012338167825, 60.166940112911924, 0.0 ], [ 24.926990522351048, 60.167324416451343, 0.0 ], [ 24.926831203850465, 60.167593482122442, 0.0 ], [ 24.92584998697993, 60.167800919963199, 0.0 ], [ 24.925440947757817, 60.167842026167428, 0.0 ], [ 24.925464402293027, 60.167636210840456, 0.0 ], [ 24.925057233085131, 60.167426343568081, 0.0 ], [ 24.924638431368617, 60.167314445885701, 0.0 ], [ 24.924653932101634, 60.166777681068048, 0.0 ], [ 24.924239526771945, 60.166656330235163, 0.0 ], [ 24.923909713383374, 60.166769702593491, 0.0 ], [ 24.919742746576386, 60.166669946668634, 0.0 ], [ 24.919486254229472, 60.168947489628216, 0.0 ], [ 24.917865586081348, 60.169052961010145, 0.0 ], [ 24.913389466202162, 60.169206955531649, 0.0 ], [ 24.908339577064975, 60.169298848862468, 0.0 ], [ 24.899993263111575, 60.168590212519007, 0.0 ] ], [ [ 24.936135087425775, 60.173864750028308, 0.0 ], [ 24.935822882124054, 60.173818038029538, 0.0 ], [ 24.935698898369246, 60.173449814747812, 0.0 ], [ 24.935042425364173, 60.172863964505616, 0.0 ], [ 24.934700282784398, 60.172293513337216, 0.0 ], [ 24.934235985164971, 60.171993255866646, 0.0 ], [ 24.93458616422809, 60.171768472366658, 0.0 ], [ 24.935119957047309, 60.171965193243153, 0.0 ], [ 24.935650390363076, 60.171879257705569, 0.0 ], [ 24.936025502093653, 60.171926942487744, 0.0 ], [ 24.936234782914752, 60.171605759312015, 0.0 ], [ 24.937662268667879, 60.172287296440999, 0.0 ], [ 24.936135087425775, 60.173864750028308, 0.0 ] ] ] ]
多边形:
[ [ [ 24.94068318546399, 60.17336319841633 ], [ 24.93618043398334, 60.17329314372988 ], [ 24.936039655930326, 60.17553644290522 ], [ 24.940542714024545, 60.17560650391693 ], [ 24.94068318546399, 60.17336319841633 ] ] ]
这是用于生成多边形的代码:
public Polygon toPolygonJTS(GeometryFactory factory,
LinearRing polygonRingHolder, ArrayList<LinearRing> holeHolder,
ArrayList<Coordinate> coordinateHolder) {
if (!this.jtsDrawn) {
boolean isHole = false;
// list of points stored in array list
for (ArrayList<ArrayList<Double>> linearRing : this.geometry
.getCoordinates()) {
for (ArrayList<Double> point : linearRing) {
// add the point to array
coordinateHolder.add(new Coordinate(point.get(0), point
.get(1)));
}
if (!isHole) {
// create a LinearRing for the polygon
polygonRingHolder = new LinearRing(
new CoordinateArraySequence(
coordinateHolder
.toArray(new Coordinate[coordinateHolder
.size()])), factory);
} else {
// add LinearRing to a list of polygons specifying holes
holeHolder.add(new LinearRing(new CoordinateArraySequence(
coordinateHolder
.toArray(new Coordinate[coordinateHolder
.size()])), factory));
}
// clear coordinate holder for the next loop
coordinateHolder.clear();
}
// create a polygon and store in object property
this.polygon = new Polygon(polygonRingHolder,
holeHolder.toArray(new LinearRing[holeHolder.size()]),
factory);
}
return this.polygon;
}
对于多多边形:
public MultiPolygon toMultiPolygonJTS(GeometryFactory factory,
ArrayList<Polygon> polygonList, LinearRing polygonRingHolder,
ArrayList<LinearRing> holeHolder,
ArrayList<Coordinate> coordinateHolder) {
if (!this.jtsDrawn) {
boolean isHole = false;
for (ArrayList<ArrayList<ArrayList<Double>>> polygon : this.geometry.coordinates) {
for (ArrayList<ArrayList<Double>> linearRing : polygon) {
for (ArrayList<Double> point : linearRing) {
coordinateHolder.add(new Coordinate(new Coordinate(((Double) (point.get(0) * 100000)).intValue(), ((Double) (point
.get(1) * 100000)).intValue())));
}
if (!isHole) {
polygonRingHolder = new LinearRing(
new CoordinateArraySequence(
coordinateHolder
.toArray(new Coordinate[coordinateHolder
.size()])), factory);
} else {
holeHolder
.add(new LinearRing(
new CoordinateArraySequence(
coordinateHolder
.toArray(new Coordinate[coordinateHolder
.size()])),
factory));
}
coordinateHolder.clear();
}
// create a polygon and add to a list
polygonList.add(new Polygon(polygonRingHolder, holeHolder
.toArray(new LinearRing[holeHolder.size()]), factory));
}
// create multipolygon from list of polygon, and store in object
this.multiPolygon = new MultiPolygon(
polygonList.toArray(new Polygon[polygonList.size()]),
factory);
}
return this.multiPolygon;
}
检查两个几何图形是否相交:
public boolean collidesJTS(MapSquarePolygonFeature mapsquare, GeometryFactory factory,
ArrayList<Polygon> polygonList, LinearRing polygonRingHolder,
ArrayList<LinearRing> holeHolder,
ArrayList<Coordinate> coordinateHolder) {
return this.multiPolygon.intersects(mapsquare.toPolygonJTS(factory, polygonRingHolder, holeHolder, coordinateHolder));
}
编辑 2:如果我从两个几何创建距离,代码运行良好,例如将多边形的 x 和 y 乘以 10。