位置: 编程技术 - 正文

Bullet(Cocos2dx)之创建地形

编辑:rootadmin

推荐整理分享Bullet(Cocos2dx)之创建地形,希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:,内容如对您有帮助,希望把文章链接给更多的朋友!

Bullet提供了几个类btBvhTriangleMeshShape,btHeightfieldTerrainShape去创建一些网&#;图形,首先了解btHeightfieldTerrainShape,通过高度图数据创建一个3D地形。

A static mesh that is optimised for and described by the surface of a height map.

官网解释: info(, , _heightMapData.getBytes(), PHY_UCHAR, 1.6f / uData, -1.f, 1.f, btVector3(.f / uData, 1.f, .f / uData));

(uData为_heightMapData的最大&#;)

自定义数据生成高度地形图(PHY_FLOAT)

参数设置HeightfieldInfo info(, , mapData, PHY_FLOAT, 1.f, -1.f, 1.f, btVector3(1.f, 1.f, 1.f));

mapData自定义数据,随机0~1的数据

自定义数据生成高度地形图(PHY_FLOAT)

参数设置HeightfieldInfo info(, , mapData, PHY_SHORT, 1.f, -1.f, 1.f, btVector3(1.f, 1.f, 1.f));

mapData自定义数据0,1的数据

Bullet 自带的Demo中的例子

btHeightfieldTerrainShape 有两个构造函数,这里分析较复杂的一个

btHeightfieldTerrainShape(

int heightStickWidth, x轴总宽度

int heightStickLength, z轴总长度

比如 width = , length = 则x轴方向为,z轴方向为

const void* heightfieldData, 高度数据

btScalar heightScale, 每个字节*heightScale = 实际高度

btScalar minHeight, 最小高度

btScalar maxHeight, 最大高度

地形原点 = (minHeight &#; maxHeight) * 0.5

int upAxis, 方向轴 取&#; 0=x, 1=y, 2=z,决定地形的朝向,类&#;法向量

PHY_ScalarType heightDataType, 数据&#;式 3种, PHY_UCHAR, PHY_SHORT, PHY_FLOAT

bool flipQuadEdges 方形裁剪

);

举个例子

* 数据

for (int i=0; i<; &#;&#;i)

{

for (int j=0; j<; &#;&#;j)

{

heightMap[i*&#;j] = j % 2;

}

}

对于heightMap[i*&#;j]

1.如果为0, minHeight = 0.f, maxHeight = 6.f;

最低点正好为-3.f

2.如果为0, minHeight = 0.f, maxHeight = .f;

最低点正好为-6.f

3.如果为0, minHeight = 0.f, maxHeight = 3.f;

最低点正好为-1.5f

1.如果为2, minHeight = 0.f, maxHeight = 6.f;

最低点正好为-4.f

2.如果为2, minHeight = 0.f, maxHeight = .f;

最低点正好为-7.f

3.如果为2, minHeight = 0.f, maxHeight = 3.f;

最低点正好为-2.5f

地形偏移offsetY = -(minHeight &#; maxHeight);

不推荐minHeight &#; maxHeight < 0, 不稳定

heightScale * value(heightfieldData[i])为实际高度

高度计算:

对于PHY_UCHAR

最低点y = offsetY &#; min(heightfieldData); minY = 0

最高点y = offsetY &#; max(heightfieldData) * heightScale;

对于PHY_SHORT, PHY_FLOAT

Bullet(Cocos2dx)之创建地形

最高点y = offsetY &#; max(heightfieldData) * heightScale;

最低点y = offsetY &#; min(heightfieldData) * heightScale;

注意:

网&#;间隔不要过大,过大会出现物体穿过。

自定义数据类型简化参数传递

PhysicsWorld3D 创建高度地形图

下面来介绍btBvhTriangleMeshShape,通过载入三角网&#;,实现网&#;形状的物理模拟

看看效果

地形能够与模型完美的融合在一起,而且即使半径为0.1的球体也不会穿过地形

使用的shape就是btBvhTriangleMeshShape, 构造方法有两个

btBvhTriangleMeshShape(

btStridingMeshInterface* meshInterface, // 网&#;接口,存放网&#;数据

bool useQuantizedAabbCompression,// 压缩?只有buildBvh为true才有效

const btVector3& bvhAabbMin,

const btVector3& bvhAabbMax, // mesh不可超过bvhaabb包围盒,只有buildBvh为true才有效

bool buildBvh = true);// 优化BVH

btBvhTriangleMeshShape(

btStridingMeshInterface* meshInterface,

bool useQuantizedAabbCompression,

bool buildBvh = true);

通过导入一个模型的原始三角形数据,就可以建立上图的地形

如何载入模型数据,官网类关系图

提供btTriangleIndexVertexArray,载入网&#;数据

btTriangleIndexVertexArray(

int numTriangles, // 三角个数

int* triangleIndexBase, // 三角形索引数组首地址

int triangleIndexStride, // 每个三角形索引大小 = 索引类型大小 * 3

int numVertices, // 顶点个数

btScalar* vertexBase, // 顶点数组首地址

int vertexStride); // 每个顶点字节 = 顶点元素 * 3

既然索引类型为int,就用int

关于原始三角形数据如何得到,

1.可以利用cocos2dx的载入模型函数获取(有待实验)

2.利用Blender或者可以导出模型原始三角数据的软件,直接导出数据

关于Blender一款开源的3D建模软件,官网: , 自带游戏引擎,物理引擎就是Bullet

Blender raw 文件

导出三角形数据,Blender有个插件专门导出三角形数据 文件后缀名为raw,它是文本&#;式的,

导出时首先要让模型旋转一定角度,坐标系不是opengl的坐标系,cocos2dx采用的就是opengl的坐标系

raw文件&#;式非常简单:n行,每行9个浮点数据(描述一个三角形),每三个浮点为一个顶点

3.自定义&#;式

。。。。

来实现数据的载入吧

首先读取raw文件,实现一个简单的PhysicsHelper3D

并不是很难吧,载入文件办法不好,不过先将就着用吧

释放申请的内存

在PhysicsWorld3D建立一个添加Mesh的方法

测试

HelloWorld 添加变量

添加网&#;

onExit()不要忘了

为了方便测试, 实现了一个漫游摄像机,有空讲解一下。

完整源码及资源

github

Cocos2dx ParticleEditor粒子编辑器 下载地址:程序调用代码:(plist文件要和贴图在同一目录)//创建粒子对象CCParticleSystem*lizi=newCCParticleSystemQuad();//设置plist动画文件lizi-initWithFile(rain1.pli

cocos2dx3.2开发 RPG《Flighting》(三)从Excel表中加载需要的数据 一、前言在一个游戏里面,需要用到的数据一般都是由游戏策划提供的(这里的策划还是由我自己担任啦哈哈)。什么是需要用到的数据?例如我创建

cocos2dx3.2开发 RPG《Flighting》(四)预先加载与选人界面 一、前言假设你已经看懂了前面三节,那么接下来我们就开始进入真正的开发啦~~二、正文1、预先加载首先我们先谈谈预先加载,什么叫预先加载,就

标签: Bullet(Cocos2dx)之创建地形

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

上一篇:Cocos2dx CCLabelAtlas字体与CCLabelTTF字体的使用方法

下一篇:Cocos2dx ParticleEditor粒子编辑器

  • 进出口环节增值税计税基础
  • 捐赠支出纳税调减
  • 自产产品用于职工福利会计处理
  • 银行现金增加会计分录
  • 林业局会计咋样做账
  • 研发费用可以结转以后年度抵扣吗对吗
  • 货币形式投资的特点是
  • 欠缴税款的后果
  • 印花税的征税对象包括
  • 冲减利润怎么做账
  • 分支机构多预缴应该怎么退税呢?
  • 自然人纳税系统
  • 车辆一次性入费用会计分录
  • 会计代理服务是什么行业
  • 每月能领多少专利费
  • 稳岗补贴计入哪个科目
  • 租赁房租备案要多久
  • 企业所得税减免优惠政策
  • 软件的维修性要求
  • 我是小规模企业客户要求开专票不开投诉
  • 已抵扣发票红冲后发票还给对方公司
  • 增值税税负率计算器
  • 通讯费补贴如何领取
  • 小规模纳税人交企业所得税吗
  • 购车保险属于什么费用
  • 联营店铺收取的收入如何账务处理?
  • 材料未到,货款尚未支付
  • 电脑图标怎么在下面显示
  • win10无internet怎么解决
  • php实现的跟QQ和MSN类似的BICQ v2.0.0
  • 股权转让的条件和方式
  • 公司不经营了不注销可以吗
  • yii框架教程
  • 汇兑结算计入什么会计科目
  • 增值税核算应采用什么科目
  • php实现多语言切换
  • php的输出语句主要有哪些
  • Laravel+jQuery实现AJAX分页效果
  • bcdboot命令怎么用
  • 命令m文件
  • 上年科目记错如何更正
  • 其他应付款怎么做账
  • 帝国cms视频教程
  • 什么是代缴代扣
  • 保险业务手续费
  • 起重机属于固定资产中什么设备类型
  • 《中华人民共和国禁毒法》自( )起施行
  • 个人所得税的税率表最新的
  • 跨年发票能不能用
  • 劳务公司账务处理实例
  • 给供应商支付货款的付款申请由谁提出
  • 无形资产研究阶段发生的支出应该全部费用化
  • 农民扶贫款到哪去领
  • 维修费收入怎么结转销售成本
  • 建筑发票可以一次性抵扣吗
  • 为什么工程施工图纸不能泄露
  • 辅助生产成本应计入什么
  • 代扣代缴个人所得税分录
  • mac硬盘挂载软件
  • win8驱动在哪个文件夹
  • centos 6.6安装教程
  • window系统怎么截屏屏幕
  • win8系统谷歌浏览器打不开
  • 一键快速关机下载手机版
  • win 10预览版
  • cocos2d-x window实现鼠标移动 键盘事件
  • python 列表分片
  • unity3d怎么查看
  • 数据结构分析时间复杂度
  • 把下一行的数字去掉
  • shell去重计数
  • 两个Collider遮挡的解决办法
  • Eclipse和PyDev搭建完美Python开发环境教程(Windows篇)
  • js setimmediate
  • android简单项目及代码
  • 企业如何注册电子税务局账号
  • 上海个人所得税优惠政策
  • 税务局无编制人员工资
  • 徐州第三税务分局
  • 农民工12000要交多少个人所得税
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设