• p2.js 与 createjs 的组合应用


    开始前简单说下其他几款js物理引擎

    box2d老牌,功能全面,但是效率低下,移动端基不用考虑的

    matterjs  效率目前我测试下来最高,但是依然还在开发中(好像还很缓慢),目前功能局限,而且有bug。(本来项目打算使用,结果局限和bug导致放弃)

    p2js 移动端推荐使用 (常规体量在目前手机大多数上应用没有问题)

    作者github:     https://github.com/schteppe

    阅读此文需要一定的基础知识,这里只讲p2.js 与 createjs 的组合应用

    坐标系:

      p2.js与createjs 的x轴是一致的。y轴是相反的

      

    注册点:  

      createjs默认在目标bound的左上角

      p2.js默认在目标bound的中心

        

    相关属性转换

      createjs.rotation = -p2.angle * 180 / Math.PI;

      createjs.x= p2.Body.position[0];

      createjs.y= -p2.Body.position[1];

    使用createjs的movieclip、sprite、img贴图渲染

      p2js的一大特点就是最基本的库里并没有集成贴图渲染的相关api,一开始觉得很不习惯,使用后觉得真心好用,能满足很多特殊情况           

      例如:1 由于模型原因,我们贴图需要稍大于模型,这样才能在渲染时没有缝隙。

         2 动态刷新贴图(例如我们直接使用createjs的movieclip,多方便)  

      其实就是把p2的坐标,角度对应的绑定给createjs的元件来显示。  

    var arrDataShow=[]; //数组管理对应关系
    
    //建createjs元件
    var _m=new createjs.MovieClip()
    //建p2刚体	
    var _p2= new p2.Body(
    {
    	mass: 1,
    	position: [0, 0],
    	angle:0.1,
    	allowSleep : false
    })
    world.addBody(_p2);	
    
    arrDataShow.push({data:_p2,show:_m,type:""});//数组管理对应关系
    
    
    //渲染
    stage.addEventListener("tick",function(e)
    {
    	world.step(1 / 10); //createjs fps 与 p2 word的step 对应关系 自行摸索
    	for (var i = 0; i < arrDataShow.length; i++)
    	{
    		var type = arrDataShow[i].type;
    		var data = arrDataShow[i].data;
    		var show = arrDataShow[i].show;
    		//
    		show.x = data.position[0];
    		show.y = -data.position[1];
    		show.rotation = -data.angle * 180 / Math.PI;
    	}
    })
    

     

    至于不规则图形,如何在p2中建立刚体官方demo里面也有

    注意:

    因为不规则所以刚体的重心并不会在bound的中心,所以需要进一步解决这个问题(项目时间原因,暂时还未想到好的办法,待更新)

    到此 两者的组合应用 算是基本清了!

  • 相关阅读:
    反思二
    安装Electron时卡在install.js不动的解决方案
    解决npm 下载速度慢的问题
    覆盖第三方jar包中的某一个类。妙!!
    关于拦截器是用注解方便,还是用配置文件写死方便的总结。
    yapi 启动后,老是自动关闭的问题。
    BaseResponse公共响应类,与我的设计一模一样,靠、ApiResponse
    HashMap 的 7 种遍历方式与性能分析!(强烈推荐)、forEach
    Jackson objectMapper.readValue 方法 详解
    yapi tag的问题,暂时只保留一个tag
  • 原文地址:https://www.cnblogs.com/luoeeyang/p/6841161.html
Copyright © 2020-2023  润新知