0

0

c++如何判断点是否在矩形内_c++几何算法基础【练习】

穿越時空

穿越時空

发布时间:2026-02-01 15:41:41

|

722人浏览过

|

来源于php中文网

原创

轴对齐矩形内点判断用坐标比较:p.x∈[x_min,x_max]且p.y∈[y_min,y_max];旋转矩形则用std::abs((p−center)·u)≤half_w和std::abs((p−center)·v)≤half_h,需单位向量与浮点容差。

c++如何判断点是否在矩形内_c++几何算法基础【练习】

std::abs 和坐标比较判断点是否在轴对齐矩形内

轴对齐矩形(AABB)是最常见情况:四边平行于坐标轴。此时无需向量或叉积,只需比较横纵坐标范围。

假设矩形由左上角 (x_min, y_min) 和右下角 (x_max, y_max) 定义(注意:y 轴方向需与你的坐标系一致;若 y 向下为正,y_min < y_max 成立;若 OpenGL 风格 y 向上为正,可能需交换逻辑)。

p 在矩形内(含边界)的充要条件是:

  • p.x >= x_min && p.x <= x_max
  • p.y >= y_min && p.y <= y_max

若需严格内部(不含边界),把 >=<= 换成 >< 即可。

立即学习C++免费学习笔记(深入)”;

处理旋转矩形:用点到边的有向距离判断

旋转矩形不能只比坐标,得转到局部坐标系,或用“点在每条边左侧(或右侧)”来判定。推荐用向量投影法:将点相对于矩形中心平移后,做两次点积,看是否落在半宽/半高范围内。

设矩形中心为 center,两个正交单位向量 u(沿长边)、v(沿短边),半宽 half_w、半高 half_h。则点 p 在矩形内等价于:

MedPeer自然科学基金
MedPeer自然科学基金

科研申报与成果分析的智能数据引擎

下载
  • std::abs((p - center).dot(u)) <= half_w
  • std::abs((p - center).dot(v)) <= half_h

注意:uv 必须是单位向量,否则点积结果会缩放失真。如果只有四个顶点,可用 v1v2v2v3 叉出法向再归一化,但更稳妥的是用 std::normalize(C++23)或手动除模长。

别直接用 float 做相等判断——浮点误差会让边界判定失效

当矩形边界由浮点计算得出(比如变换后顶点),直接写 p.x == x_min 几乎总为 false。所有边界比较都应带容差:

  • std::abs(p.x - x_min) <= eps 代替 p.x >= x_min 的临界判断
  • 典型 eps 值:对 float1e-5f,对 double1e-9
  • 若矩形尺寸跨度大(如 1e6 量级),容差应随尺度缩放,例如 eps * std::max(std::abs(x_min), std::abs(x_max))

漏掉容差,会导致本该在边上的点被误判为外部,尤其在图形拾取或碰撞检测中会明显卡顿或漏响应。

性能敏感场景下避免函数调用开销

如果每帧要判断数万次(如粒子系统),优先展开计算、避免临时对象和 STL 函数调用:

  • 手写 dot 而非依赖 std::inner_product 或自定义 vector 类的成员函数
  • (p.x - cx) * ux + (p.y - cy) * uy 替代 (p - center).dot(u)(前提是 ux, uy 已预存)
  • 若矩形不旋转,分支预测友好,现代 CPU 几乎无延迟;但旋转矩形的两次点积+两次 std::abs 仍比纯比较慢约 3–5 倍

真正容易被忽略的是:很多项目先做粗略 AABB 包围盒剔除,再对候选者做旋转矩形精判——这个两级结构比单层判断快一个数量级,但需要你主动组织数据,不是库函数能自动提供的。

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

WorkBuddy
WorkBuddy

腾讯云推出的AI原生桌面智能体工作台

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
css中float用法
css中float用法

css中float属性允许元素脱离文档流并沿其父元素边缘排列,用于创建并排列、对齐文本图像、浮动菜单边栏和重叠元素。想了解更多float的相关内容,可以阅读本专题下面的文章。

598

2024.04.28

C++中int、float和double的区别
C++中int、float和double的区别

本专题整合了c++中int和double的区别,阅读专题下面的文章了解更多详细内容。

108

2025.10.23

c++怎么把double转成int
c++怎么把double转成int

本专题整合了 c++ double相关教程,阅读专题下面的文章了解更多详细内容。

356

2025.08.29

C++中int、float和double的区别
C++中int、float和double的区别

本专题整合了c++中int和double的区别,阅读专题下面的文章了解更多详细内容。

108

2025.10.23

页面置换算法
页面置换算法

页面置换算法是操作系统中用来决定在内存中哪些页面应该被换出以便为新的页面提供空间的算法。本专题为大家提供页面置换算法的相关文章,大家可以免费体验。

508

2023.08.14

bootstrap框架介绍
bootstrap框架介绍

本专题整合了bootstrap框架相关介绍,阅读专题下面的文章了解更多详细内容。

0

2026.03.18

vscode 格式化
vscode 格式化

本专题整合了vscode格式化相关内容,阅读专题下面的文章了解更多详细内容。

0

2026.03.18

vscode设置中文教程
vscode设置中文教程

本专题整合了vscode设置中文相关内容,阅读专题下面的文章了解更多详细教程。

0

2026.03.18

vscode更新教程合集
vscode更新教程合集

本专题整合了vscode更新相关内容,阅读专题下面的文章了解更多详细教程。

2

2026.03.18

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
C# 教程
C# 教程

共94课时 | 11.7万人学习

C 教程
C 教程

共75课时 | 5.6万人学习

C++教程
C++教程

共115课时 | 22.6万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号