我真的需要一些帮助,我被卡住了。我试图在一个简单的游戏中让一个方块成为地面,另一个方块落在上面,然后可能会反弹一点,但是能够向左或向右移动盒子,从第一个方块上掉下来。有人能帮我吗?
对于任何对答案感兴趣的人,感谢PoprostuRonin和dermetfan的YouTube视频,我能够得到我正在寻找的结果,你可以在你的项目中尝试下面的代码,只需更改精灵纹理。
private Box2DDebugRenderer debugRenderer;
private OrthographicCamera camera;
private float spriteSpeed = 500000;
private World world;
private Sprite playersprite;
private Sprite groundsprite;
private Body playerBody;
private Body groundbody;
private Vector2 movement = new Vector2();
private Array<Body> tmpBodies = new Array<Body>();
public TestState(GameStateManager gsm) {
super(gsm);
Gdx.input.setInputProcessor(this);
batch = new SpriteBatch();
debugRenderer = new Box2DDebugRenderer();
camera = new OrthographicCamera();
// Sprites
playersprite = new Sprite(new Texture("badlogic.jpg"));
groundsprite = new Sprite(new Texture("ground-tiles-01.gif"));
// World
world = new World(new Vector2(0, -9.8f), true);
// Player Sprite
// Body definition
BodyDef bodyDef = new BodyDef();
bodyDef.type = BodyType.DynamicBody;
bodyDef.position.set(0, 200); //1m
PolygonShape shape = new PolygonShape();
shape.setAsBox(10, 10);
// Fixture definition
FixtureDef fixtureDef = new FixtureDef();
fixtureDef.shape = shape;
fixtureDef.density = 2.5f; //2.5kg
fixtureDef.friction = 0; //0-1
fixtureDef.restitution = .75f; //0-1
playerBody = world.createBody(bodyDef);
playerBody.createFixture(fixtureDef);
playerBody.setUserData(playersprite);
playersprite.setSize(20, 20);
playersprite.setOrigin(playersprite.getWidth() / 2, playersprite.getHeight() / 2);
shape.dispose();
// Ground Sprite
// Body definition
BodyDef groundbodyDef = new BodyDef();
groundbodyDef.type = BodyType.StaticBody;
groundbodyDef.position.set(0, 0); //1m
PolygonShape groundshape = new PolygonShape();
groundshape.setAsBox(groundsprite.getHeight() / 2, groundsprite.getWidth() / 2);
// Fixture definition
FixtureDef groundfixtureDef = new FixtureDef();
groundfixtureDef.shape = groundshape;
groundfixtureDef.density = 100; //2.5kg
groundfixtureDef.friction = .25f; //0-1
groundfixtureDef.restitution = 0; //0-1
groundbody = world.createBody(groundbodyDef);
groundbody.createFixture(groundfixtureDef);
groundbody.setUserData(groundsprite);
groundsprite.setSize(groundsprite.getHeight(), groundsprite.getWidth());
groundsprite.setOrigin(groundsprite.getWidth() / 2, groundsprite.getHeight() / 2);
groundshape.dispose();
}
@Override
public void update(float delta) {
camera.viewportWidth = Gdx.graphics.getWidth();
camera.viewportHeight = Gdx.graphics.getHeight();
}
@Override
public void render() {
Gdx.gl.glClearColor(50 / 255f, 213 / 255f, 237 / 255f, 1);
Gdx.gl.glClear(GL20.GL_COLOR_BUFFER_BIT);
debugRenderer.render(world, camera.combined);
batch.setProjectionMatrix(camera.combined);
world.step(Gdx.graphics.getDeltaTime(), 6, 2);
playerBody.applyForceToCenter(movement, true);
batch.begin();
world.getBodies(tmpBodies);
for (Body body : tmpBodies){
if (body.getUserData() != null && body.getUserData() instanceof Sprite) {
Sprite sprite = (Sprite) body.getUserData();
sprite.setPosition(body.getPosition().x - sprite.getWidth() / 2, body.getPosition().y - sprite.getHeight() / 2);
sprite.setRotation(body.getAngle() * MathUtils.radiansToDegrees);
sprite.draw(batch);
}
}
batch.end();
camera.position.set(playerBody.getPosition().x, playerBody.getPosition().y, 0);
camera.update();
}
@Override
public void dispose() {
world.dispose();
playersprite.getTexture().dispose();
groundsprite.getTexture().dispose();
}
@Override
public boolean keyDown(int keycode) {
switch (keycode) {
case Keys.DPAD_LEFT:
movement.x = -spriteSpeed;
break;
case Keys.DPAD_RIGHT:
movement.x = spriteSpeed;
break;
case Keys.DPAD_UP:
movement.y = spriteSpeed;
break;
case Keys.DPAD_DOWN:
movement.y = -spriteSpeed;
}
return true;
}
@Override
public boolean keyUp(int keycode) {
switch (keycode) {
case Keys.DPAD_LEFT:
case Keys.DPAD_RIGHT:
movement.x = 0;
break;
case Keys.DPAD_UP:
case Keys.DPAD_DOWN:
movement.y = 0;
}
return true;
}
你的代码是有效的,问题是数字。
你身体的质量很大,20480公斤。重力是颠倒的,因为你要求它:
world = new World(new Vector2(0, -1000f), true);
-1000,它低于0,所以它是倒置的,大数字(1000在你的“星球”上,9.8在地球上)导致对象不太可控。
更改值:
float spriteSpeed = 60000;
...
world = new World(new Vector2(0, 9.8F), true);
...
fixtureDef.density = 1;
fixtureDef2.density = 1;
你会注意到现在身体是可控的(它甚至可以飞)。玩这些数字,学习一些基本的物理规则,知道你在做什么。
精灵和身体位置已同步,但未正确对齐。使用此代码进行第一步,使纹理与身体对齐。
sprite.setCenter(body.getPosition().x, body.getPosition().y);
groundsprite.setCenter(ground.getPosition().x, ground.getPosition().y);
但是旋转呢
groundsprite.setOriginCenter();
sprite.setOriginCenter();
groundsprite.setRotation(ground.getAngle() * MathUtils.radDeg);
sprite.setRotation(body.getAngle() * MathUtils.radDeg);
这很简单,因为您的对象是单一纹理,我们可以简单地将其在中心对齐,但随着对象变得更复杂,需要更改代码。
如果我不知道一个物体的深度,我如何移除另一个物体内部的一个物体? json对象 假设我想删除“4”,但是“4”可能是第一级孩子或者在另一个孩子里面?
我正在使用Selenium 2.0为我的Google Chrome扩展创建自动化测试,其中包括: WebDriverJS+NodeJS ChromeDriver MacOSX 10.8.4 首先,我也想测试安装过程,但是当使用Selenium弹出安装对话框时,似乎不可能单击“Add”按钮。(我对此的另一个问题)。
所以我在做一个程序,在这里你可以有两个对象(圆)。我希望它们像行星一样围绕彼此运行,但只能是二维的。 我知道用牛顿万有引力定律,我可以得到两个物体之间的力。我也知道A=F/m,我的问题是我如何从前面的方程中得到A并把它变成一个向量?
我想让我的Apache Camel应用程序更具弹性,即使无法访问MQTT代理,也可以启动它。我们正在物联网设备上使用Camel,其互联网连接可能不稳定,我希望我们的应用程序即使没有互联网接入也能启动。 示例性路线如下所示: 只要MQTT服务器可用,这就可以正常工作。但是,当无法访问服务器时,上下文会在预热PahoEndpoint时失败。 我的第一个想法是在所有涉及Paho的路线上禁用自动启动,然后
在Spring Boot中,文档似乎鼓励在应用程序启动时运行迁移。 这很好,但有时应用程序启动可能会有副作用/依赖性,我不想麻烦-我只想自己运行迁移。设想一下,只需建立一个本地开发人员数据库,就可以在其中闲逛,甚至不用运行应用程序。 相比之下,在Dropwanner中,单独运行迁移对于应用程序的内置参数来说很简单,就像这样 Spring靴有什么等价物吗?还是我必须直接去喝liquibase? 我对
我观察球体在场景中的行为。当施加力(或设定速度)时,球体会瞬间向右侧跳出远距离,然后缓慢地向后(向左)移动到其先前设定的位置(0,1,0)。我能看见它穿过墙。 现在我的问题是: > 为什么它向右跳(而不是移动)?我玩过冲量和速度的大小,但总是一样的。 我想要达到的行为是,在施加力后,球在我的盒子里反弹,根据物理设置。 有什么想法吗?多谢了。