为了账号安全,请及时绑定邮箱和手机立即绑定

在一个函数中两次更改按钮背景

在一个函数中两次更改按钮背景

长风秋雁 2022-12-21 15:22:03
我正在尝试在 javaFX 中做“memoryGame”。我现在正在处理的是在单击此按钮后,使用 CSS 在一个函数中更改按钮的背景两次。在这个游戏中,我创建了一个 GridPane 并在每个单元格中放置了带有图片的按钮,每张图片都有两个按钮。在它上面我放了另一个空按钮。如果我点击一个按钮,它会变成透明的,所以我可以看到图片。然后我点击了另一个按钮,同样的事情发生了。现在,如果图片相同,我会得到一分,透明度不会改变,但如果图片不同,程序会等待一秒钟,然后将两个按钮都更改为它们的主要阶段(不透明)。问题是,如果我更改按钮的样式,请稍等一下,然后再更改一次,按钮在此功能期间不会更改其样式,但会在功能结束后发生。所以我们看不到第一个样式,只能看到最后一个。我发送的代码是简化版本,仅对一个按钮“有效”。public void changeTransparent(ActionEvent event) {        butCver01.setStyle("-fx-background-color: transparent");        try {            Thread.sleep(1000);        } catch (InterruptedException e) {}        butCver01.setStyle("-fx-background-color: green");    }现在,当我们单击 butCver01 时,一秒钟后它将变为绿色。
查看完整描述

1 回答

?
千巷猫影

TA贡献1829条经验 获得超7个赞

正如我在评论中提到的,JavaFX 应用程序线程无法在仍在执行您的方法时安排下一帧渲染(即“脉冲”)。您使用Thread.sleepwhich阻塞FX 线程意味着它不能做任何事情,更不用说安排下一个脉冲了。被阻止的 FX 线程等于冻结的 UI,您的用户将无法点击更多卡片来尝试获得匹配。


您应该使用动画 API在 FX 线程上“随时间”执行操作。动画是“异步”执行的(在 FX 线程上),这意味着可以在动画运行时处理其他动作。启动动画的调用也会立即返回。这是一个示例,该示例将在一秒钟内显示矩形下方的形状;但是,没有逻辑来确定是否显示了两个匹配的形状,一次只显示了两个形状,等等。


import javafx.animation.PauseTransition;

import javafx.application.Application;

import javafx.geometry.Insets;

import javafx.scene.Scene;

import javafx.scene.layout.HBox;

import javafx.scene.layout.StackPane;

import javafx.scene.paint.Color;

import javafx.scene.shape.Circle;

import javafx.scene.shape.Polygon;

import javafx.scene.shape.Rectangle;

import javafx.scene.shape.Shape;

import javafx.stage.Stage;

import javafx.util.Duration;


public class Main extends Application {


    @Override

    public void start(Stage primaryStage) {

        HBox box = new HBox(10, createCard(true), createCard(true), createCard(false));

        box.setPadding(new Insets(100));

        primaryStage.setScene(new Scene(box));

        primaryStage.show();

    }


    private StackPane createCard(boolean circle) {

        Shape shape;

        if (circle) {

            shape = new Circle(50, Color.FORESTGREEN);

        } else {

            // create triangle

            shape = new Polygon(0, 0, 50, 100, -50, 100);

            shape.setFill(Color.FIREBRICK);

        }


        Rectangle cover = new Rectangle(0, 0, 100, 150);

        cover.mouseTransparentProperty()

                .bind(cover.fillProperty().isEqualTo(Color.TRANSPARENT));

        cover.setOnMouseClicked(event -> {

            event.consume();


            cover.setFill(Color.TRANSPARENT);


            PauseTransition pt = new PauseTransition(Duration.seconds(1));

            pt.setOnFinished(e -> cover.setFill(Color.BLACK));

            pt.playFromStart();

        });

        return new StackPane(shape, cover);

    }


}


查看完整回答
反对 回复 2022-12-21
  • 1 回答
  • 0 关注
  • 65 浏览

添加回答

举报

0/150
提交
取消
意见反馈 帮助中心 APP下载
官方微信