一,鼠标拖拽刚体
使用lufylegend.js库件后,拖拽刚体变得很简单,只需调用LSprite的setBodyMouseJoint(true);方法即可,修改上一节中的add方法如下
- function add(){
- var rand = Math.random();
- if(rand < 0.33){
- cLayer = new LSprite();
- cLayer.x = 50 + Math.random()*700;
- cLayer.y = 50;
- backLayer.addChild(cLayer);
- bitmap = new LBitmap(new LBitmapData(imglist["bird1"]));
- cLayer.addChild(bitmap);
- cLayer.addBodyCircle(bitmap.getWidth()*0.5,bitmap.getHeight()*0.5,bitmap.getWidth()*0.5,1,.5,.4,.5);
- cLayer.setBodyMouseJoint(true);
- }else if(rand < 0.66){
- cLayer = new LSprite();
- backLayer.addChild(cLayer);
- bitmap = new LBitmap(new LBitmapData(imglist["bird2"]));
- cLayer.addChild(bitmap);
- var shapeArray = [
- [[0,54],[27,0],[54,54]]
- ];
- cLayer.addBodyVertices(shapeArray,27,27,1,.5,.4,.5);
- cLayer.box2dBody.SetPosition(new LGlobal.box2d.b2Vec2((50 + Math.random()*700)/LGlobal.box2d.drawScale,50/LGlobal.box2d.drawScale));
- cLayer.setBodyMouseJoint(true);
- }else{
- cLayer = new LSprite();
- cLayer.x = 50 + Math.random()*700;
- cLayer.y = 50;
- backLayer.addChild(cLayer);
- bitmap = new LBitmap(new LBitmapData(imglist["stage01"]));
- cLayer.addChild(bitmap);
- cLayer.addBodyPolygon(bitmap.getWidth(),bitmap.getHeight(),1,5,.4,.2);
- }
- }
http://lufy.netne.net/lufylegend-js/lufylegend-1.4/box2d/sample01/index4.html
二,碰撞检测
使用如下代码来加入碰撞检测事件
- LGlobal.box2d.setEvent(LEvent.BEGIN_CONTACT,beginContact);
为了方便,我这里使用lufylegend.js中的debug方法来验证
- function beginContact(contact){
- if(contact.GetFixtureA().GetBody().GetUserData().name == "bird" &&
- contact.GetFixtureB().GetBody().GetUserData().name == "bird"){
- trace("bird and bird");
- }
- trace("bird and other");
- };
以上方法就是碰撞的检测,意思是当两只小鸟之间发生碰撞的时候,输出"bird and bird",小鸟和其他刚体,或者其他刚体之间发生碰撞的时候输出"bird and other"
这里是测试连接
http://lufy.netne.net/lufylegend-js/lufylegend-1.4/box2d/sample01/index5.html
下面是运行结果
三,刚体之间的各种链接
最后,我们来看看刚体之间的各种连接,这部分目前没有封装在lufylegend.js里,以后会陆续封装进去,不过现在我们先来看看如何手动实现这些连接
1,距离链接(b2DistanceJointDef)
b2DistanceJointDef可以用来约束两个body之间的距离,用法如下
- function add(){
- cLayer = new LSprite();
- cLayer.name = "bird";
- cLayer.x = 50 + Math.random()*700;
- cLayer.y = 50;
- backLayer.addChild(cLayer);
- bitmap = new LBitmap(new LBitmapData(imglist["bird1"]));
- cLayer.addChild(bitmap);
- cLayer.addBodyCircle(bitmap.getWidth()*0.5,bitmap.getHeight()*0.5,bitmap.getWidth()*0.5,1,.5,.4,.5);
- cLayer.setBodyMouseJoint(true);
- return cLayer;
- }
- var bird1 = add();
- var bird2 = add();
- var distanceJointDef = new LGlobal.box2d.b2DistanceJointDef();
- distanceJointDef.Initialize(bird1.box2dBody, bird2.box2dBody, bird1.box2dBody.GetWorldCenter(), bird2.box2dBody.GetWorldCenter());
- LGlobal.box2d.world.CreateJoint(distanceJointDef);
这里是测试连接
http://lufy.netne.net/lufylegend-js/lufylegend-1.4/box2d/sample01/index6.html
下面是运行结果
2,旋转链接(b2RevoluteJointDef)
b2RevoluteJointDef可以给两个body设置一个轴心,让两个body绕这个轴心旋转,用法如下
- var bird = new LSprite();
- bird.name = "bird";
- bird.x = 200;
- bird.y = 200;
- backLayer.addChild(bird);
- bitmap = new LBitmap(new LBitmapData(imglist["bird1"]));
- bird.addChild(bitmap);
- bird.addBodyCircle(bitmap.getWidth()*0.5,bitmap.getHeight()*0.5,bitmap.getWidth()*0.5,0);
- var pig = new LSprite();
- pig.name = "pig";
- pig.x = 200;
- pig.y = 150;
- backLayer.addChild(pig);
- bitmap = new LBitmap(new LBitmapData(imglist["pig2"]));
- pig.addChild(bitmap);
- pig.addBodyCircle(bitmap.getWidth()*0.5,bitmap.getHeight()*0.5,bitmap.getWidth()*0.5,1,.5,.4,.5);
- var revoluteJointDef = new LGlobal.box2d.b2RevoluteJointDef();
- revoluteJointDef .Initialize(pig.box2dBody, bird.box2dBody, bird.box2dBody.GetWorldCenter());
- LGlobal.box2d.world.CreateJoint(revoluteJointDef );
这里是测试连接
http://lufy.netne.net/lufylegend-js/lufylegend-1.4/box2d/sample01/index7.html
下面是运行结果
3,滑轮链接(b2PulleyJointDef)
b2PulleyJointDef类似滑轮效果,用法如下
- var bird = new LSprite();
- bird.name = "bird";
- bird.x = 200;
- bird.y = 200;
- backLayer.addChild(bird);
- bitmap = new LBitmap(new LBitmapData(imglist["bird1"]));
- bird.addChild(bitmap);
- bird.addBodyCircle(bitmap.getWidth()*0.5,bitmap.getHeight()*0.5,bitmap.getWidth()*0.5,1,.5,.4,.5);
- bird.setBodyMouseJoint(true);
- var bird01 = new LSprite();
- bird01.name = "bird";
- bird01.x = 400;
- bird01.y = 150;
- backLayer.addChild(bird01);
- bitmap = new LBitmap(new LBitmapData(imglist["bird1"]));
- bird01.addChild(bitmap);
- bird01.addBodyCircle(bitmap.getWidth()*0.5,bitmap.getHeight()*0.5,bitmap.getWidth()*0.5,1,.5,.4,.5);
- bird01.setBodyMouseJoint(true);
- var anchor1 = bird.box2dBody.GetWorldCenter();
- var anchor2 = bird01.box2dBody.GetWorldCenter();
- var groundAnchor1 = new LGlobal.box2d.b2Vec2(anchor1.x, anchor1.y - (100 / LGlobal.box2d.drawScale));
- var groundAnchor2 = new LGlobal.box2d.b2Vec2(anchor2.x, anchor2.y - (100 / LGlobal.box2d.drawScale));
- var ratio = 1.0;
- var pulleyJointDef = new LGlobal.box2d.b2PulleyJointDef();
- pulleyJointDef.Initialize(bird.box2dBody, bird01.box2dBody, groundAnchor1, groundAnchor2, anchor1, anchor2, ratio);
- pulleyJointDef.maxLengthA = 300 / LGlobal.box2d.drawScale;
- pulleyJointDef.maxLengthB = 300 / LGlobal.box2d.drawScale;
- LGlobal.box2d.world.CreateJoint(pulleyJointDef);
这里是测试连接
http://lufy.netne.net/lufylegend-js/lufylegend-1.4/box2d/sample01/index8.html
下面是运行结果
其余的连接还有,b2GearJoint,b2PrismaticJoint,b2LineJoint,b2WeldJoint等多种链接,这些等以后封装到lufylegend.js后再详细介绍,这里不细说了,想了解的朋友可以查阅一下相关资料
最后给出这两次内容的所有源代码
http://fsanguo.comoj.com/download.phpi=box2d_sample01.rar
注意,上面只是源码,如果想要在本地运行这些源码的话,需要自己下载lufylegend.js库件以及box2dweb,然后进行配置
有了上面的介绍,应该可以做一个物理游戏了,相信大家都知道一款非常有名的游戏《愤怒的小鸟》,下次咱们来研究一下如何用html5来实现它