JavaFX:在关键事件上更改 CSS PseudoClass
JavaFX: Change CSS PseudoClass on Key Event
我有一个按钮,当它被点击时会改变它的设计。 (根据 CSS)简单。
但我还想启用如果您按 ENTER 也应该按下的功能。这行得通,但我有一个伪 class,它将按钮的大小设置为 90% (.button:pressed
)。
问题:按回车键不生效。点击工作正常。 KeyTyped有没有css伪class?
CSS:
.button{
-fx-background-image: url("../resources/Game/cookie.png");
-fx-background-color: transparent;
}
.button:pressed{
-fx-background-size: 90%;
-fx-background-position: center;
}
提前谢谢你:)
您可以在按下 Enter 时显式添加伪class“pressed”,然后在释放时将其删除。
button.setOnKeyPressed(e -> {
if (e.getCode() == KeyCode.ENTER) {
button.pseudoClassStateChanged(PseudoClass.getPseudoClass("pressed"), true);
}
});
button.setOnKeyReleased(e -> {
if (e.getCode() == KeyCode.ENTER) {
button.pseudoClassStateChanged(PseudoClass.getPseudoClass("pressed"), false);
}
});
MCVE
import javafx.application.Application;
import javafx.css.PseudoClass;
import javafx.scene.Scene;
import javafx.scene.control.Button;
import javafx.scene.input.KeyCode;
import javafx.scene.layout.StackPane;
import javafx.stage.Stage;
public class Test extends Application {
@Override
public void start(Stage primaryStage) throws Exception {
Button button = new Button("Change Color");
button.setOnKeyPressed(e -> {
if (e.getCode() == KeyCode.ENTER) {
button.pseudoClassStateChanged(PseudoClass.getPseudoClass("pressed"), true);
}
});
button.setOnKeyReleased(e -> {
if (e.getCode() == KeyCode.ENTER) {
button.pseudoClassStateChanged(PseudoClass.getPseudoClass("pressed"), false);
}
});
StackPane stackPane = new StackPane(button);
Scene scene = new Scene(stackPane, 200, 200);
scene.getStylesheets().add(getClass().getResource("test.css").toExternalForm());
primaryStage.setScene(scene);
primaryStage.show();
}
public static void main(String[] args) {
Application.launch();
}
}
test.css
.button:pressed{
-fx-background-color: red;
}
我有一个按钮,当它被点击时会改变它的设计。 (根据 CSS)简单。
但我还想启用如果您按 ENTER 也应该按下的功能。这行得通,但我有一个伪 class,它将按钮的大小设置为 90% (.button:pressed
)。
问题:按回车键不生效。点击工作正常。 KeyTyped有没有css伪class?
CSS:
.button{
-fx-background-image: url("../resources/Game/cookie.png");
-fx-background-color: transparent;
}
.button:pressed{
-fx-background-size: 90%;
-fx-background-position: center;
}
提前谢谢你:)
您可以在按下 Enter 时显式添加伪class“pressed”,然后在释放时将其删除。
button.setOnKeyPressed(e -> {
if (e.getCode() == KeyCode.ENTER) {
button.pseudoClassStateChanged(PseudoClass.getPseudoClass("pressed"), true);
}
});
button.setOnKeyReleased(e -> {
if (e.getCode() == KeyCode.ENTER) {
button.pseudoClassStateChanged(PseudoClass.getPseudoClass("pressed"), false);
}
});
MCVE
import javafx.application.Application;
import javafx.css.PseudoClass;
import javafx.scene.Scene;
import javafx.scene.control.Button;
import javafx.scene.input.KeyCode;
import javafx.scene.layout.StackPane;
import javafx.stage.Stage;
public class Test extends Application {
@Override
public void start(Stage primaryStage) throws Exception {
Button button = new Button("Change Color");
button.setOnKeyPressed(e -> {
if (e.getCode() == KeyCode.ENTER) {
button.pseudoClassStateChanged(PseudoClass.getPseudoClass("pressed"), true);
}
});
button.setOnKeyReleased(e -> {
if (e.getCode() == KeyCode.ENTER) {
button.pseudoClassStateChanged(PseudoClass.getPseudoClass("pressed"), false);
}
});
StackPane stackPane = new StackPane(button);
Scene scene = new Scene(stackPane, 200, 200);
scene.getStylesheets().add(getClass().getResource("test.css").toExternalForm());
primaryStage.setScene(scene);
primaryStage.show();
}
public static void main(String[] args) {
Application.launch();
}
}
test.css
.button:pressed{
-fx-background-color: red;
}