网站建设资讯

NEWS

网站建设资讯

C# 计算不规则多边形的相交/包含等关系

核心思路是使用Region的求交集和并集的结果与原始Region对比

10年积累的网站设计、做网站经验,可以快速应对客户对网站的新想法和需求。提供各种问题对应的解决方案。让选择我们的客户得到更好、更有力的网络服务。我虽然不认识你,你也不认识我。但先建设网站后付款的网站建设流程,更有从江免费网站建设让你可以放心的选择与我们合作。

Winform项目自带这个类库,如果使用控制台,需要先在nuget安装System.Drawing.Common

        /// 
        /// 计算两个形状的关系
        /// 
        /// 形状1
        /// 形状2
        /// 
        private string CalculateShapeRelationship(Region rgn1, Region rgn2)
        {
            RectangleF[] rect1 = rgn1.GetRegionScans(new Matrix());  //将形状切片
            RectangleF[] rect2 = rgn2.GetRegionScans(new Matrix());
            if (Enumerable.SequenceEqual(rect1, rect2))  //如果两个形状切片结果相同,则为重叠
                return "重叠";

            using (Region rgnIntersect = rgn1.Clone())
            {
                rgnIntersect.Intersect(rgn2);  //求交集
                RectangleF[] rectIntersect = rgnIntersect.GetRegionScans(new Matrix());//将交集切片
                if (rectIntersect.Length == 0)  //如果交集切片没有结果则两个形状没有交集
                    return "相离";
            }
            using (Region rgnUnion = rgn1.Clone())
            {
                rgnUnion.Union(rgn2);  //求并集
                RectangleF[] rectUnion = rgnUnion.GetRegionScans(new Matrix()); //将并集切片

                if (rectUnion.Length == rect1.Length)  //如果区域1和并集一样
                    return "区域1包含区域2";

                if (rectUnion.Length == rect2.Length)  //如果区域2和并集一样
                    return "区域2包含区域1";

                return "相交";  //两个都只占并集的一部分,则为相交
            }
        }

源码:
附件


文章名称:C# 计算不规则多边形的相交/包含等关系
标题路径:http://njwzjz.com/article/dsopddj.html