我收到此异常,不知道该怎么办。
我使用线性环创建了两个多边形。
然后,我尝试查找是否相交。
我得到这个异常:

com.vividsolutions.jts.geom.TopologyException:侧面位置冲突[(-1.7542192568359292E-100,1.7542192568359284E-100,0.0)]

这是stackTrace:

com.vividsolutions.jts.geom.TopologyException: side location conflict [ (-1.7542192568359292E-100, 1.7542192568359284E-100, 0.0) ]
    at com.vividsolutions.jts.geomgraph.EdgeEndStar.propagateSideLabels(EdgeEndStar.java:300)
    at com.vividsolutions.jts.geomgraph.EdgeEndStar.computeLabelling(EdgeEndStar.java:139)
    at com.vividsolutions.jts.operation.relate.RelateComputer.labelNodeEdges(RelateComputer.java:297)
    at com.vividsolutions.jts.operation.relate.RelateComputer.computeIM(RelateComputer.java:132)
    at com.vividsolutions.jts.operation.relate.RelateOp.getIntersectionMatrix(RelateOp.java:130)
    at com.vividsolutions.jts.operation.relate.RelateOp.relate(RelateOp.java:75)
    at com.vividsolutions.jts.geom.Geometry.relate(Geometry.java:1017)
    at com.vividsolutions.jts.geom.Geometry.intersects(Geometry.java:769)

在EdgeEndStar类中发生异常:
//Debug.print(rightLoc != currLoc, this);
          if (rightLoc != currLoc)
            throw new TopologyException("side location conflict", e.getCoordinate());
          if (leftLoc == Location.NONE) {
            Assert.shouldNeverReachHere("found single null side (at " + e.getCoordinate() + ")");
          }
          currLoc = leftLoc;

边缘不对的地方有座标:
  //coordinate: (-262.9001323617947, 313.3121772356619, 0.0)
    //coordinate: (-232.77552855071107, 332.43790711803985, 0.0)

请给我一个关于我的错误的想法。
我在Google上看到过几则帖子,但有相同的例外。有时候我确实会收到这个例外,有时候却不会。取决于 class 的图形形状:)

我在linearRing和Polygon上都调用了isValid()。这两个对象均有效。
System.out.println("=== === ===");
        LinearRing linearRing = geometryFactory.createLinearRing(coordinates.toArray(new Coordinate[coordinates.size()]));
        IsValidOp isValidOp  = new IsValidOp(linearRing);
        System.out.println("LinearRing: closed?" + linearRing.isClosed() + " valid?" + linearRing.isValid() + " isValidOp.isValid(); " + isValidOp.isValid());


        Polygon polygon =geometryFactory.createPolygon(linearRing, null);
        isValidOp  = new IsValidOp(polygon);
        System.out.println("Polygon valid? " + polygon.isValid() +" isValidOp" + isValidOp.isValid());
        return new BaseGeometry(polygon);

我不知道我该怎么做。

最佳答案

  • 将jts从1.12
  • 更新到1.13
  • 将getools从9.0
  • 更新为10-快照

    然后验证操作返回false。
    Description说,某些位置的点太近了,地质工具认为线性环相交。
    我将点后的coodinates截断为5位,这很有帮助。精度太高。

    问题已经解决了。

    10-04 12:59