【发布时间】:2015-08-12 15:48:19
【问题描述】:
我正在尝试制作一个基于图块的简单移动系统,以便在按下方向时播放平移转换以平滑地将角色移动到一个图块上。我遇到的问题是,当我播放动画时,图像的过渡效果很好,但在过渡完成后,图像会跳到比预期更远的位置。如果我取出代码部分 onFinished 那么动画会完美播放,但之后按方向会导致图像从前一个位置而不是当前位置移动。
这里是代码
import javafx.animation.TranslateTransition;
import javafx.application.Application;
import javafx.scene.Group;
import javafx.scene.Scene;
import javafx.scene.image.Image;
import javafx.scene.image.ImageView;
import javafx.scene.paint.Color;
import javafx.stage.Stage;
import javafx.util.Duration;
public class ControlTranslateImage extends Application
{
final int STEP_SIZE = 64;
final Duration DURATION = Duration.millis(500);
Group player;
public static void main(String[] args)
{
launch(args);
}
@Override
public void start(Stage stage)
{
final ImageView image0 = new ImageView(new Image("http://opengameart.org/sites/default/files/styles/medium/public/slime_idle.gif"));
player = new Group(image0);
player.getChildren().setAll(image0);
final Scene scene = new Scene(player, 900, 600, Color.WHITE);
moveOnKeyPressed(scene, player);
stage.setScene(scene);
stage.show();
}
private void moveOnKeyPressed(Scene scene, Group player)
{
final TranslateTransition transition = new TranslateTransition(DURATION, player);
scene.setOnKeyPressed(e -> {
switch(e.getCode())
{
case UP:
{
transition.setFromX(player.getLayoutX());
transition.setFromY(player.getLayoutY());
transition.setToX(player.getLayoutX());
transition.setToY(player.getLayoutY() - STEP_SIZE);
transition.playFromStart();
transition.setOnFinished(t -> {
player.setLayoutX(player.getLayoutX());
player.setLayoutY(player.getLayoutY() - STEP_SIZE);
});
} break;
case DOWN:
{
transition.setFromX(player.getLayoutX());
transition.setFromY(player.getLayoutY());
transition.setToX(player.getLayoutX());
transition.setToY(player.getLayoutY() + STEP_SIZE);
transition.playFromStart();
transition.setOnFinished(t -> {
player.setLayoutX(player.getLayoutX());
player.setLayoutY(player.getLayoutY() + STEP_SIZE);
});
} break;
case LEFT:
{
transition.setFromX(player.getLayoutX());
transition.setFromY(player.getLayoutY());
transition.setToX(player.getLayoutX() - STEP_SIZE);
transition.setToY(player.getLayoutY());
transition.playFromStart();
transition.setOnFinished(t -> {
player.setLayoutX(player.getLayoutX() - STEP_SIZE);
player.setLayoutY(player.getLayoutY());
});
player.setLayoutX(player.getLayoutX() - STEP_SIZE);
player.setLayoutY(player.getLayoutY());
} break;
case RIGHT:
{
transition.setFromX(player.getLayoutX());
transition.setFromY(player.getLayoutY());
transition.setToX(player.getLayoutX() + STEP_SIZE);
transition.setToY(player.getLayoutY());
transition.playFromStart();
transition.setOnFinished(t -> {
player.setLayoutX(player.getLayoutX() + STEP_SIZE);
player.setLayoutY(player.getLayoutY());
});
} break;
default:break;
}
});
}
}
【问题讨论】:
-
A
TranslateTransition操纵translateX和translateY属性,而不是layoutX和layoutY属性。 -
完美解决,感谢 James
-
不要在您的问题中发布您的固定代码,而是 answer your own question 并将固定代码粘贴到那里。一段时间后,您可能会获得足够的声誉来标记您自己的答案正确。
标签: javafx transition move translate keyevent