0

我正在尝试合并一个多面体,但效果不佳,如下图所示:

在此处输入图像描述

我正在使用的代码是:

using ClipperLib;
using Polygon = System.Collections.Generic.List<ClipperLib.IntPoint>;
using Polygons = System.Collections.Generic.List<System.Collections.Generic.List<ClipperLib.IntPoint>>;

namespace Ylp.ComputationalGeometry
{
    public static class Merge
    {
        public static IList<IList<double>> Multipolygon(IList<IList<IList<IList<double>>>> multiPolygon)
        {
            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.ctUnion, 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;
        }
    }
}

我真正希望联合的 oucome 看起来像下面这样,所以中间的任何交叉点都应该被忽略,并且应该创建一个覆盖两个形状的区域:

在此处输入图像描述

原来的形状是: 在此处输入图像描述

4

0 回答 0