在方法内更新JavaFX舞台。

huangapple go评论98阅读模式
英文:

Update JavaFX stage within method

问题

  1. 我正在编写一个程序需要使用大量数据进行多次计算而且需要一段时间才能完成这就是为什么我想要更新并通知用户程序当前已完成的百分比但是我不知道如何在计算方法内部更新阶段
  2. public void calculate() {
  3. // 在这里我想要更改“百分比文本”
  4. // 并更新舞台。
  5. }
英文:

I am writing a program that uses a lot of data to do several calculations and it takes quite a while to finish. This is why I want to update and inform the user on the current percentage of the program being done. However I don't know how I can update the stage within the calculation method.

  1. import javafx.application.Application;
  2. import javafx.event.ActionEvent;
  3. import javafx.event.EventHandler;
  4. import javafx.geometry.Insets;
  5. import javafx.scene.Scene;
  6. import javafx.scene.control.Button;
  7. import javafx.scene.layout.GridPane;
  8. import javafx.scene.layout.Pane;
  9. import javafx.scene.layout.VBox;
  10. import javafx.scene.text.Text;
  11. import javafx.stage.Stage;
  12. public class Main extends Application {
  13. public void calculate() {
  14. //Here I want to change the "percentage text"
  15. //and update the stage.
  16. }
  17. @Override
  18. public void start(Stage primaryStage) {
  19. primaryStage.setTitle("Hello World!");
  20. Text percentage = new Text();
  21. Button btn = new Button();
  22. btn.setText("Say 'Hello World'");
  23. btn.setOnAction(new EventHandler<ActionEvent>() {
  24. @Override
  25. public void handle(ActionEvent event) {
  26. calculate();
  27. }
  28. });
  29. final GridPane inputGridPane = new GridPane();
  30. GridPane.setConstraints(btn, 0, 0);
  31. GridPane.setConstraints(percentage, 1, 0);
  32. inputGridPane.setHgap(6);
  33. inputGridPane.setVgap(6);
  34. inputGridPane.getChildren().addAll(btn, percentage);
  35. final Pane rootGroup = new VBox(12);
  36. rootGroup.setPrefWidth(400);
  37. rootGroup.setPrefHeight(225);
  38. rootGroup.getChildren().addAll(inputGridPane);
  39. rootGroup.setPadding(new Insets(12,12,12,12));
  40. primaryStage.setScene(new Scene(rootGroup));
  41. primaryStage.show();
  42. }
  43. public static void main(String[] args) {
  44. launch(args);
  45. }
  46. }

This is what my code roughly looks like. Thank you in advance.

答案1

得分: 0

JavaFx提供了一个名为"Task<v>"的类,可以用于在后台进行计算并保持进度同步!

我建议这样做:

创建一个继承Task<v>的第二个类来执行重计算:

  1. import javafx.concurrent.Task;
  2. public class CalculationTask extends Task&lt;String&gt; {
  3. @Override
  4. protected String call() throws Exception {
  5. for (int i = 0; i &lt; 100000000;i++) {
  6. updateProgress(i, 100000000);
  7. }
  8. succeeded();
  9. return "这是计算的结果... 如果你在计算数字,数据类型可以通过泛型进行更改";
  10. }
  11. }

这是在应用程序类中如何使用它的一种方式:

  1. import javafx.application.Application;
  2. import javafx.concurrent.Task;
  3. import javafx.concurrent.WorkerStateEvent;
  4. import javafx.event.ActionEvent;
  5. import javafx.event.EventHandler;
  6. import javafx.geometry.Insets;
  7. import javafx.scene.Scene;
  8. import javafx.scene.control.Alert;
  9. import javafx.scene.control.Button;
  10. import javafx.scene.control.ProgressBar;
  11. import javafx.scene.layout.GridPane;
  12. import javafx.scene.layout.Pane;
  13. import javafx.scene.layout.VBox;
  14. import javafx.stage.Stage;
  15. public class Main extends Application {
  16. @Override
  17. public void start(Stage primaryStage) {
  18. primaryStage.setTitle("Hello World!");
  19. Button btn = new Button();
  20. btn.setText("Say 'Hello World'");
  21. Task&lt;String&gt; calculationTask = new CalculationTask();
  22. ProgressBar progressBar = new ProgressBar(); //ProgressIndicator could also be used
  23. progressBar.progressProperty().bind(calculationTask.progressProperty());
  24. progressBar.visibleProperty().bind(calculationTask.runningProperty());
  25. btn.setOnAction(new EventHandler&lt;ActionEvent&gt;() {
  26. @Override
  27. public void handle(ActionEvent event) {
  28. calculationTask.setOnSucceeded(new EventHandler&lt;WorkerStateEvent&gt;() {
  29. @Override
  30. public void handle(WorkerStateEvent workerStateEvent) {
  31. new Alert(Alert.AlertType.CONFIRMATION, calculationTask.getValue()).show();
  32. }
  33. });
  34. new Thread(calculationTask).start();
  35. }
  36. });
  37. final GridPane inputGridPane = new GridPane();
  38. GridPane.setConstraints(btn, 0, 0);
  39. GridPane.setConstraints(progressBar, 1, 0);
  40. inputGridPane.setHgap(6);
  41. inputGridPane.setVgap(6);
  42. inputGridPane.getChildren().addAll(btn, progressBar);
  43. final Pane rootGroup = new VBox(12);
  44. rootGroup.setPrefWidth(400);
  45. rootGroup.setPrefHeight(225);
  46. rootGroup.getChildren().addAll(inputGridPane);
  47. rootGroup.setPadding(new Insets(12,12,12,12));
  48. primaryStage.setScene(new Scene(rootGroup));
  49. primaryStage.show();
  50. }
  51. public static void main(String[] args) {
  52. launch(args);
  53. }
  54. }

希望这有所帮助,否则请随时提问!

英文:

JavaFx provides a class called "Task<v>" which can be used for background calculations while keeping the progression syncronised!

I would suggest doing it that way:

Create a second class extending Task<v> for doing the heavy calculation:

  1. import javafx.concurrent.Task;
  2. public class CalculationTask extends Task&lt;String&gt; {
  3. @Override
  4. protected String call() throws Exception {
  5. for (int i = 0; i &lt; 100000000;i++) {
  6. updateProgress(i, 100000000);
  7. }
  8. succeeded();
  9. return &quot;This is the computed result... Datatype can be changed by generics if you are calculation numbers&quot;;
  10. }
  11. }

This is one way how you could use it in your application class:

  1. import javafx.application.Application;
  2. import javafx.concurrent.Task;
  3. import javafx.concurrent.WorkerStateEvent;
  4. import javafx.event.ActionEvent;
  5. import javafx.event.EventHandler;
  6. import javafx.geometry.Insets;
  7. import javafx.scene.Scene;
  8. import javafx.scene.control.Alert;
  9. import javafx.scene.control.Button;
  10. import javafx.scene.control.Dialog;
  11. import javafx.scene.control.ProgressBar;
  12. import javafx.scene.layout.GridPane;
  13. import javafx.scene.layout.Pane;
  14. import javafx.scene.layout.VBox;
  15. import javafx.scene.text.Text;
  16. import javafx.stage.Stage;
  17. public class Main extends Application {
  18. @Override
  19. public void start(Stage primaryStage) {
  20. primaryStage.setTitle(&quot;Hello World!&quot;);
  21. Button btn = new Button();
  22. btn.setText(&quot;Say &#39;Hello World&#39;&quot;);
  23. Task&lt;String&gt; calculationTask = new CalculationTask();
  24. ProgressBar progressBar = new ProgressBar(); //ProgressIndicator could also be used
  25. progressBar.progressProperty().bind(calculationTask.progressProperty());
  26. progressBar.visibleProperty().bind(calculationTask.runningProperty());
  27. btn.setOnAction(new EventHandler&lt;ActionEvent&gt;() {
  28. @Override
  29. public void handle(ActionEvent event) {
  30. calculationTask.setOnSucceeded(new EventHandler&lt;WorkerStateEvent&gt;() {
  31. @Override
  32. public void handle(WorkerStateEvent workerStateEvent) {
  33. new Alert(Alert.AlertType.CONFIRMATION, calculationTask.getValue()).show();
  34. }
  35. });
  36. new Thread(calculationTask).start();
  37. }
  38. });
  39. final GridPane inputGridPane = new GridPane();
  40. GridPane.setConstraints(btn, 0, 0);
  41. GridPane.setConstraints(progressBar, 1, 0);
  42. inputGridPane.setHgap(6);
  43. inputGridPane.setVgap(6);
  44. inputGridPane.getChildren().addAll(btn, progressBar);
  45. final Pane rootGroup = new VBox(12);
  46. rootGroup.setPrefWidth(400);
  47. rootGroup.setPrefHeight(225);
  48. rootGroup.getChildren().addAll(inputGridPane);
  49. rootGroup.setPadding(new Insets(12,12,12,12));
  50. primaryStage.setScene(new Scene(rootGroup));
  51. primaryStage.show();
  52. }
  53. public static void main(String[] args) {
  54. launch(args);
  55. }
  56. }

I hope that helped, otherwise feel free to ask questions!

huangapple
  • 本文由 发表于 2020年7月22日 17:25:46
  • 转载请务必保留本文链接:https://go.coder-hub.com/63031026.html
匿名

发表评论

匿名网友

:?: :razz: :sad: :evil: :!: :smile: :oops: :grin: :eek: :shock: :???: :cool: :lol: :mad: :twisted: :roll: :wink: :idea: :arrow: :neutral: :cry: :mrgreen:

确定