wyjątek w JavaFX Exception in thread "JavaFX Application Thread" java.lang.RuntimeException: java.lang.reflect.InvocationTargetException

0

Witam.

Mam problem z o obsługą metody w Javie FX.

moim głównym oknem jest BorderPane (w topie zaczytuje się menu) a do
center mam utworzoną metodę setCenter :

private static final String USER_FXML = "/fxml/NewUser.fxml";

public void setCenter(String fxmlPath) {
        FXMLLoader loader = new FXMLLoader(this.getClass().getClassLoader().getResource(fxmlPath));
        ResourceBundle bundle = ResourceBundle.getBundle("bundles.messages");
        loader.setResources(bundle);
        // po parent wszystekie kontrolery dziedzicza
        Parent parent = null;
        try {
            parent = loader.load();
        } catch (IOException e) {
            e.printStackTrace();
        }
        borderPane.setCenter(parent);
    }
	
	co ciekawe jeżeli usunę użycie tej metodu i zmienę na zwykle sou ("test") program na konsoli wysiwetli dane słowo
	
	Metoda ma w centralnym punkcie zmieniac okna w zależności od wybranego menu
	wywołanie metody zarówno w tej jak i innej klasie konczy się błędem :

Exception in thread "JavaFX Application Thread" java.lang.RuntimeException: java.lang.reflect.InvocationTargetException
	at javafx.fxml.FXMLLoader$MethodHandler.invoke(FXMLLoader.java:1774)
	at javafx.fxml.FXMLLoader$ControllerMethodEventHandler.handle(FXMLLoader.java:1657)
	at com.sun.javafx.event.CompositeEventHandler.dispatchBubblingEvent(CompositeEventHandler.java:86)
	at com.sun.javafx.event.EventHandlerManager.dispatchBubblingEvent(EventHandlerManager.java:238)
	at com.sun.javafx.event.EventHandlerManager.dispatchBubblingEvent(EventHandlerManager.java:191)
	at com.sun.javafx.event.BasicEventDispatcher.dispatchEvent(BasicEventDispatcher.java:58)
	at com.sun.javafx.event.EventDispatchChainImpl.dispatchEvent(EventDispatchChainImpl.java:114)
	at com.sun.javafx.event.EventUtil.fireEventImpl(EventUtil.java:74)
	at com.sun.javafx.event.EventUtil.fireEvent(EventUtil.java:49)
	at javafx.event.Event.fireEvent(Event.java:198)
	at javafx.scene.control.MenuItem.fire(MenuItem.java:462)
	at com.sun.javafx.scene.control.skin.ContextMenuContent$MenuItemContainer.doSelect(ContextMenuContent.java:1405)
	at com.sun.javafx.scene.control.skin.ContextMenuContent$MenuItemContainer.lambda$createChildren$6(ContextMenuContent.java:1358)
	at com.sun.javafx.event.CompositeEventHandler$NormalEventHandlerRecord.handleBubblingEvent(CompositeEventHandler.java:218)
	at com.sun.javafx.event.CompositeEventHandler.dispatchBubblingEvent(CompositeEventHandler.java:80)
	at com.sun.javafx.event.EventHandlerManager.dispatchBubblingEvent(EventHandlerManager.java:238)
	at com.sun.javafx.event.EventHandlerManager.dispatchBubblingEvent(EventHandlerManager.java:191)
	at com.sun.javafx.event.CompositeEventDispatcher.dispatchBubblingEvent(CompositeEventDispatcher.java:59)
	at com.sun.javafx.event.BasicEventDispatcher.dispatchEvent(BasicEventDispatcher.java:58)
	at com.sun.javafx.event.EventDispatchChainImpl.dispatchEvent(EventDispatchChainImpl.java:114)
	at com.sun.javafx.event.BasicEventDispatcher.dispatchEvent(BasicEventDispatcher.java:56)
	at com.sun.javafx.event.EventDispatchChainImpl.dispatchEvent(EventDispatchChainImpl.java:114)
	at com.sun.javafx.event.BasicEventDispatcher.dispatchEvent(BasicEventDispatcher.java:56)
	at com.sun.javafx.event.EventDispatchChainImpl.dispatchEvent(EventDispatchChainImpl.java:114)
	at com.sun.javafx.event.BasicEventDispatcher.dispatchEvent(BasicEventDispatcher.java:56)
	at com.sun.javafx.event.EventDispatchChainImpl.dispatchEvent(EventDispatchChainImpl.java:114)
	at com.sun.javafx.event.EventUtil.fireEventImpl(EventUtil.java:74)
	at com.sun.javafx.event.EventUtil.fireEvent(EventUtil.java:54)
	at javafx.event.Event.fireEvent(Event.java:198)
	at javafx.scene.Scene$MouseHandler.process(Scene.java:3757)
	at javafx.scene.Scene$MouseHandler.access$1500(Scene.java:3485)
	at javafx.scene.Scene.impl_processMouseEvent(Scene.java:1762)
	at javafx.scene.Scene$ScenePeerListener.mouseEvent(Scene.java:2494)
	at com.sun.javafx.tk.quantum.GlassViewEventHandler$MouseEventNotification.run(GlassViewEventHandler.java:394)
	at com.sun.javafx.tk.quantum.GlassViewEventHandler$MouseEventNotification.run(GlassViewEventHandler.java:295)
	at java.security.AccessController.doPrivileged(Native Method)
	at com.sun.javafx.tk.quantum.GlassViewEventHandler.lambda$handleMouseEvent$2(GlassViewEventHandler.java:432)
	at com.sun.javafx.tk.quantum.QuantumToolkit.runWithoutRenderLock(QuantumToolkit.java:410)
	at com.sun.javafx.tk.quantum.GlassViewEventHandler.handleMouseEvent(GlassViewEventHandler.java:431)
	at com.sun.glass.ui.View.handleMouseEvent(View.java:555)
	at com.sun.glass.ui.View.notifyMouse(View.java:937)
	at com.sun.glass.ui.win.WinApplication._runLoop(Native Method)
	at com.sun.glass.ui.win.WinApplication.lambda$null$4(WinApplication.java:186)
	at java.lang.Thread.run(Thread.java:748)
Caused by: java.lang.reflect.InvocationTargetException
	at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
	at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:62)
	at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)
	at java.lang.reflect.Method.invoke(Method.java:498)
	at sun.reflect.misc.Trampoline.invoke(MethodUtil.java:71)
	at sun.reflect.GeneratedMethodAccessor1.invoke(Unknown Source)
	at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)
	at java.lang.reflect.Method.invoke(Method.java:498)
	at sun.reflect.misc.MethodUtil.invoke(MethodUtil.java:275)
	at javafx.fxml.FXMLLoader$MethodHandler.invoke(FXMLLoader.java:1771)
	... 43 more
Caused by: java.lang.IllegalStateException: Location is not set.
	at javafx.fxml.FXMLLoader.loadImpl(FXMLLoader.java:2434)
	at javafx.fxml.FXMLLoader.load(FXMLLoader.java:2409)
	at pl.moj.obieg.controllers.MainControllers.setCenter(MainControllers.java:34)
	at pl.moj.obieg.controllers.MainControllers.newUser(MainControllers.java:43)
	... 53 more
2
emilgajecki napisał(a):

Caused by: java.lang.IllegalStateException: Location is not set.
at javafx.fxml.FXMLLoader.loadImpl(FXMLLoader.java:2434)
at javafx.fxml.FXMLLoader.load(FXMLLoader.java:2409)
at pl.moj.obieg.controllers.MainControllers.setCenter(MainControllers.java:34)
at pl.moj.obieg.controllers.MainControllers.newUser(MainControllers.java:43)
... 53 more

Strzelam, że to wina tego:

public void setCenter(String fxmlPath) {
       FXMLLoader loader = new FXMLLoader(this.getClass().getClassLoader().getResource(fxmlPath));
   }

Pokaż jak wygląda fxmlPath

2

this.getClass().getClassLoader().getResource(fxmlPath)

  1. this jest niepotrzebne
  2. getClassLoader() też bym wywalił - i tak chyba podajesz ścieżkę z / na początku
  3. Najpierw sobie wypisz co ci zwraca to getResource, bo najprawdopodobniej dostajesz nulla i analiza dalszego kodu nie ma sensu.
0
kixe52 napisał(a):
emilgajecki napisał(a):

Caused by: java.lang.IllegalStateException: Location is not set.
at javafx.fxml.FXMLLoader.loadImpl(FXMLLoader.java:2434)
at javafx.fxml.FXMLLoader.load(FXMLLoader.java:2409)
at pl.moj.obieg.controllers.MainControllers.setCenter(MainControllers.java:34)
at pl.moj.obieg.controllers.MainControllers.newUser(MainControllers.java:43)
... 53 more

Strzelam, że to wina tego:

public void setCenter(String fxmlPath) {
       FXMLLoader loader = new FXMLLoader(this.getClass().getClassLoader().getResource(fxmlPath));
   }

Pokaż jak wygląda fxmlPath

fxmlPath
private static final String USER_FXML = "/fxml/NewUser.fxml";
2

Jak zamienisz new FXMLLoader(this.getClass().getClassLoader().getResource(fxmlPath)); na new FXMLLoader(null); to dostaniesz ten sam błąd, bo this.getClass().getClassLoader().getResource(fxmlPath) zwraca ci nulla.

2

Emil, przenieś NewUser.fxml do głównego katalogu resources i załaduj formę tak:
FXMLLoader.load(getClass().getResource("/NewUser.fxml"));
Jeśli Ci zależy na osobnym folderze: fxml to sprawdź, czy taki jest w target\classes, jeśli nie ma to przebuduj cały project, przeładuj pom.xml jeśli to Maven itd., bo być może uruchamiasz tylko klasę z metodą main.

0
cs napisał(a):

Emil, przenieś NewUser.fxml do głównego katalogu resources i załaduj formę tak:
FXMLLoader.load(getClass().getResource("/NewUser.fxml"));
Jeśli Ci zależy na osobnym folderze: fxml to sprawdź, czy taki jest w target\classes, jeśli nie ma to przebuduj cały project,

Jeżeli chodzi o target to pliku NewUser.fxml nie ma Jest jedynie MainScreen.fxml. być może tutaj jest przyczyna.

przeładuj pom.xml jeśli to Maven itd., bo być może uruchamiasz tylko klasę z metodą main.

Maven chodzi o Maven to mam mam auto przeładowanie po każdej zmianie.

Rozumiem, że jeżeli dodam plik do target problem powinien się rozwiązać?
I w jaki sposób go tam dodać?

Po dodaniu świeci się na czerwono i wskazuje na jave

0

Dziękuje wszystkim za pomoc. Problem leżał w pliku fxml' w którym miałem błędną nazwię po której się odnosiłem (w fxml było to borderPaneMain a w klasie onosiłem się do borderPane). Chwila braku uwagi zatrzymała mój proces na kilka dni.

1 użytkowników online, w tym zalogowanych: 0, gości: 1