更改CSS

时间:2018-04-04 22:14:51

标签: java javafx nullpointerexception

我有一个带有多个控制器和阶段的应用程序。我试图通过CSS在父控制器类中实现一个可切换的主题系统,所有其他控制器都继承自。它工作正常,除非我打开我的首选项对话框并关闭它。如果我之后尝试更改主题,我在控制台中获得了无限的NullPointerExceptions流,我的应用程序停止响应。同样重要的是要注意,如果我通过IntelliJ运行它,这不会发生,只有当我运行我的jar时。

许多相关代码和转储:

    public class ControllerBase {

  protected static final String LOGGING_CONFIG_FILE_NAME = "/config/logging/log4j.xml";

  public static SimpleStringProperty themeFilename = new SimpleStringProperty(  );

  protected Stage stage;

  protected String cfgFile = new WorkbenchAppConfig().getFileName();
  protected AppPropertiesManager prefs = new AppPropertiesManager();

  protected Logger log;
  protected ResourceBundle res;

  protected ChangeListener CSSListener;

  protected ControllerBase(){


    doInitsFromConfigFile();


    String themeName = prefs.getString( cfgFile, KEY_GUI_THEME_ACTIVE, "Light" );
    themeFilename.set(  prefs.getString( cfgFile, KEY_GUI_THEMES_BASE + "." + themeName + ".filename" ));



    CSSListener = new ChangeListener() {
      @Override
      public void changed( ObservableValue observable, Object oldValue, Object newValue ) {
        updateCss();
      }
    };
    themeFilename.addListener( CSSListener );

  }

  protected void updateCss() {

    //Refresh Theme settings
    if(stage != null) {
      ObservableList< String > css = stage.getScene().getStylesheets();
      css.clear();
      css.add( themeFilename.getValue() );
    }
  }

  protected void doInitsFromConfigFile() {

    // get localized resources
    String localeLanguage = prefs.getString(cfgFile, KEY_APP_LOCALE_LANGUAGE, "en");
    String localeCountry = prefs.getString(cfgFile, KEY_APP_LOCALE_COUNTRY, "US");


    res = CommonGuiUtils.getStringResourceBundle();

    // get active GUI theme
    String themeName = prefs.getString( cfgFile, KEY_GUI_THEME_ACTIVE, "Dark" );
    themeFilename.set(  prefs.getString( cfgFile, KEY_GUI_THEMES_BASE + "." + themeName + ".filename" ));
  }

主控制器处理选择菜单的方法:

private void setUpThemeSelection() {

    lightingStyleGroup = new ToggleGroup();
    lightingStyleGroup.getToggles().add( lightThemeOption );
    lightingStyleGroup.getToggles().add( darkThemeOption );

    String themeName = prefs.getString( cfgFile, KEY_GUI_THEME_ACTIVE, "Dark" );
    ObservableList list = lightingStyleGroup.getToggles();

    for ( Object x : list ) {
      if ( ( (RadioMenuItem) x ).getText().startsWith( themeName ) ) {
        lightingStyleGroup.selectToggle( (Toggle) x );
      }
    }
  }

   private void switchTheme( ActionEvent actionEvent ) {

    //Find selected item and change prefs
    RadioMenuItem selected = (RadioMenuItem) lightingStyleGroup.getSelectedToggle();
    prefs.setString( cfgFile, KEY_GUI_THEME_ACTIVE, selected.getText() );

    //Refresh Theme settings
    String themeName = prefs.getString( cfgFile, KEY_GUI_THEME_ACTIVE, "Dark" );
    themeFilename.set(  prefs.getString( cfgFile, KEY_GUI_THEMES_BASE + "." + themeName + ".filename" ));

  }

从控制台转储,删节

Exception in thread "JavaFX Application Thread" java.lang.NullPointerException
    at com.sun.javafx.css.StyleManager.lambda$loadStylesheetUnPrivileged$191(StyleManager.java:1060)
    at java.security.AccessController.doPrivileged(Native Method)
    at com.sun.javafx.css.StyleManager.loadStylesheetUnPrivileged(StyleManager.java:1054)
    at com.sun.javafx.css.StyleManager.loadStylesheet(StyleManager.java:935)
    at com.sun.javafx.css.StyleManager.processStylesheets(StyleManager.java:1556)
    at com.sun.javafx.css.StyleManager.gatherSceneStylesheets(StyleManager.java:1625)
    at com.sun.javafx.css.StyleManager.findMatchingStyles(StyleManager.java:1663)
    at javafx.scene.CssStyleHelper.createStyleHelper(CssStyleHelper.java:111)
    at javafx.scene.Node.reapplyCss(Node.java:8985)
    at javafx.scene.Node.impl_processCSS(Node.java:9182)
    at javafx.scene.Parent.impl_processCSS(Parent.java:1249)
    at javafx.scene.Node.processCSS(Node.java:9058)
    at javafx.scene.Scene.doCSSPass(Scene.java:545)
    at javafx.scene.Scene.access$3600(Scene.java:159)
    at javafx.scene.Scene$ScenePulseListener.pulse(Scene.java:2392)
    at com.sun.javafx.tk.Toolkit.lambda$runPulse$30(Toolkit.java:355)
    at java.security.AccessController.doPrivileged(Native Method)
    at com.sun.javafx.tk.Toolkit.runPulse(Toolkit.java:354)
    at com.sun.javafx.tk.Toolkit.firePulse(Toolkit.java:381)
    at com.sun.javafx.tk.quantum.QuantumToolkit.pulse(QuantumToolkit.java:510)
    at com.sun.javafx.tk.quantum.QuantumToolkit.pulse(QuantumToolkit.java:490)
    at com.sun.javafx.tk.quantum.QuantumToolkit.lambda$runToolkit$404(QuantumToolkit.java:319)
    at com.sun.glass.ui.InvokeLaterDispatcher$Future.run(InvokeLaterDispatcher.java:95)
    at com.sun.glass.ui.win.WinApplication._runLoop(Native Method)
    at com.sun.glass.ui.win.WinApplication.lambda$null$148(WinApplication.java:191)
    at java.lang.Thread.run(Thread.java:748)
Exception in thread "JavaFX Application Thread" java.lang.NullPointerException
    at com.sun.javafx.css.StyleManager.lambda$loadStylesheetUnPrivileged$191(StyleManager.java:1060)
    at java.security.AccessController.doPrivileged(Native Method)
    at com.sun.javafx.css.StyleManager.loadStylesheetUnPrivileged(StyleManager.java:1054)
    at com.sun.javafx.css.StyleManager.loadStylesheet(StyleManager.java:935)
    at com.sun.javafx.css.StyleManager.processStylesheets(StyleManager.java:1556)
    at com.sun.javafx.css.StyleManager.gatherSceneStylesheets(StyleManager.java:1625)
    at com.sun.javafx.css.StyleManager.findMatchingStyles(StyleManager.java:1663)
    at javafx.scene.CssStyleHelper.createStyleHelper(CssStyleHelper.java:111)
    at javafx.scene.Node.reapplyCss(Node.java:8985)
    at javafx.scene.Node.impl_processCSS(Node.java:9182)
    at javafx.scene.Parent.impl_processCSS(Parent.java:1249)
    at javafx.scene.Node.processCSS(Node.java:9058)
    at javafx.scene.Scene.doCSSPass(Scene.java:545)
    at javafx.scene.Scene.access$3600(Scene.java:159)
    at javafx.scene.Scene$ScenePulseListener.pulse(Scene.java:2392)
    at com.sun.javafx.tk.Toolkit.lambda$runPulse$30(Toolkit.java:355)
    at java.security.AccessController.doPrivileged(Native Method)
    at com.sun.javafx.tk.Toolkit.runPulse(Toolkit.java:354)
    at com.sun.javafx.tk.Toolkit.firePulse(Toolkit.java:381)
    at com.sun.javafx.tk.quantum.QuantumToolkit.pulse(QuantumToolkit.java:510)
    at com.sun.javafx.tk.quantum.QuantumToolkit.pulse(QuantumToolkit.java:490)
    at com.sun.javafx.tk.quantum.QuantumToolkit.lambda$runToolkit$404(QuantumToolkit.java:319)
    at com.sun.glass.ui.InvokeLaterDispatcher$Future.run(InvokeLaterDispatcher.java:95)
    at com.sun.glass.ui.win.WinApplication._runLoop(Native Method)
    at com.sun.glass.ui.win.WinApplication.lambda$null$148(WinApplication.java:191)
    at java.lang.Thread.run(Thread.java:748)
Exception in thread "JavaFX Application Thread" java.lang.NullPointerException
    at com.sun.javafx.css.StyleManager.lambda$loadStylesheetUnPrivileged$191(StyleManager.java:1060)
    at java.security.AccessController.doPrivileged(Native Method)
    at com.sun.javafx.css.StyleManager.loadStylesheetUnPrivileged(StyleManager.java:1054)
    at com.sun.javafx.css.StyleManager.loadStylesheet(StyleManager.java:935)
    at com.sun.javafx.css.StyleManager.processStylesheets(StyleManager.java:1556)
    at com.sun.javafx.css.StyleManager.gatherSceneStylesheets(StyleManager.java:1625)
    at com.sun.javafx.css.StyleManager.findMatchingStyles(StyleManager.java:1663)
    at javafx.scene.CssStyleHelper.createStyleHelper(CssStyleHelper.java:111)
    at javafx.scene.Node.reapplyCss(Node.java:8985)
    at javafx.scene.Node.impl_processCSS(Node.java:9182)
    at javafx.scene.Parent.impl_processCSS(Parent.java:1249)
    at javafx.scene.Node.processCSS(Node.java:9058)
    at javafx.scene.Scene.doCSSPass(Scene.java:545)
    at javafx.scene.Scene.access$3600(Scene.java:159)
    at javafx.scene.Scene$ScenePulseListener.pulse(Scene.java:2392)
    at com.sun.javafx.tk.Toolkit.lambda$runPulse$30(Toolkit.java:355)
    at java.security.AccessController.doPrivileged(Native Method)
    at com.sun.javafx.tk.Toolkit.runPulse(Toolkit.java:354)
    at com.sun.javafx.tk.Toolkit.firePulse(Toolkit.java:381)
    at com.sun.javafx.tk.quantum.QuantumToolkit.pulse(QuantumToolkit.java:510)
    at com.sun.javafx.tk.quantum.QuantumToolkit.pulse(QuantumToolkit.java:490)
    at com.sun.javafx.tk.quantum.QuantumToolkit.lambda$runToolkit$404(QuantumToolkit.java:319)
    at com.sun.glass.ui.InvokeLaterDispatcher$Future.run(InvokeLaterDispatcher.java:95)
    at com.sun.glass.ui.win.WinApplication._runLoop(Native Method)
    at com.sun.glass.ui.win.WinApplication.lambda$null$148(WinApplication.java:191)
    at java.lang.Thread.run(Thread.java:748)

    ...and so on forever

有谁知道最近发生了什么?是什么导致了这个?

1 个答案:

答案 0 :(得分:0)

我发现了问题,我的偏好管理器有时会在错误的时间返回null(看似随机)。我解决了这个问题。