26

正如标题所说,我的问题是,如何防止/取消 JavaFX 2.2 中初级阶段的关闭?我对谷歌做了一些研究,以下两个链接似乎解决了这个问题:

我尝试了这两个链接解释的方法,但遗憾的是,它们都不起作用。所以,事不宜迟,这就是我所做的。

首先,我尝试将一个附加OnCloseRequestprimaryStage如下。

primaryStage.setOnCloseRequest(new EventHandler<WindowEvent>() {
    @Override
    public void handle(WindowEvent event) {
        if (!canExit()) {
            event.consume();
            primaryStage.show(); // I tried without this line also.
        }
    }
});

canExit()返回时,false我试图阻止事件进一步传播并通过调用来退出应用程序event.consume()。但是舞台正在关闭/隐藏,我在 Netbeans 输出窗口中收到以下错误消息。它不断出现,直到我从 Netbeans 强制关闭应用程序。

(java:6731): Gtk-CRITICAL **: IA__gtk_widget_get_visible: assertion `GTK_IS_WIDGET (widget)' failed

(java:6731): Gtk-CRITICAL **: IA__gtk_widget_get_visible: assertion `GTK_IS_WIDGET (widget)' failed

(java:6731): Gtk-CRITICAL **: IA__gtk_widget_get_visible: assertion `GTK_IS_WIDGET (widget)' failed

在这次尝试中尝到了失败的滋味,我改变OnCloseRequestOnHiding对成功的期望。

primaryStage.setOnHiding(new EventHandler<WindowEvent>() {
    @Override
    public void handle(WindowEvent event) {
        if (!canExit()) {
            event.consume();
            primaryStage.show(); // I tried without this line also.
        }
    }
});

虽然,我在这次尝试中也尝到了失败的滋味,但我想我已经取得了一些进展。这次没有错误消息,也不需要从 Netbeans 强制关闭应用程序。

然后我读到了一些setImplicitExit()Platform课堂上命名的魔法方法。认为这是我所缺少的,我尝试Platform.setImplicitExit(false);了两种方法,如下所示:

  1. OnCloseRequest版本

    Platform.setImplicitExit(false);
    
    primaryStage.setOnCloseRequest(new EventHandler<WindowEvent>() {
        if (!canExit()) {
            // ...
        } else {
            Platform.exit();
        }
    });
    

    没有区别,舞台被关闭/隐藏,并且重复出现相同的错误消息。

  2. OnHiding版本

    Platform.setImplicitExit(false);
    
    primaryStage.setOnHiding(new EventHandler<WindowEvent>() {
        if (!canExit()) {
            // ...
        } else {
            Platform.exit();
        }
    });
    

    从积极的一面开始,应用程序不会像之前那样退出。但是,不利的一面是舞台仍在关闭/隐藏。

现在,我的军械库中没有武器/装备来解决它,所以我在这里请求各位英雄和勇士的帮助。那么,我该如何解决这个问题或者我做错了什么或者我错过了什么?

4

4 回答 4

32

我在我的应用程序中使用了以下代码,它运行良好,

Platform.setImplicitExit(false);

primaryStage.setOnCloseRequest(new EventHandler<WindowEvent>() {
    @Override
    public void handle(WindowEvent event) {
        event.consume();
    }
});
于 2013-06-10T03:51:29.203 回答
3

我认为这是 JavaFX for Linux 的一个错误。我在 Javafx 2.2.21-b11 上遇到了同样的问题。根据上下文,GTK 错误可能存在也可能不存在,但是使用关闭请求事件的任何一种方式都不会阻止窗口关闭(但进程会继续运行)。Windows 上的同一个应用程序的行为与我预期的一样。因此,充其量我们在跨平台的行为上存在差异。

我提交了一个错误报告,如果你愿意,你可以投票:https ://javafx-jira.kenai.com/browse/RT-33295

这是我的测试应用程序的来源

import javafx.application.Application;
import javafx.event.EventHandler;
import javafx.stage.Stage;
import javafx.stage.WindowEvent;

public class Boom extends Application {
    @Override
    public void start(final Stage primary)  {
        System.out.println(com.sun.javafx.runtime.VersionInfo.getRuntimeVersion());
        primary.setOnCloseRequest(new EventHandler<WindowEvent>() {
            @Override
            public void handle(WindowEvent e) {
                e.consume();
            }
        });
        primary.show();
    }

    public static void main(String[] args) {
        launch(args);
    }
}
于 2013-10-01T19:46:29.223 回答
3

我想你理解onCloseRequest()错了。如果您消费该事件,您将取消关闭!所以它反过来工作,如果canExit()返回 false 你消耗事件

于 2013-06-09T06:07:52.000 回答
0

这对我有用

                stage.setOnCloseRequest(new EventHandler<WindowEvent>() {  
                    @Override
                    public void handle(WindowEvent event) {
                        AlertHelper addMore = new AlertHelper("Exit application? Any unsaved data will be lost", "Attention", "Confirmation Required");
                        boolean actionNeeded = addMore.populatePopup();
                        if (actionNeeded) {
                            System.exit(0);
                        } else {
                            event.consume();
                        }

                    }
                });
于 2019-01-19T14:52:23.630 回答