0

I'm new to both javaFX and intellij Idea. I'm trying to connect my JIMachine.fxml file to Controller.java file by using the attribute "fx:controller" as shown below. From what I have gathered, you have to use the fully qualified name of the class in order for it to find it. The files in this project are not inside of a package, so I believe the fully qualified name should just be "Controller", however, I get the error below when I attempt to run the program.

The commands I run to compile and run are as follows:

javac --module-path C:\Users\Max\javafx-sdk-11.0.2\lib --add-modules javafx.controls,javafx.fxml JIMachine.java
java --module-path C:\Users\Max\javafx-sdk-11.0.2\lib --add-modules javafx.controls JIMachine
<?xml version="1.0" encoding="UTF-8"?>
<?import javafx.scene.control.*?>
<Button fx:controller="Controller" id="btn_msg" fx:id="btn_msg" mnemonicParsing="false" onAction="#pressButton" text="Say: &quot;Hello, World&quot;" xmlns="http://javafx.com/javafx/10.0.2-internal" xmlns:fx="http://javafx.com/fxml/1" />
Exception in Application start method
java.lang.reflect.InvocationTargetException
    at java.base/jdk.internal.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
    at java.base/jdk.internal.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:62)
    at java.base/jdk.internal.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)
    at java.base/java.lang.reflect.Method.invoke(Method.java:567)
    at javafx.graphics/com.sun.javafx.application.LauncherImpl.launchApplicationWithArgs(LauncherImpl.java:464)
    at javafx.graphics/com.sun.javafx.application.LauncherImpl.launchApplication(LauncherImpl.java:363)
    at java.base/jdk.internal.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
    at java.base/jdk.internal.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:62)
    at java.base/jdk.internal.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)
    at java.base/java.lang.reflect.Method.invoke(Method.java:567)
    at java.base/sun.launcher.LauncherHelper$FXHelper.main(LauncherHelper.java:1051)
Caused by: java.lang.RuntimeException: Exception in Application start method
    at javafx.graphics/com.sun.javafx.application.LauncherImpl.launchApplication1(LauncherImpl.java:900)
    at javafx.graphics/com.sun.javafx.application.LauncherImpl.lambda$launchApplication$2(LauncherImpl.java:195)
    at java.base/java.lang.Thread.run(Thread.java:830)
Caused by: javafx.fxml.LoadException: 
/C:/Users/Max/Java/JavaFXTest/JIMachine.fxml:6

    at javafx.fxml/javafx.fxml.FXMLLoader.constructLoadException(FXMLLoader.java:2625)
    at javafx.fxml/javafx.fxml.FXMLLoader.access$700(FXMLLoader.java:105)
    at javafx.fxml/javafx.fxml.FXMLLoader$ValueElement.processAttribute(FXMLLoader.java:930)
    at javafx.fxml/javafx.fxml.FXMLLoader$InstanceDeclarationElement.processAttribute(FXMLLoader.java:980)
    at javafx.fxml/javafx.fxml.FXMLLoader$Element.processStartElement(FXMLLoader.java:227)
    at javafx.fxml/javafx.fxml.FXMLLoader$ValueElement.processStartElement(FXMLLoader.java:752)
    at javafx.fxml/javafx.fxml.FXMLLoader.processStartElement(FXMLLoader.java:2722)
    at javafx.fxml/javafx.fxml.FXMLLoader.loadImpl(FXMLLoader.java:2552)
    at javafx.fxml/javafx.fxml.FXMLLoader.loadImpl(FXMLLoader.java:2466)
    at javafx.fxml/javafx.fxml.FXMLLoader.loadImpl(FXMLLoader.java:3237)
    at javafx.fxml/javafx.fxml.FXMLLoader.loadImpl(FXMLLoader.java:3194)
    at javafx.fxml/javafx.fxml.FXMLLoader.loadImpl(FXMLLoader.java:3163)
    at javafx.fxml/javafx.fxml.FXMLLoader.loadImpl(FXMLLoader.java:3136)
    at javafx.fxml/javafx.fxml.FXMLLoader.loadImpl(FXMLLoader.java:3113)
    at javafx.fxml/javafx.fxml.FXMLLoader.load(FXMLLoader.java:3106)
    at JIMachine.start(JIMachine.java:14)
    at javafx.graphics/com.sun.javafx.application.LauncherImpl.lambda$launchApplication1$9(LauncherImpl.java:846)
    at javafx.graphics/com.sun.javafx.application.PlatformImpl.lambda$runAndWait$12(PlatformImpl.java:455)
    at javafx.graphics/com.sun.javafx.application.PlatformImpl.lambda$runLater$10(PlatformImpl.java:428)
    at java.base/java.security.AccessController.doPrivileged(AccessController.java:391)
    at javafx.graphics/com.sun.javafx.application.PlatformImpl.lambda$runLater$11(PlatformImpl.java:427)
    at javafx.graphics/com.sun.glass.ui.InvokeLaterDispatcher$Future.run(InvokeLaterDispatcher.java:96)
    at javafx.graphics/com.sun.glass.ui.win.WinApplication._runLoop(Native Method)
    at javafx.graphics/com.sun.glass.ui.win.WinApplication.lambda$runLoop$3(WinApplication.java:174)
    ... 1 more
Caused by: java.lang.ClassNotFoundException: Controller
    at java.base/jdk.internal.loader.BuiltinClassLoader.loadClass(BuiltinClassLoader.java:602)
    at java.base/jdk.internal.loader.ClassLoaders$AppClassLoader.loadClass(ClassLoaders.java:178)
    at java.base/java.lang.ClassLoader.loadClass(ClassLoader.java:521)
    at javafx.fxml/javafx.fxml.FXMLLoader$ValueElement.processAttribute(FXMLLoader.java:928)
    ... 22 more

Exception running application JIMachine

I'm not able to post a picture so I can't directly show the file tree but the sources root is C:\Users\Max\Java\JavaFXTest Inside that folder are the .idea folder for configuration items, as well as the files "Controller", "JIMachine.java" (shows as "JIMachine" in intellij), "JIMachine.class", "JIMachine.fxml".

Is it an error with the fx:controller attribute or something else?

Brad
  • 121
  • 1
  • 8
  • 1
    "The files in this project are not inside of a package". You need to put everything in a package. – James_D Mar 13 '20 at 02:36
  • I'm unable to use a package or I would have. It shouldn't be necessary. – Brad Mar 13 '20 at 03:27
  • It’s absolutely necessary. The “default package” (unnamed package) has been discouraged since Java 1.0 (released in 1996), and it’s a compile error to create a modular Java application with unnamed packages in Java 9 and later. There’s no reason for you to be “unable “ to use a package. – James_D Mar 13 '20 at 03:31
  • @James_D While all true (or should be, sometimes places such as schools have weird restrictions), it should be possible to use the default package. At least, it worked when I tried it using Java 13.0.2 (and everything on the class-path). – Slaw Mar 13 '20 at 07:33
  • @Mr.Brad Can you provide a [mre] demonstrating the problem, including project structure and commands used? – Slaw Mar 13 '20 at 07:34
  • 1
    You don't appear to be compiling `Controller.java` based on the `javac` command you provided. You need to compile _all_ source files, otherwise they don't exist at runtime. – Slaw Mar 13 '20 at 20:56
  • Ah, slaw, you are of course, correct. Thank you for the insight – Brad Mar 15 '20 at 00:33

0 Answers0