大佬教程收集整理的这篇文章主要介绍了cocos2d-x 画物理齿轮,大佬教程大佬觉得挺不错的,现在分享给大家,也给大家做个参考。
正在做物理小游戏, 用到齿轮
Node *drawGear(float r1,float r2,int teeth) { DrawNode *gear = DrawNode::create(); float da=2.0*PI/teeth/4.0; PhysicsBody* gearBody = PhysicsBody::create(); Physicsmaterial gearMaterial(0.05,0.5,0.05f); gearBody->setGravityEnable(false); Vec2 polyPoint[4]; float angle; for(int i = 0; i < teeth; i++) { int j = 3; angle= i * 2.0 * PI / teeth; Vec2 pos1 = Vec2(r1*cos(anglE),r1*sin(anglE)); polyPoint[j] = pos1; //gear->drawPoint(pos1,3,Color4F::rED); Vec2 pos2 = Vec2(r2 * cos(angle+da),r2 * sin(angle+da)); polyPoint[--j] = pos2; //gear->drawPoint(pos2,Color4F::BLUE); gear->drawSegment(pos1,pos2,1,Color4F::BLACK); pos1 = Vec2(r2 * cos(angle+da),r2 * sin(angle+da)); //polyPoint[++j] = pos1; //gear->drawPoint(pos1,Color4F::YELLOW); pos2 = Vec2(r2 * cos(angle+2*da),r2 * sin(angle+2*da)); //polyPoint[++j] = pos2; //gear->drawPoint(pos2,Color4F::GREEN); gear->drawSegment(pos1,Color4F::BLACK); pos1 = Vec2(r2 * cos(angle+2*da),r2 * sin(angle+2*da)); polyPoint[--j] = pos1; //gear->drawPoint(pos1,Color4F::GRAY); pos2 = Vec2(r1 * cos(angle+3*da),r1 * sin(angle+3*da)); polyPoint[--j] = pos2; //gear->drawPoint(pos2,Color4F::MAGENTA); gear->drawSegment(pos1,Color4F::BLACK); gear->drawCircle(Vec2::ZERO,r1,60,false,Color4F::BLACK); gearBody->addShape(PhysicsShapeCircle::create(r1,gearMaterial)); gear->drawCircle(Vec2::ZERO,r1/3*2,Color4F::BLACK); gearBody->addShape(PhysicsShapePolygon::create(polyPoint,4,gearMaterial)); } gear->setPhysicsBody(gearBody); return gear; }
以上是大佬教程为你收集整理的cocos2d-x 画物理齿轮全部内容,希望文章能够帮你解决cocos2d-x 画物理齿轮所遇到的程序开发问题。
如果觉得大佬教程网站内容还不错,欢迎将大佬教程推荐给程序员好友。
本图文内容来源于网友网络收集整理提供,作为学习参考使用,版权属于原作者。
如您有任何意见或建议可联系处理。小编QQ:384754419,请注明来意。