首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >如何获得另一个UI界面的场景- Javafx 8

如何获得另一个UI界面的场景- Javafx 8
EN

Stack Overflow用户
提问于 2016-01-03 05:27:31
回答 1查看 971关注 0票数 0

我是JavafX的新手。我想通过第二个GUI来更改我的第一个GUI的CSS文件。

我有以下代码:

Main1.java

代码语言:javascript
复制
package javafxapplication3.a;

import javafx.application.Application;
import javafx.fxml.FXMLLoader;
import javafx.scene.Parent;
import javafx.scene.Scene;
import javafx.stage.Stage;

public class Main1 extends Application{

    public static void main(String[] args) {
        launch(args);
    }

    @Override
    public void start(Stage primaryStage) throws Exception {
        Parent root = null;
        try {
            root = FXMLLoader.load(getClass().getResource("/main1.fxml"));
        } catch (Exception e) {
        }

        String css = Main1.class.getResource("/main1.css").toExternalForm();
        Scene scene = new Scene(root, 400, 400);
        scene.getStylesheets().clear();
        scene.getStylesheets().add(css);
        primaryStage.setResizable(false);
        primaryStage.setScene(scene);
        primaryStage.setTitle("JCal");
        primaryStage.show();
    }

}

Main1Controller.java

代码语言:javascript
复制
package javafxapplication3.a;

import javafx.fxml.FXML;
import javafx.fxml.FXMLLoader;
import javafx.scene.Parent;
import javafx.scene.Scene;
import javafx.scene.control.Button;
import javafx.stage.Stage;

public class Main1Controller {

    @FXML
    private Button button1;

    public void initialize() {

        button1.setOnAction(value -> {
            Stage primaryStage = new Stage(); 
        Parent root = null;
        try {
            root = FXMLLoader.load(getClass().getResource("/main2.fxml"));
        } catch (Exception e) {
        }

        Scene scene = new Scene(root, 400, 400);
        primaryStage.setResizable(false);
        primaryStage.setScene(scene);
        primaryStage.setTitle("JCal");
        primaryStage.show();
        });

    }
}

main1.fxml

代码语言:javascript
复制
<AnchorPane maxHeight="-Infinity" maxWidth="-Infinity" minHeight="-Infinity" minWidth="-Infinity" prefHeight="400.0" prefWidth="600.0" xmlns="http://javafx.com/javafx/8.0.40" xmlns:fx="http://javafx.com/fxml/1" fx:controller="javafxapplication3.a.Main1Controller">
   <children>
      <Button fx:id="button1" layoutX="271.0" layoutY="173.0" mnemonicParsing="false" text="Main-1" />
   </children>
</AnchorPane>

main2.fxml

代码语言:javascript
复制
<AnchorPane maxHeight="-Infinity" maxWidth="-Infinity" minHeight="-Infinity" minWidth="-Infinity" prefHeight="400.0" prefWidth="600.0" xmlns="http://javafx.com/javafx/8.0.40" xmlns:fx="http://javafx.com/fxml/1" fx:controller="javafxapplication3.a.Main2Controller">
   <children>
      <Button fx:id="button" layoutX="271.0" layoutY="173.0" mnemonicParsing="false" text="Main-2" />
   </children>
</AnchorPane>

在FXML中,我有一个名为button1的按钮,当我单击它时,它会打开一个新的GUI,其中包含另一个名为button的按钮。最后,我想做的是,当我单击第二个按钮时,即button,主GUI中按钮的颜色应该会发生变化。

我确实尝试过获得this示例中显示的控制器,但这种能力对我有帮助。

我是否需要创建第二个控制器,一起创建一个新的舞台和场景?或者有什么别的办法吗?

EN

回答 1

Stack Overflow用户

发布于 2016-01-03 15:37:24

main2.fxml的控制器中,提供一种机制,用于设置按下按钮时要执行的操作。例如:

代码语言:javascript
复制
public class Main2Controller {

    @FXML
    private Button button ;

    private Runnable buttonAction = () -> {} ; // do nothing by default

    public void setButtonAction(Runnable action) {
        this.buttonAction = action ;
    }

    public void initialize() {
        button.setOnAction(e -> buttonAction.run());
    }
}

现在,在Main1Controller中,您可以在加载FXML时检索控制器,并设置按钮操作:

代码语言:javascript
复制
button1.setOnAction(value -> {
    Stage primaryStage = new Stage(); 
    Parent root = null;
    try {
        FXMLLoader loader = new FXMLLoader(getClass().getResource("/main2.fxml"));
        root = loader.load();
        Main2Controller controller = loader.getController();
        controller.setButtonAction(() -> {
            // perform button action here...
        });
    } catch (Exception e) {
        e.printStackTrace();
    }

    Scene scene = new Scene(root, 400, 400);
    primaryStage.setResizable(false);
    primaryStage.setScene(scene);
    primaryStage.setTitle("JCal");
    primaryStage.show();
});

另一种方法是让两个控制器都可以访问相同的可观测状态,例如ObjectProperty<Color>。如果在一个控制器中有许多操作影响其他地方的状态(只需将所有数据打包到一个您传递的“模型”类中),这种方法可能会更好。这看起来像是:

代码语言:javascript
复制
public class Main1Controller {

    private final ObjectProperty<Color> color = new SimpleObjectProperty<>();

    @FXML
    private Button button1;

    public void initialize() {

        color.addListener((obs, oldColor, newColor) -> {
            String style = String.format("-fx-background-color: #%02x%02x%02x;",
                (int) (newColor.getRed() * 255),
                (int) (newColor.getGreen() * 255),
                (int) (newColor.getBlue() * 255));
            button1.setStyle(style);
        });

        button1.setOnAction(value -> {
            Stage primaryStage = new Stage(); 
            Parent root = null;
        try {
            FXMLLoader loader = new FXMLLoader(getClass().getResource("/main2.fxml"));
            root = loader.load();
            Main2Controller controller = loader.getController();
            controller.setColorModel(color);
        } catch (Exception e) {
            e.printStackTrace();
        }

        Scene scene = new Scene(root, 400, 400);
        primaryStage.setResizable(false);
        primaryStage.setScene(scene);
        primaryStage.setTitle("JCal");
        primaryStage.show();
        });

    }
}

Main2Controller看起来就像

代码语言:javascript
复制
public class Main2Controller {

    @FXML
    private Button button ;

    private ObjectProperty<Color> colorModel = new SimpleObjectProperty<>();

    public void setColorModel(ObjectProperty<Color> color) {
        this.colorModel = color ;
    }


    public void initialize() {
        button.setOnAction(e -> {
            colorModel.set(/* some color */);
        });
    }
}
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/34573641

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档