0

0

c++如何实现一个简单的物理引擎_c++游戏开发碰撞检测与响应【项目】

冰火之心

冰火之心

发布时间:2025-12-07 11:05:02

|

278人浏览过

|

来源于php中文网

原创

C++简易物理引擎包含刚体建模、显式欧拉积分、AABB/圆形碰撞检测、基于动量守恒与恢复系数的碰撞响应,以及穿透修正和固定时间步长等稳定性处理。

c++如何实现一个简单的物理引擎_c++游戏开发碰撞检测与响应【项目】

用 C++ 实现一个简单的物理引擎,核心在于 物体建模、运动积分、碰撞检测、碰撞响应 四个环节。不需要依赖大型库(如 Bullet 或 Box2D),纯手写也能跑通基础刚体动力学——比如小球下落、反弹、静止堆叠、简单矩形碰撞。下面按实际开发逻辑分块说明。

1. 刚体数据结构与运动学更新

先定义最简刚体:位置、速度、加速度、质量(可设为 1 简化)、是否受重力影响。

  • struct RigidBody 封装:含 vec2 pos, vel, acc(可用 std::array 或自定义二维向量)
  • 每帧调用 显式欧拉积分 更新(适合教学/简单场景):
    vel += acc * dt;
    pos += vel * dt;
  • 重力加在 acc.y = 9.8f(或 -9.8,取决于 Y 轴方向),地面设 y=0,碰到后手动清速并设位置为 0

2. 碰撞检测:AABB 与 圆-圆 / 圆-矩形

初学者优先实现轴对齐包围盒(AABB)和圆形碰撞,开销低、逻辑清晰。

  • AABB-AABB:两个矩形 (x,y,w,h),判断 abs(A.cx - B.cx)
  • Circle-Circle:距离平方 dx*dx + dy*dy
  • Circle-AABB:求圆心到矩形最近点距离平方(clamp 圆心 x/y 到矩形范围),再与半径平方比较

3. 碰撞响应:动量守恒 + 恢复系数

检测到碰撞后,不能只“弹开”,要算出合理的新速度——关键在法线方向的冲量计算。

ListenHub
ListenHub

超真实的AI播客生成器

下载

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

  • 先归一化碰撞法线 n(例如圆-圆:从 A 圆心指向 B 圆心;圆-AABB:用上一步最近点反推)
  • 相对速度沿法线的投影:v_rel = dot(vel_B - vel_A, n)
  • v_rel > 0,说明正在分离,跳过(避免重复响应)
  • 计算标量冲量 j = -(1 + restitution) * v_rel / (1/mA + 1/mB)(restitution ∈ [0,1],0=完全非弹性,1=完全弹性)
  • 更新速度:vel_A += j * n / mA;vel_B -= j * n / mB;

4. 稳定性技巧:碰撞顺序与穿透修正

多物体同时碰撞时,顺序会影响结果;持续穿透会导致抖动甚至爆炸。加两步小处理:

  • 分离穿透:响应后,沿法线把物体推开一点(如 pos_A -= n * penetration * 0.5f),防止下一帧再次触发
  • 排序响应:所有碰撞对收集后,按“穿透深度”从大到小处理,或简单地多迭代 2–3 次(称为 position-based correction)
  • 固定时间步长(如 dt = 1.0f/60)比用真实 delta-time 更稳定,避免高速穿墙

基本上就这些。写完可以做一个小场景:几个彩色圆球从空中落下,撞地板反弹,互相碰撞弹开,加点阻尼(每帧 vel *= 0.99)就更自然。不复杂但容易忽略细节——比如法线方向、质量倒数、穿透修正量。动手写一遍,比看十篇理论文章理解得深。

相关专题

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

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

562

2024.04.28

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

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

99

2025.10.23

treenode的用法
treenode的用法

​在计算机编程领域,TreeNode是一种常见的数据结构,通常用于构建树形结构。在不同的编程语言中,TreeNode可能有不同的实现方式和用法,通常用于表示树的节点信息。更多关于treenode相关问题详情请看本专题下面的文章。php中文网欢迎大家前来学习。

535

2023.12.01

C++ 高效算法与数据结构
C++ 高效算法与数据结构

本专题讲解 C++ 中常用算法与数据结构的实现与优化,涵盖排序算法(快速排序、归并排序)、查找算法、图算法、动态规划、贪心算法等,并结合实际案例分析如何选择最优算法来提高程序效率。通过深入理解数据结构(链表、树、堆、哈希表等),帮助开发者提升 在复杂应用中的算法设计与性能优化能力。

17

2025.12.22

深入理解算法:高效算法与数据结构专题
深入理解算法:高效算法与数据结构专题

本专题专注于算法与数据结构的核心概念,适合想深入理解并提升编程能力的开发者。专题内容包括常见数据结构的实现与应用,如数组、链表、栈、队列、哈希表、树、图等;以及高效的排序算法、搜索算法、动态规划等经典算法。通过详细的讲解与复杂度分析,帮助开发者不仅能熟练运用这些基础知识,还能在实际编程中优化性能,提高代码的执行效率。本专题适合准备面试的开发者,也适合希望提高算法思维的编程爱好者。

16

2026.01.06

堆和栈的区别
堆和栈的区别

堆和栈的区别:1、内存分配方式不同;2、大小不同;3、数据访问方式不同;4、数据的生命周期。本专题为大家提供堆和栈的区别的相关的文章、下载、课程内容,供大家免费下载体验。

390

2023.07.18

堆和栈区别
堆和栈区别

堆(Heap)和栈(Stack)是计算机中两种常见的内存分配机制。它们在内存管理的方式、分配方式以及使用场景上有很大的区别。本文将详细介绍堆和栈的特点、区别以及各自的使用场景。php中文网给大家带来了相关的教程以及文章欢迎大家前来学习阅读。

572

2023.08.10

CSS position定位有几种方式
CSS position定位有几种方式

有4种,分别是静态定位、相对定位、绝对定位和固定定位。更多关于CSS position定位有几种方式的内容,可以访问下面的文章。

81

2023.11.23

高德地图升级方法汇总
高德地图升级方法汇总

本专题整合了高德地图升级相关教程,阅读专题下面的文章了解更多详细内容。

43

2026.01.16

热门下载

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

精品课程

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

共94课时 | 6.9万人学习

C 教程
C 教程

共75课时 | 4.1万人学习

C++教程
C++教程

共115课时 | 12.6万人学习

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

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