位置: 编程技术 - 正文

cocos2d-x初探学习笔记(19)--物理引擎box2d(1)(cocos2dx-js)

编辑:rootadmin

推荐整理分享cocos2d-x初探学习笔记(19)--物理引擎box2d(1)(cocos2dx-js),希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:cocos2dx官方教程,cocos2dx-js,cocos2dx视频教程,cocos 2d x,cocos2dx4.0教程,cocos2dx官方教程,cocos2dx官方教程,cocos2dx4.0入门,内容如对您有帮助,希望把文章链接给更多的朋友!

小满(bill man)个人原创,欢迎转载,转载请注明地址,小满(bill man)的专栏地址 是用可移植的 C&#;&#; 来写成的。引擎中定义的大部分类型都有 b2 前缀,可以把它和我们游戏中的其他元素区分开来。

Box2d中有很多概念。

1.刚体

即是物理学中的质点,只有位置,没有大小,它又可以区分为以下几类

静态刚体:静态刚体没有质量,没有速度,只可以手动来改变他的位置

棱柱刚体:棱柱刚体没有质量,但是可以有速度,可以自己更新位置

动态刚体:动态刚体有质量也有速度

物理引擎需要首先定义一个描述类,然后再根据描述类通过世界创建某个对象。创建刚体时需要有两个步骤,一是生成一个刚体定义,二是根据刚体定义生成刚体。在刚体创建时定义中的信息会被复制,也就是说创建完成后刚体只要没被释放掉,就还可以重复使用。

//定义刚体

b2BodyDef groundBodyDef;

groundBodyDef.position.Set(screenSize.width/2/PTM_RATIO, screenSize.height/2/PTM_RATIO);

//生成刚体

b2Body* groundBody = world->CreateBody(&groundBodyDef);

2.形状

通过关联添加到刚体上,碰撞可以根据形状来判定,具有摩擦和恢复等材料特性。

b2PolygonShape groundBox;

// bottom

groundBox.SetAsBox(screenSize.width/2/PTM_RATIO, 0, b2Vec2(0, -screenSize.height/2/PTM_RATIO), 0);

3.关联

关联是一种附加在刚体上的属性,一个刚体可以有多个关联,创建关联时,需要定义关联的信息,然后通过刚体创建关联,当关联被创建时关联定义中的信息也会被保留,也可以重用

//定义并创建关联

b2FixtureDef fixtureDef;

fixtureDef.shape = &dynamicBox;

fixtureDef.density = 1.0f;

fixtureDef.friction = 0.3f;

cocos2d-x初探学习笔记(19)--物理引擎box2d(1)(cocos2dx-js)

body->CreateFixture(&fixtureDef);

4.链接

链接可以联系多个缸体,使得刚体之间相互影响,同样的,也需要首先定义信息,之后通过世界创建链接,同样的,信息也可以被保留,从而重用

另外链接还支持限制和马达,限制就是限制物体运动的角度,马达就是依照关节中的限制来约束物体

链接有旋转,棱柱和距离等

b2RevoluteJointDef rjd;

rjd.Initialize(m_attachment, m_platform, b2Vec2(0.0f, 5.0f));

rjd.maxMotorTorque = .0f;

rjd.enableMotor = true;

m_world->CreateJoint(&rjd);

5.约束

一个约束就是消除物体自由度的物理连接。在 2D 中,一个物体有 3 个自由度。如果我

们把一个物体钉在墙上(像摆锤那样),那我们就把它约束到了墙上。这样,此物体就只能绕着这个钉子旋转,所以这个约束消除了它 2 个自由度。

还有一种不须你创建的接触约束,一个防止刚体穿透,以及用于模拟摩擦和恢复的特殊约束。

6.世界

世界是遵循物理的空间,以上的所有都存在于世界中,可以创建多个世界,但很少这样用

创建世界需要两个步骤,一是生成重力向量,二是根据重力生成世界对象

//生成重力向量

b2Vec2 gravity;

gravity.Set(0.0f, -.0f);

//生成世界对象

bool doSleep = true;

world = new b2World(gravity);

world->SetAllowSleeping(doSleep);

world->SetContinuousPhysics(true);

刚开始研究此引擎,如有错误之处,希望大家多多指正

下一篇继续深入box2d

cocos2d-x初探学习笔记()--精灵类 小满(billman)个人原创,欢迎转载,转载请注明地址,小满(billman)的专栏地址

cocos2d-x初探学习笔记()--动画类 小满(billman)个人原创,欢迎转载,转载请注明地址,小满(billman)的专栏地址

cocos2d-x初探学习笔记()--其他(屏幕旋转,schedule,系统语言) 小满(billman)个人原创,欢迎转载,转载请注明地址,小满(billman)的专栏地址

标签: cocos2dx-js

本文链接地址:https://www.jiuchutong.com/biancheng/372674.html 转载请保留说明!

上一篇:cocos2d-x初探学习笔记(18)--Lable(cocos2dx-js)

下一篇:cocos2d-x初探学习笔记(21)--精灵类(cocos2d教程)

  • 企业所得税研发费用加计扣除条件
  • 企业纳税人是什么
  • 金融资产交易增值税
  • 增值税专用发票丢失了要怎么处理
  • 什么是保函业务?如何进行核算?
  • 收到发票怎么写收据
  • 增值税何时需要交税
  • 会计中预付款余额是什么
  • 个人所得税里累计专项扣除是什么意思
  • 合同资产减值准备怎么计提
  • 旧房转让土地增值税计算案例
  • 结转无形资产账面价值
  • 个税退税入账
  • 公司欠增值税如何补交?
  • 装修计入固定资产
  • 2021 上海房产税
  • 报关单出口退税联在哪打印
  • 个人是否可以开展募捐
  • 已认证的发票开红字红发要去税局吗
  • 没有成立工会的企业要交工会筹备金吗
  • 购进货物运费会退吗
  • 建筑业月末账务处理
  • 存货成本有哪些问题
  • 同一控制下合并对价怎么算
  • linux计划任务crontab
  • mac版chrome浏览器无法上网
  • 电脑每次开机都要按f1怎么解决
  • php bcmul
  • 收境外汇款时怎么操作
  • 打开苹果safari浏览器
  • 限售股交易征税是多少
  • 股东股权转让税务稽查案例
  • 资产为什么等于成本
  • 机器学习——BP神经网络详细介绍及案例Python代码实现
  • vue watch和computed
  • php数据统计源码
  • python每行输出五个且对齐
  • 土地作为无形资产入账依据
  • 公司借款方式
  • 商品流通企业的含义
  • 冲销上个月成本的会计分录
  • 应交增值税进项税额和销项税额区别
  • 学历教育服务增值税
  • 存货科目计算公式是什么
  • 小微企业减免附加税税率
  • 日用品办公用品的经营范围
  • 预付电费收到发票报销单怎么写
  • 外贸公司出口退税实例
  • 以前年度会计科目记错
  • 定期存款怎么做
  • 微软雅黑可以免费用吗
  • win7哪年停止更新
  • win10升级电脑
  • microsoft skypeapp
  • 怎么自己安装windows7
  • win8.1笔记本
  • Centos 6.5 64位双网卡绑定教程
  • 邮件传输过程中都使用哪些协议
  • 怎么看清水印
  • 微软星期二补丁
  • javascript数据结构与算法 pdf
  • js正则用法
  • jquery tagname
  • cocos2dx ActionManager播放动画回调问题
  • BUG: OpenGL error 0x0500 in -[CCEAGLView swapBuffers] 328
  • 怎么创建pom.xml
  • css下margin、padding、border、background和font缩写示例
  • jquery添加删除属性
  • ghost此应用无法在你的电脑上运行
  • 使用筷子就餐会不会传染乙肝病毒
  • Android中dip、dp、sp、pt和px的区别
  • jquery 动态添加元素
  • 12366纳税服务热线存在的问题
  • 关于工龄认定的司法解释
  • 税务u盘是干嘛的
  • 船舶税由谁代征
  • 政务公开事项目录编制
  • 资源税是什么?
  • 税务登录 河北省地方税务局
  • 销售税金含增值税怎么计算企业所得税
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

    网站地图: 企业信息 工商信息 财税知识 网络常识 编程技术

    友情链接: 武汉网站建设