2

我正在尝试一口气学习 Java 和子弹物理。一次做所有事情可能有点太多了,但我喜欢挑战。

到目前为止,我已经学会了如何导入 g3db 对象,将子弹物理应用到它们,并使用以下代码在屏幕上与它们交互:

assets = new AssetManager();
assets.load("globe.g3db", Model.class);
assets.load("crate.g3db", Model.class);
assets.finishLoading();

Model model = assets.get("globe.g3db", Model.class);
ModelInstance inst = new ModelInstance(model);
inst.transform.trn(0, 20, 0);

btRigidBody body;
btSphereShape sh = new btSphereShape(1);
sh.calculateLocalInertia(1, new Vector3(0,0,0));

body = new btRigidBody(new btRigidBody.btRigidBodyConstructionInfo(3, new btDefaultMotionState(inst.transform), sh));
body.setUserValue(Minstances.size);
body.proceedToTransform(inst.transform);

motionState = new MyMotionState();
motionState.transform = inst.transform;
body.setMotionState(motionState);

dynamicsWorld.addRigidBody(body );
Minstances.add(inst);

这很好用,如果我把它放在地上,它会掉下来停在地上,但是当它四处移动时,它会滑动而不是滚动。有简单的解决方法吗?

4

2 回答 2

2

要允许滚动物理体,您需要计算其局部惯性并将其提供给构造信息。在您的代码中,您几乎做对了。

方法

btCollisionShape.calculateLocalInertia(float mass, Vector3 inertia)

确实计算了局部惯性,但将其存储在第二个参数“Vector3惯性”中。不会对其自身应用任何更改btCollisionShape

获得惯性矢量后,您需要将其传递给

btRigidBodyConstructionInfo(float mass, btMotionState motionState, btCollisionShape collisionShape, Vector3 localInertia)

作为最后一个论点。

正确的代码应如下所示:

btRigidBody body;
btSphereShape sh = new btSphereShape(1);
Vector3 inertia = new Vector3(0,0,0);
sh.calculateLocalInertia(1, inertia);

body = new btRigidBody(new btRigidBody.btRigidBodyConstructionInfo(3, new btDefaultMotionState(inst.transform), sh, inertia));

执行模拟不需要局部惯性,但没有它,所有施加到物体上的力都被视为中心力,因此不会影响角速度。

于 2015-10-14T20:03:48.787 回答
0

您还需要读出并设置旋转,现在您只是在阅读\应用翻译。

创建一个新的四元数并获取 xyzw 值并将它们应用于您的对象。

像这样的东西(c++代码,但你可以在java中轻松地做同样的事情):

btTransform trans;
Quat myquat;
yourBulletDynamicObject->getMotionState()->getWorldTransform(trans);

btQuaternion rot = trans.getRotation();
myquat.w = rot.w();
myquat.x = rot.x();
myquat.y = rot.z();
myquat.z = rot.y();

将 myquat 重新设置在您的对象上。

于 2014-06-30T11:34:16.657 回答