首页 > 解决方案 > KeyEvent更改照片不起作用,如何激活它?

问题描述

我想使用imageView和keyEvent来切换照片程序,但是当我尝试使用keyEvent时它不​​起作用,我正在尝试添加scene.getRoot().requestFocus(); 但没有帮助,所以我的问题是,为什么它不起作用我怎么能激活它?

MenuScreenController.java

    @FXML
public void getNewImageHandler(KeyEvent event) {
    System.out.println(singleFile.getName());
    imgFieldView.setOnKeyPressed(e -> {
        if (e.getCode() == KeyCode.N) {
            photoSwipCounter++;
            System.out.println("P clicked");
        } else if (e.getCode() == KeyCode.P) {
            photoSwipCounter--;
        }
    });

//        if (event.getCode().equals(KeyCode.N)) {
//            photoSwipCounter++;
//        }
//        if (event.getCode().equals(KeyCode.P)) {
//            photoSwipCounter--;
//        }

    if (photoSwipCounter < 0) {
        singleFile = selectedImgsList.get(selectedImgsList.size() - photoSwipCounter);
    } else {
        singleFile = selectedImgsList.get(photoSwipCounter);
    }

    image = new Image(singleFile.toURI().toString(),
            900, 400,
            true, true, true);
    imgFieldView.setImage(image);
}

正如你所看到的,我尝试了很多方法,通过流或经典,但它并没有做出改变。

菜单屏幕.fxml

<Pane fx:id="menuPane" maxHeight="-Infinity" maxWidth="-Infinity" minHeight="-Infinity" minWidth="-Infinity" prefHeight="700.0" prefWidth="1000.0" xmlns="http://javafx.com/javafx/8.0.171" xmlns:fx="http://javafx.com/fxml/1" fx:controller="screensaverfxml.Controllers.MenuScreenController">
   <children>
      <ImageView fx:id="imgFieldView" fitHeight="400.0" fitWidth="900.0" layoutX="66.0" layoutY="62.0" onKeyPressed="#getNewImageHandler" onMouseClicked="#imgDoubleClick" pickOnBounds="true" preserveRatio="true" />
   </children>
</Pane>

ScreenSaverFXML.java

    @Override
public void start(Stage primaryStage) throws Exception {
    FXMLLoader loader = new FXMLLoader(this.getClass().getResource("/screensaverfxml/fxmlConfig/MainScreen.fxml"));
    Pane mainPane = loader.load();
    Scene scene = new Scene(mainPane, 1000, 700);
    primaryStage.setScene(scene);
    primaryStage.setTitle("Screen Saver");

    primaryStage.show();

   scene.getRoot().requestFocus();
}

而且我有方法在 imageView 上加载第一张照片,它可以通过将它从文件夹加载到列表来工作,但是切换到下一个 nope

标签: javajavafxfxmlkeyevent

解决方案


只有具有焦点的节点才会接收关键事件。既然你有scene.getRoot().requestFocus()它是接收事件的根。但是,您正在添加EventHandlertoimgFieldView并且由于该节点是根的后代,因此它永远不会看到任何关键事件。您需要imgFieldView获得焦点或将处理程序添加到根节点。

注意:只有当目标NodeScene.

另一个问题是您imgFieldView.setOnKeyPressed(...)getNewImageHandler方法中调用。当您通过 FXML 添加事件处理程序时,例如使用onKeyPressed="#getNewImageHandler",它会设置节点的相应onXXX属性。在您的情况下,它正在设置onKeyPressed. imgFieldView但是,在该处理程序中,您还设置了替换由FXMLLoader. 您的新处理程序只是增加或减少该photoSwipeCounter字段,但对新值不做任何事情。您的方法应该看起来更像:

@FXML
public void getNewImageHandler(KeyEvent event) {
    if (event.getCode().equals(KeyCode.N)) {
        photoSwipeCounter++;
    }
    if (event.getCode().equals(KeyCode.P)) {
        photoSwipeCounter--;
    }

    // wrap around logic
    if (photoSwipeCounter < 0) {
        photoSwipeCounter = selectedImgsList.size() - 1;
    } else if (photoSwipeCounter >= selectedImgsList.size()) {
        photoSwipeCounter = 0;
    }

    singleFile = selectedImgsList.get(photoSwipeCounter);

    image = new Image(singleFile.toURI().toString(),
            900, 400,
            true, true, true);
    imgFieldView.setImage(image);
}

推荐阅读