javaalgorithmgeometrypathgeometry

Algorithm to split self-intersected Path2D into several not self-intersected paths?


I need to get rid of self-intersections in a shape. Shape is constructed from an array of points, so all segments of that shape are lines. (only lines, no curves and arcs)

Previously, I tried to create Path2D from that points, construct an Area from it, and then using its PathIterator I created several Path2Ds, which somehow were subpaths of previous path, and so self-intersetions were gone. But this isn't working for some paths - self-intersections still remain there.

So could you point me to some place where I can find good algorithm to do similar thing?

Edit: I haven't found anything useful anywhere, so I written my own algorithm. See the answers.


Solution

  • If Area is not working for you, you could try using a GLUtessellator to decompose your Shape into a set of triangles, or (using the GL_LINE_LOOP option) just the boundary edges.