核心思路是使用Region的求交集和并集的结果与原始Region对比,先看效果
Winform项目自带这个类库,如果使用控制台,需要先在nuget安装System.Drawing.Common
核心代码如下:
/// <summary>
/// 计算两个形状的关系
/// </summary>
/// <param name="rgn1">形状1</param>
/// <param name="rgn2">形状2</param>
/// <returns></returns>
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#计算不规则多边形关系
原文地址:https://blog.csdn.net/lwf3115841/article/details/127905491
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。