Box2d碰撞检测

本文介绍如何利用Box2d物理引擎和LuFyLegend框架进行H5游戏开发,通过实例展示了游戏场景的搭建,包括添加物理属性、创建动态和静态物体、设置调试模式等关键步骤。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

项目地址:

https://dev.tencent.com/u/simplyhabit/p/H5GameDemo/git/tree/master/Box2d

lufylegend-1.10.1.min.js

地址:

https://dev.tencent.com/u/simplyhabit/p/H5GameDemo/git/blob/master/js/lufylegend-1.10.1.min.js

Box2d是一款Js物理引擎

地址:

https://dev.tencent.com/u/simplyhabit/p/H5GameDemo/git/blob/master/Box2d/Box2d.min.js

html:

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Title</title>
    <script src="../js/lufylegend-1.10.1.min.js"></script>
    <script src="./Box2d.min.js"></script>
    <script src="./main.js"></script>
</head>
<body>
<div id="myLegend"></div>
</body>
</html>

main.js

var loader;

init(50,"myLegend",640,480,main);

var backLayer,cLayer;

function main() {

    // 调试模式
    LGlobal.setDebug(true);
    backLayer = new LSprite();
    // console.log(LGlobal.stage)
    addChild(backLayer);

    // 创建Box2d对象
    LGlobal.box2d = new LBox2d();
    cLayer = new LSprite();

    cLayer.x = 300;
    cLayer.y = 390;

    backLayer.addChild(cLayer);
    //addBodyPolygon :  宽、高、是否动态(0不动),密度,摩擦,弹性
    // 创建矩形 当做地板
    cLayer.addBodyPolygon(600,10,0,5,0.4,0.1)

    cLayer = new LSprite();
    cLayer.x = 300;
    cLayer.y = 100;
    backLayer.addChild(cLayer);
    cLayer.addBodyPolygon(30,20,1,5,0.4,0.5);//矩形
    cLayer.addBodyCircle(10,20,5,1,5,0.4,0.3);//圆
    var shapeArray = [
        [[0,54],[27,0],[54,54]]
    ];
    cLayer.addBodyVertices(shapeArray,27,27,1,.5,.4,.5) //三角形
}

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值