




本文详解如何正确实现轴对齐矩形(aabb)碰撞检测,指出原代码中坐标逻辑错误、边界判断冗余及条件反转等问题,并提供可运行的修复方案与可视化验证示例。
在 2D 游戏或图形引擎开发中,矩形碰撞检测(即 AABB,Axis-Aligned Bounding Box)是最基础也最易出错的物理交互模块。你提供的 isCollide 函数存在多处关键逻辑缺陷,导致始终无法正确判定碰撞:
function isCollide(y, x, w, h, x2, y2, w2, h2) {
return !(
((y + h) < (y2)) || // ✅ 上方无交叠(但 y 轴方向定义需统一!)
(y > (y2 + h2)) || // ✅ 下方无交叠
((x + w) < x2) || // ✅ 左侧无交叠
(x2 > (x2 + w2)) // ❌ 永真式!应为 x > (x2 + w2) —— 这是严重笔误
);
}两个矩形发生碰撞 ⇔ 在 X 轴和 Y 轴上同时重叠。
即:
合并为单行布尔表达式(无需取反,语义清晰):
function collides(rect1, rect2) {
return (
rect1.x < rect2.x + rect2.w &&
rect2.x < rect1.x + rect1.w &&
rect1.y < rect2.y + rect2.h &&
rect2.y < rect1.y + rect1.h
);
}? 提示:此公式假设所有矩形均以左上角为原点(Canvas 默认坐标系),x/y 表示左上顶点,w/h 为宽高。若使用中心点表示(如示例代码中的 fillRect(x - w/2, y - h/2, w, h)),则传入 collides() 前需先转换为左上角坐标,或统一在函数内处理。
以下代码已在现代浏览器中验证通过,点击运行即可观察红/黑边框实时响应碰撞状态:
掌握正确的 AABB 实现,是构建可靠 2D 物理系统的第一块基石。从今天起,请永远抛弃 !(A || B || C || D) 式的“反向分离”写法——正向描述重叠,才是健壮、可读、可维护的工程实践。