찾다

box2d源码解析 一

Jun 07, 2016 pm 03:20 PM
소스 코드분석하다

为什么写这篇博文: 前一段时间一直在花时间看box2d源码,真可谓废了九牛二虎之力,四处扒资料,皇天不负有心人,最终还是将源码看完了,可以长舒一口气了.不过会想起我在学习过程中遇到的没有资料之苦,是绝不能让后来人再次承受,因为这非但不是对毅力的历练,反而

为什么写这篇博文:

前一段时间一直在花时间看box2d源码,真可谓废了九牛二虎之力,四处扒资料,皇天不负有心人,最终还是将源码看完了,可以长舒一口气了.不过会想起我在学习过程中遇到的没有资料之苦,是绝不能让后来人再次承受,因为这非但不是对毅力的历练,反而是对时间的浪费。

网上的资料实在少得可怜,有关于box2d的,也是box2d的用法,根本就不是源码的解析。所以决定将我的学习历程分享给大家,帮助后来人,共勉。

还想说一些关于学习要深入到精髓源码中去,而不是浮在表面学习一下别人写的东西的api之类的话,想着我等无名小辈,人微言轻,怕被喷,还是算了,还是算了。

Box2d介绍:

我就不从维基百科上复制了,自己说下了.这个东西对游戏开发者来说是再熟悉不过了,就是一个物理引擎,通过输入(刚体的位置,速度,角速度,用户的操作)通过一定的计算,给出输出(刚体新的位置,速度,角速度).如果不是特别了解的朋友,回忆下愤怒的小鸟,其中的物理效果就是靠Box2d来实现的~

 

为什么会去看box2d源码:

         去看源码真心的出于兴趣,就是感觉box2d这个东西那是相当的神奇啊,怎么就能通过运算模拟出了物体(主要是刚体)的运动,还有各种约束。更重要的一点是我能找到源码,这就要感谢box2d的作者开放了源代码

 

博文计划:

         第一篇博文主要是一个概述,说下我看了那些资料,还有一些看源码的时候的难以理解的点(通过看box2d作者写的文章到最后也不能理解的点) ,对于出来找资料准备自己研究源码的人来说,看第一篇博文足够用了,这里面会有必要资料,对box2d的概述.

         后面的博文会陆陆续续的出,主要是对一些具体的点的解析,还有就是一些外文网站的翻译,看源码的时候有哪里看不懂的可以回来看看.

基本上废话就这么多,让我们直奔主题:

学习历程:刚开始拿到源码的时候,想着一天看一个类不出一个月也能看完。可是后来发现,如果不知道一个类的用途,想去看懂其中的逻辑真心的费事。所以还是来csdn搜索了一下,发现了扭曲45 的文章,跟着他写的几篇文章的思路一直坚持,一直到他的最后一篇关于box2d的博文(真心感谢扭曲45 如果没有您,我不会坚持到最后,但是您的几篇文章都是将源码粘上去加上注释也是真心难看懂啊╭(╯3╰)╮)。但是后面的约束并没有涉及,也就是说看完他的文章如果都理解的话也只是知道了如何检测刚体之间发生了碰撞,得到碰撞的信息(后面的William的文章中也有说举得例子更详细~),至于如果判断刚体的进一步运动,如果合理约束,还是需要自己研究。然后通过,扭曲45的推荐找到了http://www.codezealot.org/这个网站,上面讲了很多关于约束的东西,然后通过codezealot的博主William的推荐找到了box2d的作者ErinCatto存放资料的地方https://code.google.com/p/box2d/downloads/list,里面有每年ErinCatto在WDC上的演讲的东西,其中的2005年 2006年的演讲资料,以及一个box2_Lite(box2d简化版)对看懂box2d源码意义重大。总结来说扭曲45 的博文主要是基础部分和碰撞部分,William的博文主要是详细的碰撞方法部分,和约束部分,ErinCatto的演讲资料,就是总结,所以看ErinCatto资料之前一定要对box2d有个基本的了解,这样看才会有收获才会发现精髓原来在这里,要不然指定是更加的迷糊一头雾水。还有最重要的就是自己的思考和不懈地坚持。通过这么多博文资料 自己的努力 足够看懂源码的了

类解析:概要的介绍这里也不可能说的太详细,box2d中的很多函数都是全局函数,很多很多。还有一点不得不说,box2d中每个刚体都有着两套坐标,一套本地坐标,直接保存在属性中,还有一套世界坐标通过transform计算出来,两套坐标的好处,game-physics-engine-development-the-morgan-kaufmann-series-in-interactive-3d-technology.pdf中有讲,有中文版。

一、Common文件夹下:此文件夹下最重要的莫过于对象池的实现了,其余的都是一些小函数,定义,and so on。

1.      b2BlockAllocator:使用栈内存的小对象分配器,说白了其实就是自己先向系统申请一块较大的内存,然后自己掌控这块内存的分配回收,最后返回给系统。

2.      b2StackAllocator:使用堆内存的小对象分配器。堆内存就是最后系统会自动回收,栈内存就是new alloc 申请的最后要释放的 那种内存。(应该没记错)

3.      b2Draw:因为不懂OpenGl 所以看不懂写的什么,不过反正知道就是在黑窗口的时候画出一些图形,关节,碰撞点等等。

4.      后面的就不写了很简单 源码自带的注释非常详细。

二、Collision/Shapes文件夹下:各种形状的定义,都是继承自b2Shape

三、Collision文件夹:

1.      B2Distance:通过输入两个刚体(各种上面Shapes文件夹中定义的形状的),transform(刚体在世界坐标系中的位置,旋转角度),得出刚体的距离,return出去。

2.      B2Collision:碰撞的常用函数实现。    RayCast()用来判断射线和刚体相交的位置,b2ClipSegmentToLine()在后面的分离轴处使用,b2TestOverlap()调用的b2Distance中的b2Distance()函数得到距离看是否重叠(碰撞)。

3.      B2DynamicTree:动态AABB树,其实就是树,里面存的对象是AABB。AABB就是碰撞包围盒, 包裹在刚体周围的,一对边和x轴平行,另一对边和x轴垂直的矩形,详细的在game-physics-engine-development-the-morgan-kaufmann-series-in-interactive-3d-technology.pdf中有讲,有中文版.

4.      B2BroadPhase:中有一个b2DynamicTree对象,也就是说b2BroadPhase是为了操作b2DynamicTree而生,在检测碰撞初期先用AABB进行粗略的碰撞检测,只有AABB碰撞的一对刚体才真的可能发生了碰撞,如果AABB都没有碰撞,说明这对刚体没有碰撞,引入AABB的意义在于,加快碰撞的检测,因为判断AABB是否碰撞远比判断具体的形状之间是否发生了碰撞代价小。

5. b2CollideCircle。Cpp 这个家伙连个头文件都没有,其中的函数直接就是全局函数,用于计算圆形和圆形的碰撞。通过输入(constb2PolygonShape* polygonA,constb2Transform&xfA,

constb2CircleShape* circleB,constb2Transform&xfB),计算出碰撞点的位置,个数,类型,放在输出(b2Manifold* manifold)中。

6.      b2CollideEdge中的b2CollideEdgeAndCircle用于计算线段和圆形,b2EPCollider结构体用于计算线段和多边形。

7.      b2CollidePolygon用于计算多边形和多变性,具体后面翻译的外文博客中有讲。

四、Dynamic/Contacts文件夹

1.      各种碰撞的定义都是继承自b2Contact,其中的得到碰撞信息都是调用的三、5.6。中的东西。

五、Dynamic/Joint文件夹:

1.      各种关节,都是继承于b2Joint,具体的东西,后面翻译的外文网站中有。

六、Dynamic文件夹:这里面的东西,基本上就是相当于人类的大脑,操控全局,调用其它的类,函数。很多熟悉的就不多说了,很好理解。

1.      b2Island:这个东西主要是b2word在处理碰撞的时候需要计算时,将各种东西塞进b2Island中进行计算,也就是说这个类存在的意义就是计算。

2.      b2ConatactManager:同样也是为b2Word服务,用来管理碰撞。

 

box2d源码解析 一  到这里基本上就结束了,全是一些概述。不过不急,谁也不可能一口吃成大胖子,慢慢来,一步一步展开。

后面先翻译几篇外文,将必备知识储备完善,之后再说其他.

성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
MySQL과 다른 SQL 방언의 구문의 차이점은 무엇입니까?MySQL과 다른 SQL 방언의 구문의 차이점은 무엇입니까?Apr 27, 2025 am 12:26 AM

mysqldiffersfromothersqldialectsinsyntaxforlimit, 자동 점유, 문자열 comparison, 하위 쿼리 및 퍼포먼스 앤 알리 분석 .1) mysqluse Slimit, whilesqlSerVerusestOpandoracleSrownum.2) MySql'Sauto_incrementContrastSwithPostgresql'serialandoracle '

MySQL 파티셔닝이란 무엇입니까?MySQL 파티셔닝이란 무엇입니까?Apr 27, 2025 am 12:23 AM

MySQL 파티셔닝은 성능을 향상시키고 유지 보수를 단순화합니다. 1) 큰 테이블을 특정 기준 (예 : 날짜 범위)으로 작은 조각으로 나누고, 2) 데이터를 독립적 인 파일로 물리적으로 나눌 수 있습니다.

MySQL에서 어떻게 권한을 부여하고 취소합니까?MySQL에서 어떻게 권한을 부여하고 취소합니까?Apr 27, 2025 am 12:21 AM

MySQL에서 권한을 부여하고 취소하는 방법은 무엇입니까? 1. 보조금 명세서를 사용하여 grantallprivilegesondatabase_name.to'username'@'host '와 같은 부여 권한; 2. Revoke 문을 사용하여 Revokeallprivilegesondatabase_name.from'username'@'host '와 같은 권한을 취소하여 허가 변경의 적시에 의사 소통을 보장하십시오.

InnoDB와 MyISAM 스토리지 엔진의 차이점을 설명하십시오.InnoDB와 MyISAM 스토리지 엔진의 차이점을 설명하십시오.Apr 27, 2025 am 12:20 AM

InnoDB는 거래 지원 및 높은 동시성이 필요한 응용 프로그램에 적합한 반면, MyISAM은 더 많은 읽기와 덜 쓰는 응용 프로그램에 적합합니다. 1. INNODB는 전자 상거래 및 은행 시스템에 적합한 거래 및 은행 수준의 자물쇠를 지원합니다. 2. Myisam은 블로깅 및 컨텐츠 관리 시스템에 적합한 빠른 읽기 및 색인을 제공합니다.

MySQL의 다른 유형의 조인은 무엇입니까?MySQL의 다른 유형의 조인은 무엇입니까?Apr 27, 2025 am 12:13 AM

MySQL에는 Innerjoin, Leftjoin, RightJoin 및 FullouterJoin의 네 가지 주요 조인 유형이 있습니다. 1. 결합 조건을 충족하는 두 테이블의 모든 행을 반환합니다. 2. Leftjoin 오른쪽 테이블에 일치하는 행이 없더라도 왼쪽 테이블의 모든 행을 반환합니다. 3. RightJoin은 LeftJoin과 상반되며 오른쪽 테이블의 모든 행을 반환합니다. 4. FULLOUTERNOIN은 조건을 충족 시키거나 충족하지 않는 두 테이블의 모든 행을 반환합니다.

MySQL에서 사용 가능한 다른 스토리지 엔진은 무엇입니까?MySQL에서 사용 가능한 다른 스토리지 엔진은 무엇입니까?Apr 26, 2025 am 12:27 AM

mysqloffersvariousStorageEngines, 각각의 everitedforentUsecases : 1) innodbisidealforapplicationsneedingAcidCoInceandHighConcurrency, 지원 트랜잭션 및 foreignKeys.2) myIsAmisbestforread-heverworkloads, memoryengineis

MySQL의 일반적인 보안 취약점은 무엇입니까?MySQL의 일반적인 보안 취약점은 무엇입니까?Apr 26, 2025 am 12:27 AM

MySQL의 일반적인 보안 취약점에는 SQL 주입, 약한 암호, 부적절한 권한 구성 및 업데이트되지 않은 소프트웨어가 포함됩니다. 1. 전처리 명령문을 사용하여 SQL 주입을 방지 할 수 있습니다. 2. 강력한 비밀번호 전략을 사용하여 약한 암호는 피할 수 있습니다. 3. 정기적 인 검토 및 사용자 권한 조정을 통해 부적절한 권한 구성을 해결할 수 있습니다. 4. Unupdated 소프트웨어는 MySQL 버전을 정기적으로 확인하고 업데이트하여 패치 할 수 있습니다.

MySQL에서 느린 쿼리를 어떻게 식별 할 수 있습니까?MySQL에서 느린 쿼리를 어떻게 식별 할 수 있습니까?Apr 26, 2025 am 12:15 AM

느린 쿼리 로그를 활성화하고 임계 값을 설정하여 MySQL에서 느린 쿼리를 식별 할 수 있습니다. 1. 느린 쿼리 로그를 활성화하고 임계 값을 설정하십시오. 2. 느린 쿼리 로그 파일을보고 분석하고 심층 분석을 위해 MySQLDumpSlow 또는 PT-Query 소수성과 같은 도구를 사용하십시오. 3. 인덱스 최적화, 쿼리 재 작성 및 select*의 사용을 피함으로써 느린 쿼리 최적화를 달성 할 수 있습니다.

See all articles

핫 AI 도구

Undresser.AI Undress

Undresser.AI Undress

사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover

AI Clothes Remover

사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool

Undress AI Tool

무료로 이미지를 벗다

Clothoff.io

Clothoff.io

AI 옷 제거제

Video Face Swap

Video Face Swap

완전히 무료인 AI 얼굴 교환 도구를 사용하여 모든 비디오의 얼굴을 쉽게 바꾸세요!

뜨거운 도구

안전한 시험 브라우저

안전한 시험 브라우저

안전한 시험 브라우저는 온라인 시험을 안전하게 치르기 위한 보안 브라우저 환경입니다. 이 소프트웨어는 모든 컴퓨터를 안전한 워크스테이션으로 바꿔줍니다. 이는 모든 유틸리티에 대한 액세스를 제어하고 학생들이 승인되지 않은 리소스를 사용하는 것을 방지합니다.

DVWA

DVWA

DVWA(Damn Vulnerable Web App)는 매우 취약한 PHP/MySQL 웹 애플리케이션입니다. 주요 목표는 보안 전문가가 법적 환경에서 자신의 기술과 도구를 테스트하고, 웹 개발자가 웹 응용 프로그램 보안 프로세스를 더 잘 이해할 수 있도록 돕고, 교사/학생이 교실 환경 웹 응용 프로그램에서 가르치고 배울 수 있도록 돕는 것입니다. 보안. DVWA의 목표는 다양한 난이도의 간단하고 간단한 인터페이스를 통해 가장 일반적인 웹 취약점 중 일부를 연습하는 것입니다. 이 소프트웨어는

스튜디오 13.0.1 보내기

스튜디오 13.0.1 보내기

강력한 PHP 통합 개발 환경

SublimeText3 중국어 버전

SublimeText3 중국어 버전

중국어 버전, 사용하기 매우 쉽습니다.

Dreamweaver Mac版

Dreamweaver Mac版

시각적 웹 개발 도구