Hi Edgar,
Thanks for your help but I have one case where there is a problem.
If I cut the polygon on the one single side,
data:image/s3,"s3://crabby-images/afacd/afacddaa5544f99f4e57e53ed7be61459d9c36f9" alt=""
I have this result
data:image/s3,"s3://crabby-images/152bc/152bcca5f97981fd056babdf4c7165a7865c6908" alt=""
data:image/s3,"s3://crabby-images/537c6/537c6c2b6d9ac90dac4c0cf47b3aa99a2a089001" alt=""
The result is 2 equals polygons.
So I did some modifications in the class splitter
public static MultipolygonShape Split(PolygonShape processedPolygon, LineShape lineShape)
{
MultipolygonShape resultShape = new MultipolygonShape();
MultipointShape intersectionMultiPoint = lineShape.GetCrossing(processedPolygon.OuterRing);
if (intersectionMultiPoint.Points.Count == 2)
{
PolygonShape polygonShape1 = GetPolygonForSplit(processedPolygon, lineShape, false);
PolygonShape polygonShape2 = GetPolygonForSplit(processedPolygon, lineShape, true);
if (polygonShape1.IsWithin(polygonShape2))
{
polygonShape2 = processedPolygon.OuterRing.GetDifference(polygonShape1).Polygons[0];
foreach (RingShape ii in processedPolygon.InnerRings)
{
polygonShape2.InnerRings.Add(ii);
}
}
.....
}
So I changed too the SplitRing Method because I believed that the problem came because we did not use the intersection point in the creation of the new polygon (intersectionPointShape2)
public static RingShape SplitRing(RingShape processedRing, Collection<PointShape> intersectionPointShapes)
{
RingShape resultRingShape = new RingShape();
PointShape intersectionPointShape1 = intersectionPointShapes[0];
PointShape intersectionPointShape2 = intersectionPointShapes[intersectionPointShapes.Count - 1];
int i = 0;
int totalPointNumber = processedRing.Vertices.Count;
while (i < totalPointNumber - 1)
{
int indexA = i + 1;
if (DoesPointShapeBelongToLineSegment(intersectionPointShape1, new PointShape(processedRing.Vertices), new PointShape(processedRing.Vertices[indexA])))
{
resultRingShape.Vertices.Add(new Vertex(intersectionPointShape1));
if (DoesPointShapeBelongToLineSegment(intersectionPointShape2, new PointShape(processedRing.Vertices), new PointShape(processedRing.Vertices[indexA])))
{
resultRingShape.Vertices.Add(new Vertex(intersectionPointShape2));
for (int shapeIndex = intersectionPointShapes.Count - 2; shapeIndex > 0; shapeIndex--)
{ resultRingShape.Vertices.Add(new Vertex(intersectionPointShapes[shapeIndex])); }
resultRingShape.Vertices.Add(new Vertex(intersectionPointShape1));
...
}
But I still have the problem ;-( and sometimes the new polygon is not correct (form butterfly .....)
data:image/s3,"s3://crabby-images/14e51/14e5132a8676daf8a9a429de48cd33f840426b3b" alt=""
But the other polygon is correct
data:image/s3,"s3://crabby-images/f462d/f462d3b7c9e8f28843d46dae0fb776852a74307f" alt=""
So I don't understand why the GetDifference function gives this result .. ?
May be it's not necessary to use the GetDifference function to solve the problem of cutting of a polygon on a single side ?
Thanks a lots for your help.
Regards.
Stéphanie.