【问题标题】:JavaFX Changing the Global Stylesheet from Document ControllerJavaFX 从文档控制器更改全局样式表
【发布时间】:2017-05-23 07:54:58
【问题描述】:

我是 JavaFX 新手,目前正在开发 JavaFXML 应用程序。我想做的是找到一种方法来在我单击按钮时更改全局样式表。我当前的代码是这个..

Main.Java

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

    public class CssChange extends Application {

    static FXMLDocumentController myControllerHandle;

    @Override
    public void start(Stage stage) throws Exception {
    FXMLLoader loader = new 
    FXMLLoader(getClass().getResource("CssChange.fxml"));
    Parent root = loader.load();

    myControllerHandle = (FXMLDocumentController)loader.getController();

    Scene scene = new Scene(root);

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

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

Controller.java

    import java.io.IOException;
    import java.net.URL;
    import java.util.ResourceBundle;
    import javafx.event.ActionEvent;
    import javafx.fxml.FXML;
    import javafx.fxml.FXMLLoader;
    import javafx.fxml.Initializable;
    import javafx.scene.Parent;
    import javafx.scene.Scene;
    import javafx.scene.control.Button;
    import javafx.scene.control.Label;
    import javafx.scene.layout.AnchorPane;
    import javafx.scene.layout.Pane;

    public class FXMLDocumentController implements Initializable {

    @FXML
    private Label label;

@FXML
private Button button;

@FXML
private void CssChange(ActionEvent event) throws IOException{
    Parent root;
    root = (AnchorPane) FXMLLoader.load(getClass().getResource("CssChange.fxml"));
    System.out.println("You clicked me!");
    label.setText("Hello World!");
    String css = CssChange.class.getResource("login2.css").toExternalForm();
    root.getStylesheets().clear();
    root.getStylesheets().add(css);
    root.applyCss();
}

@Override
public void initialize(URL url, ResourceBundle rb) {
    // TODO
}    

}

FXML 文档

    <?xml version="1.0" encoding="UTF-8"?>

    <?import java.lang.*?>
    <?import java.util.*?>
    <?import javafx.scene.*?>
    <?import javafx.scene.control.*?>
    <?import javafx.scene.layout.*?>
    <?import javafx.scene.text.Font?>

    <AnchorPane  prefHeight="800.0" prefWidth="480.0" 
       stylesheets="@Login.css" xmlns="http://javafx.com/javafx/8.0.111" 
       xmlns:fx="http://javafx.com/fxml/1" 
       fx:controller="csschange.FXMLDocumentController" fx:id="root">

<children>
  <Button layoutX="14.0" layoutY="25.0" mnemonicParsing="false" 
       onAction="#CssChange" text="CSS Change" fx:id="button">
     <font>
        <Font name="Arial Bold Italic" size="18.0" />
     </font>
  </Button>
  <Label layoutX="126" layoutY="120" minHeight="16" minWidth="69" 
       fx:id="label" />
  </children>
  </AnchorPane >

第一个 CSS

    .root {
    -fx-background-color:
    linear-gradient(#000000 0%, #ffffff 100%);
    }

    .label {
    -fx-font-size: 12px;
    -fx-font-weight: bold;
    -fx-text-fill: #333333;
    -fx-effect: dropshadow( gaussian , rgba(255,255,255,0.5) , 0,0,0,1 );
    }

第二个 CSS

    .root {
    -fx-background-image: url("background.jpg");
    }

    .label {
    -fx-font-size: 12px;
    -fx-font-weight: bold;
    -fx-text-fill: #ffffff;
    -fx-effect: dropshadow( gaussian , rgba(255,255,255,0.5) , 0,0,0,1 );
    }

代码似乎可以正常工作,当我单击按钮时,我没有收到任何错误,但是没有任何反应。第二个 CSS 似乎根本没有被调用。我真的很感激我能得到的任何帮助。先感谢您。

【问题讨论】:

    标签: java css javafx stylesheet fxml


    【解决方案1】:

    您是否尝试隐藏然后显示舞台(或您的根窗格)? 也许实现显示会改变一些东西......

    【讨论】:

    • 我们确实尝试过隐藏然后显示每个窗格。结果证明只是缺少一个@FXML 标签。
    猜你喜欢
    • 1970-01-01
    • 2019-08-02
    • 1970-01-01
    • 2016-12-11
    • 2018-09-08
    • 1970-01-01
    • 1970-01-01
    • 2017-05-17
    • 1970-01-01
    相关资源
    最近更新 更多