移动碰撞法 ——套料排版算法——CAD c#

套料排版算法中,关键的一步是碰撞检测,当两个多边形碰撞时停止继续移动,进行下一个轨迹运动。

给定两个多边形,固定其中一个,让另一个多边形围绕它作不旋转的刚体运动。在运动过程中,始终保证两个多边形边界上至少有一点互相靠接,且不重叠。这就使得参考点只能在固定多边形的某一侧特定区域内运动。

例如,在二维排料场景中,为了判断待排料工件与已排料工件是否相交,会计算待排料工件相对于已排料工件的临界多边形。待排料工件只能在已排料工件的外部边缘滑动,其参考点形成的临界多边形也就只会在已排料工件的外侧,不会在其内部或两侧同时出现偏移。

移动碰撞法:首先根据多边形 A 和 B 当前时刻的靠接状态,得到 B 下一步的移动方向,计算出 A 和 B 之间的最小碰撞距离,从而得到移动距离,将 B 移动到新的位置,重复以上过程。

目前移动碰撞(基于CAD C#)算法实现的效果如下:

目前实现的效果:分别让B从A的右、上、左、下四个方向进行碰撞检测,当碰撞时停下,继续下一个轨迹。

局部代码如下:

复制代码
 public void 两个零件排版4方向()
 {
     Database db = HostApplicationServices.WorkingDatabase;
     Editor ed = Application.DocumentManager.MdiActiveDocument.Editor;

     // 选择两个零件曲线
     var curveA = db.SelectCurve("\n请选择零件(A):");
     if (curveA == null) return;

     var curveB = db.SelectCurve("\n请选择零件(B):");
     if (curveB == null) return;

     // 排版方向参数(0=右, 1=上, 2=左, 3=下)
     int direction = 0; // 默认从右侧开始排版,逆时针一周
     bool allDirections = true; // 是否执行所有方向的排版

     Timing tt = new Timing();//开始计时
     Flash flashBHorizontal = null; // 瞬态显示对象

//**********省略部分代码
 }

算法需求联系↓↓↓(不免费)

相关推荐
_OP_CHEN1 分钟前
【算法基础篇】(五十九)巴什博弈 (Bash Game) 超详解:从原理到实战,搞定经典取石子问题
算法·蓝桥杯·c/c++·博弈论·算法竞赛·acm/icpc·bash博弈
颜酱10 小时前
图结构完全解析:从基础概念到遍历实现
javascript·后端·算法
m0_7369191010 小时前
C++代码风格检查工具
开发语言·c++·算法
yugi98783810 小时前
基于MATLAB强化学习的单智能体与多智能体路径规划算法
算法·matlab
DuHz11 小时前
超宽带脉冲无线电(Ultra Wideband Impulse Radio, UWB)简介
论文阅读·算法·汽车·信息与通信·信号处理
Polaris北极星少女11 小时前
TRSV优化2
算法
代码游侠12 小时前
C语言核心概念复习——网络协议与TCP/IP
linux·运维·服务器·网络·算法
2301_7634724612 小时前
C++20概念(Concepts)入门指南
开发语言·c++·算法
abluckyboy13 小时前
Java 实现求 n 的 n^n 次方的最后一位数字
java·python·算法
园小异13 小时前
2026年技术面试完全指南:从算法到系统设计的实战突破
算法·面试·职场和发展