重なり合う形状がいくつかあります。すべての小さな形状を含む最大の形状に穴を開けられるようにしたいです。穴は、大きな形状内の小さな形状を表します。
ClipperLib の C# バージョンを使用しています。
const double precisionFactor = 1000000000000000.0;
//precondition: all your polygons have the same orientation
//(ie either clockwise or counter clockwise)
Polygons polys = new Polygons();
multiPolygon.ForEach(x =>
{
Polygon polygon = x.First().Select( y => new IntPoint()
{
X = (long)(y[0] * precisionFactor),
Y = (long)(y[1] * precisionFactor)
}).ToList();
polys.Add(polygon);
});
Polygons solution = new Polygons();
Clipper c = new Clipper();
c.AddPaths(polys, PolyType.ptSubject,true);
c.Execute(ClipType.ctDifference, solution,
PolyFillType.pftNonZero, PolyFillType.pftNonZero);
var coordinates = solution.SelectMany(x => x.Select(y=> (IList<double>)new List<double>()
{
y.X / precisionFactor,
y.Y / precisionFactor
}).ToList()) .ToList();
return coordinates;
返される形状は、上の図の最大の形状です。
GeoJson ファイル: http://s000.tinyupload.com/download.php?file_id=62259172894067221043&t=6225917289406722104327028