我试图使一个简单的平铺移动系统,以便当一个方向被按下一个平移过渡播放,以平稳地移动一个平铺的字符。我遇到的问题是,当我播放动画时,图像的过渡很好,但过渡完成后,图像跳到比预期更远的地方。如果我把代码的一部分拿出来完成,那么动画就会完美地播放,但在那之后按下方向会导致图像从以前的地方移动,而不是当前的位置。
这是代码
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;
}
});
}
}
固定代码
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);
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.getTranslateX());
transition.setFromY(player.getTranslateY());
transition.setToX(player.getTranslateX());
transition.setToY(player.getTranslateY() - STEP_SIZE);
transition.playFromStart();
} break;
case DOWN:
{
transition.setFromX(player.getTranslateX());
transition.setFromY(player.getTranslateY());
transition.setToX(player.getTranslateX());
transition.setToY(player.getTranslateY() + STEP_SIZE);
transition.playFromStart();
} break;
case LEFT:
{
transition.setFromX(player.getTranslateX());
transition.setFromY(player.getTranslateY());
transition.setToX(player.getTranslateX() - STEP_SIZE);
transition.setToY(player.getTranslateY());
transition.playFromStart();
} break;
case RIGHT:
{
transition.setFromX(player.getTranslateX());
transition.setFromY(player.getTranslateY());
transition.setToX(player.getTranslateX() + STEP_SIZE);
transition.setToY(player.getTranslateY());
transition.playFromStart();
} break;
default:break;
}
});
}
}
问题内容: 我正在尝试创建一个简单游戏的开始。我要做的第一件事是将图形导入到我的代码中,然后在屏幕上移动它。我能够在屏幕上画一个球并四处移动,但是当我从文件导入图形时,无法四处移动。我想念什么或做错什么? 我的司机是在另一个班级,如下所示: 问题答案: 这里有两个大问题: 您正在从中读取文件。 永远 不要这样做,因为这会不必要地减慢绘图速度。可能在构造函数中读取一次图像,然后在图形中使用存储的im
我试图移动这个图像: 在我的PyGame屏幕上,从右到左再向后,但是随着图像的移动,每隔一秒左右我就会有一点屏幕撕裂,就像这样: 我使用的代码是类似于此的循环: 到目前为止,我已经尝试了以下方法来解决这个问题: 在创建屏幕时使用,,标志,这没有效果,我也调整了更新为(因为使用?)时建议使用此选项) 在GPU和CPU之间拆分内存(我在raspberry pi 2上运行此功能)我尝试过为这两个处理器提
本文向大家介绍Android实现在屏幕上移动图片的方法,包括了Android实现在屏幕上移动图片的方法的使用技巧和注意事项,需要的朋友参考一下 本文实例讲述了Android实现在屏幕上移动图片的方法。分享给大家供大家参考。具体实现方法如下: 1. Speed.java文件: 2. main.java文件: 希望本文所述对大家的Android程序设计有所帮助。
我制作了一个闪屏,效果非常好,直到我添加了图片。图像不会出现,我复制了与图片完全相同的代码,并将其放在主活动xml中,它成功了。 我可以在设计和蓝图中看到图片,但在我的手机上看不到 splash_activity.xml 喷溅活动。JAVA 我曾尝试将更改为,但在设计中甚至无法显示图片。
问题内容: 我有一个使用react native创建的登录屏幕。 当用户输入textInput时,如何将屏幕上移? 我是否要监听onFocus()事件并使用css样式来更改视图? 问题答案: 在2017年(RN 0.43),这方面有特殊的组成部分: KeyboardAvoidingView
我试图根据用户输入的坐标捕捉区域截图。基本上,用户在屏幕上点击得到x,y坐标,然后在其他地方点击另一对x,y坐标,然后将其放入一个矩形中,并使用机器人库创建屏幕截图。 我有的问题是,我得到了随机截图,这不是用户输入的坐标,我怎么能考虑包括0的坐标,因为矩形值必须超过1。 以下是我迄今为止的代码: