本文基于cocos2d-x2.2.3,并未在3.0以后的版本下编写,仅仅是提供1个思路,方便往后其他场景使用到该功能点可以参考,也没有详细讲述box2d物理引擎的基础知识,相干知识请自行多参考其他技术文档。
使用box2d物理引擎,通常需要我们自己给定1个边界来限制body的活动范围,最经常使用的是在屏幕的边界使用4条边来包围,构成1个矩形。但如果我们的需求是在1个圆形范围内,仅仅想通过1个中心点和半径来肯定这个范围,该如何处理呢?其实圆弧也能够看成是无数小线段组成的,当线段数目足够多时便无穷趋近于圆,因此我们可以在想要做为范围的圆周上面取1定数量的点,将各个点连起来所包围的范围,即可以看作是1个圆形区域。我们需要做的就是肯定这些点的坐标,首尾相连就能够围城1个近似圆的区域,固然点数越多越圆,计算量越多,性能越低,所以取适立即可,本文例子中取24个点。
如此1来,我们在创建物理世界初始化的时候,即可以将各个点数据围1个圆形的包围盒,写法以下:
<span style="font-family:Comic Sans MS;"> //设置重力参数
b2Vec2 gravity;
gravity.Set(0.0f,0.0f);
//创建世界
m_world = new b2World(gravity);
//是不是允许休眠
m_world->SetAllowSleeping(true);
//是不是连续物理测试
m_world->SetContinuousPhysics(true);
//地面物体定义
b2BodyDef groundBodyDef;
groundBodyDef.position.Set(0,0);
groundBody = m_world->CreateBody(&groundBodyDef);
//定义点的个数
float pointNum = 24;
//定义圆形边界的半径
radius = 300;
//定义圆心
m_center = ccp(640,400);
//寄存点数据的数组
CCPoint point[24];
for (int i= 0; i < pointNum; i++) {
//计算每两个点连成的线段的起始点的角度、坐标(第1个为0°)
float angle = (float)i/pointNum *PI*2;
float bx = radius * cos(angle);
float by = radius * sin(angle);
//圆心加上偏移量即为当前点坐标
bx += m_center.x;
by += m_center.y;
point[i].setPoint(bx,by);
}
point[23].setPoint(point[0].x,point[0].y);
for(int i= 0; i < pointNum⑴; i++)
{
//设置边沿范围
groundBox.Set(b2Vec2(point[i].x/PTM_RATIO,point[i].y/PTM_RATIO),b2Vec2(point[i+1].x/PTM_RATIO,point[i+1].y/PTM_RATIO));
groundBody->CreateFixture(&groundBox,100);
}</span>
效果以下:
上面只是给出了主要实现的代码段,仅供参考,也能够下载代码自己运行试试看,根据需要再进行参数的调剂,自己mark,免得往后需要的时候找来找去!!代码和资源在下面,请自己创建工程运行
点击下载参考源代码