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 成立;若 OpenGL 风格 y 向上为正,可能需交换逻辑)。

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

  • p.x >= x_min && p.x
  • p.y >= y_min && p.y

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

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

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

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

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

VidAU
VidAU

VidAU AI 是一款AI驱动的数字人视频创作平台,旨在简化视频内容创作流程

下载
  • std::abs((p - center).dot(u))
  • std::abs((p - center).dot(v))

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

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

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

  • std::abs(p.x - x_min) 代替 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

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

豆包大模型
豆包大模型

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

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

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

文心一言
文心一言

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

讯飞写作
讯飞写作

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

即梦AI
即梦AI

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

ChatGPT
ChatGPT

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

相关专题

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

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

580

2024.04.28

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

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

103

2025.10.23

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

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

113

2025.08.29

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

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

103

2025.10.23

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

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

419

2023.08.14

go语言 注释编码
go语言 注释编码

本专题整合了go语言注释、注释规范等等内容,阅读专题下面的文章了解更多详细内容。

29

2026.01.31

go语言 math包
go语言 math包

本专题整合了go语言math包相关内容,阅读专题下面的文章了解更多详细内容。

17

2026.01.31

go语言输入函数
go语言输入函数

本专题整合了go语言输入相关教程内容,阅读专题下面的文章了解更多详细内容。

15

2026.01.31

golang 循环遍历
golang 循环遍历

本专题整合了golang循环遍历相关教程,阅读专题下面的文章了解更多详细内容。

3

2026.01.31

热门下载

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

精品课程

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

共18课时 | 5.1万人学习

CSS教程
CSS教程

共754课时 | 26.1万人学习

Vue.js 微实战--十天技能课堂
Vue.js 微实战--十天技能课堂

共18课时 | 1.2万人学习

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

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