C# 计算不规则多边形的相交/包含等关系
2023-03-31 10:56:29 时间
核心思路是使用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 "相交"; //两个都只占并集的一部分,则为相交
}
}
源码:
附件
相关文章
- Linux fd 系列 — socket fd 是什么?
- 万万没想到!TCP/IP 协议会有这么多漏洞
- HarmonyOS基础技术赋能之分布式数据服务功能
- HarmonyOS自定义控件之速度检测VelocityDetector
- HarmonyOS服务卡片开发知识总结
- Firefox 91 支持用户一键清除指定或全部网站的 Cookie
- HarmonyOS小游戏:吃豆豆---基于分布式数据库与分布式任务调度
- Windows 10/11 福利:微软为所有安卓手机带来 Windows 剪贴板同步功能
- 就很凸然,电脑里多出了一个文件···
- HarmonyOS 分布式亲子教育
- 十大面向Windows的免费数据恢复工具
- Windows 7还能升级Windows 11吗?微软披露Windows11升级细节
- 从模型复杂度角度来理解过拟合现象
- 拉格朗日乘数法,一种计算条件极值的方式
- elasticsearch高亮之highlight原理
- elasticsearch查询之大数据集分页查询
- elasticsearch之多索引查询
- 如何使用注解优雅的记录操作日志 | 萌新写开源 01
- elasticsearch支持大table格式数据的搜索
- 解析fiddler返回的部分数据。