位置: 编程技术 - 正文

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教程)

  • 异地预缴可以退吗
  • 年度部门决算报表系统路径
  • 代收代付保险费的差额可以放入营业外收入么
  • 加计抵减其他收益汇算清缴填哪里
  • 其他货币资金是资产类科目吗
  • 无偿代建政府公告
  • 个人给单位干的小工程需代扣个税吗?
  • 营改增后哪些费用可以抵扣
  • 金三打印客户端插件如何下载?
  • 一般纳税人运费计入什么科目
  • 项目资本金是什么意思大白话
  • 食堂购买的固定资产可以一次性加计扣除吗
  • 中途做账的企业如何建账
  • 网络直播应如何缴纳增值税?
  • 买保险公司的年金险划算吗
  • 营改增挂靠工程项目账务处理
  • 经营租赁的固定资产计提折旧吗
  • 1697508581
  • 外贸出口退税会计和会计区别
  • 有限合伙人的投资风险有哪些
  • 判决公告费应计入哪个科目?
  • 个体工商户怎样开发票
  • 坏账准备和资产减值损失
  • 工信部推出一键解绑怎么用
  • compaq-rba.exe是哪个方面的进程 作用是什么 compaq-rba进程查询
  • 企业扣除内容有哪些
  • 个人所得税扣缴申报啥意思
  • 自制原始凭证包括哪些凭证
  • 代理进口的增值税如何入账
  • 领用材料已抵扣进项税
  • PHP:imagecreatefromgif()的用法_GD库图像处理函数
  • laravel实战教程
  • 结转,结余
  • java上传文件 multipartfile
  • 一个简单的小实验
  • 公司租赁个人车辆账务处理
  • 计算工业总产值公式
  • 广告费支出税前扣除标准30
  • 个体户办营业执照有什么优点和缺点
  • 进项税额在借方是增加还是减少
  • 帝国cms自动推送插件
  • 小规模纳税人的个人所得税怎么算
  • sqlserver 中charindex/patindex/like 的比较
  • 实收资本变化
  • 小规模增值税为负数怎么报税
  • 原材料用于在建工程要进项转出吗
  • 费用报销冲抵借支
  • 材料成本多少合适
  • 手工账本应付账款怎么做
  • 饭店现金账怎么记账
  • 会计凭证数字书写模板
  • SQLServer2000 报1053错误(服务没有及时响应或控制请求)的解决方法
  • mysql数据库自动重启
  • unix系统复制命令
  • 操作系统与硬件之间的关系
  • windows崩溃后怎么修复
  • Win10 Insider 10565去除快捷方式小箭头的方法
  • windows十桌面
  • win10右下角弹出全屏截图
  • 手机上的安全模式是什么
  • win8开始界面如何设置成win7
  • 微软反盗xp黑屏怎么办
  • cocos2djs教程
  • ie11滚动条样式
  • nodejs child_process
  • linux命令行命令
  • android 动效
  • 如何得到pull解析器?
  • 网管系统怎么用
  • ip安全策略设置报错
  • python 执行远程代码
  • python爬虫过程
  • 深入探讨换个说法怎么说
  • js的设计模式有哪些
  • unity接收数据
  • css实现遮罩层
  • javascript总结
  • 对于初学者的鼓励
  • 税务上成品油换算
  • 增值税电子普通发票可以抵扣吗
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设