0

我有一个应用程序可以创建一个减小大小的矩形,例如 10 秒的时间流逝,但是当我尝试缩小矩形时,窗口错误(场景中没有显示)并等到倒计时完成以停止窃听(然后显示未缩小的矩形)。我试图在互联网上找到相当于在 Swing 中重绘但不是平均的:/this.requestLayout() -> 我在互联网上找到了这个,但它不起作用。这是我的倒计时代码:

public class Compteur {

    DemoBorderPane p ;

    public DemoBorderPane getPan() {
        if(p==null) {
            p = new DemoBorderPane();
        }
        return p;
    }

    public Compteur() {

    }

    public void lancerCompteur() throws InterruptedException {


       int leTempsEnMillisecondes=1000;

        for (int i=5;i>=0;i--) {
            try {
                Thread.sleep (leTempsEnMillisecondes);
            } 
            catch (InterruptedException e) {
                System.out.print("erreur");
            }
            System.out.println(i);
            getPan().diminuerRect(35);
        }
    }
}

有我的 Borderpane 代码:

public class DemoBorderPane extends BorderPane {

    private Rectangle r;

    public Rectangle getRect() {
        if(r==null) {
            r = new Rectangle();
             r.setWidth(350);
                r.setHeight(100);
                r.setArcWidth(30);
                r.setArcHeight(30);
                r.setFill( //on remplie notre rectangle avec un dégradé
                        new LinearGradient(0f, 0f, 0f, 1f, true, CycleMethod.NO_CYCLE,
                            new Stop[] {
                                new Stop(0, Color.web("#333333")),
                                new Stop(1, Color.web("#000000"))
                            }
                        )
                    );
        }

        return r;
    }

    public void diminuerRect(int a) {
        getRect().setWidth(getRect().getWidth()-a);
        int c= (int) (getRect().getWidth()-a);
        System.out.println(c);
        this.requestLayout();
        //this.requestFocus();
    }


    public DemoBorderPane() {
        this.setBottom(getRect());

    }
}

有我的主要代码:

public class Main extends Application {
    private DemoBorderPane p;

    public DemoBorderPane getPan() {
        if(p==null) {
            p = new DemoBorderPane();
        }
        return p;
    }

    @Override
    public void start(Stage primaryStage) {
        Compteur c = new Compteur();
        try {

            //Group root = new Group();
            Scene scene = new Scene(getPan(),800,600);
            //scene.getStylesheets().add(getClass().getResource("application.css").toExternalForm());
            //root.getChildren().add(getPan());
            primaryStage.setScene(scene);
            primaryStage.show();



        } catch(Exception e) {
            e.printStackTrace();
        }

        try {
            c.lancerCompteur();
        } catch (InterruptedException e) {
            // TODO Auto-generated catch block
            e.printStackTrace();
        }
    }

    public static void main(String[] args) {

        launch(args);


        /*Son s = null;
        try {
            s = new Son();
        } catch (LineUnavailableException | IOException | UnsupportedAudioFileException e) {
            // TODO Auto-generated catch block
            e.printStackTrace();
        }
        s.volume(0.1);
        s.jouer();
        c.lancerCompteur();
        s.arreter();*/

    }
}

谢谢 ;)

4

1 回答 1

0

只要您保持 JavaFX 应用程序线程繁忙,它就无法执行布局/渲染。出于这个原因,确保在应用程序线程上运行的任何方法(例如Application.start输入事件上的事件处理程序)快速返回非常重要。

lancerCompteur但是阻塞应用程序线程 5 秒,因此您看到的唯一结果是方法完成后的最后一个结果。

一般来说,您可以在不同的线程上运行这样的代码并使用它Platform.runLater来更新 ui。

在这种情况下,您可以利用Timeline允许您在给定延迟后触发应用程序线程上的事件处理程序的类:

@Override
public void start(Stage primaryStage) {
    Scene scene = new Scene(getPan(), 800, 600);

    Timeline timeline = new Timeline(new KeyFrame(Duration.seconds(1), event -> {
        getPan().diminuerRect(35);
    }));
    timeline.setCycleCount(5);
    timeline.play();

    primaryStage.setScene(scene);
    primaryStage.show();
}

  • DemoBorderPane您还可以在您的Main班级和班级中使用不同的实例Compteur;场景中Rectangle显示的内容从未更新。
  • 没有必要打电话requestLayoutdiminuerRectRectangle' 的大小被修改时,这会自动发生。
  • 如果您确定在对象创建期间将调用 getter,那么延迟初始化是没有意义的。从它的构造函数调用,因此将初始化移动到构造函数将允许您在不影响功能DemoBorderPane.getRect的情况下摆脱检查。if
于 2018-03-11T10:50:18.147 回答