核心思路是使用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 "相交"; //两个都只占并集的一部分,则为相交
}
}
源码:
附件