Подтвердить что ты не робот

Использование maven ant плагина в приложении javafx, Как добавить зависимости в javaFX jar. Все еще сталкивается с классом не найденное исключение

Я использую это руководство, добавив мои зависимости к главному банку JavaFX jar с включенными зависимостями Я сталкиваюсь с проблемой зависимостей, которые вызывают исключение класса. Мой Pom точно так же упоминается в ссылке выше. Я использую плагин зависимостей для копирования зависимостей в папку lib в цель.

Вот моя трассировка стека

Try calling Class.forName(com.client.main.App) using classLoader = j
[email protected]
found class: class com.client.main.App
launchApp: Try calling com.sun.javafx.application.LauncherImpl.launchApplication

Autoconfig of proxy is completed.
JavaFX: using com.sun.javafx.tk.quantum.QuantumToolkit
Exception in Application init method
java.lang.reflect.InvocationTargetException
    at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
    at sun.reflect.NativeMethodAccessorImpl.invoke(Unknown Source)
    at sun.reflect.DelegatingMethodAccessorImpl.invoke(Unknown Source)
    at java.lang.reflect.Method.invoke(Unknown Source)
    at com.javafx.main.Main.launchApp(Main.java:698)
    at com.javafx.main.Main.main(Main.java:871)
Caused by: java.lang.RuntimeException: Exception in Application init method
    at com.sun.javafx.application.LauncherImpl.launchApplication1(Unknown So
urce)
    at com.sun.javafx.application.LauncherImpl.access$000(Unknown Source)
    at com.sun.javafx.application.LauncherImpl$1.run(Unknown Source)
    at java.lang.Thread.run(Unknown Source)
Caused by: java.lang.NoClassDefFoundError: com/google/inject/Module
    at com.nuaxis.rpas.client.main.App.init(App.java:25)
    ... 4 more
Caused by: java.lang.ClassNotFoundException: com.google.inject.Module
    at java.net.URLClassLoader$1.run(Unknown Source)
    at java.net.URLClassLoader$1.run(Unknown Source)
    at java.security.AccessController.doPrivileged(Native Method)
    at java.net.URLClassLoader.findClass(Unknown Source)
    at java.lang.ClassLoader.loadClass(Unknown Source)
    at java.lang.ClassLoader.loadClass(Unknown Source)
    ... 5 more
Done with invoke and wait

Maven Ant Задача в файле maven pom с использованием плагина maven Ant

<jfxjar destfile="${project.build.directory}/${project.build.finalName}">
  <fileset dir="${project.build.directory}/classes" />
  <fileset dir="${project.build.directory}/lib/" includes="*.jar" />    

  <application name="${project.name}" mainClass="com.client.main.App" />        
  <resources>
     <fileset dir="${project.build.directory}/lib/" includes="*.jar" />
  </resources>
</jfxjar>

Вот мой код класса приложения Fx

public class App extends Application {
    /*public static Logger mLogger = LoggerFactory.getLogger(App.class);    */
public static Injector injector;
public static AppHandler mAppHandler;

@Override
public void init() throws Exception {
    // TODO Auto-generated method stub
    super.init();
    injector = Guice.createInjector(new GuiceModule());/*This line cause exception*/
    mAppHandler = injector.getInstance(AppHandler.class);
    if(mAppHandler!=null)
        mAppHandler.startHandler();
}

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

    Scene scene = new Scene(root);
    scene.getStylesheets().add("/styles/style.css");
    stage.setTitle("RPAS Java Client");
    stage.getIcons().add(new Image("/images/RPAS Java Client.png"));
    stage.setScene(scene);
    stage.show();
}

@Override
public void stop() throws Exception {
    mAppHandler.stopHandler();
} 



/**
 * @param args the command line arguments
 */
public static void main(String[] args) { 
    launch(args);        
}

}

Вот мое понимание

Теперь я понимаю, что мои зависимости не загружаются должным образом. Ant Задача "jar making" делает банку без каких-либо проблем. когда я дважды щелкаю его по исключению. Я открыл банку, и вот мой манифест

Manifest-Version: 1.0
JavaFX-Version: 2.2
JavaFX-Application-Class: com.client.main.App
JavaFX-Class-Path: guice-3.0.jar hamcrest-core-1.3.jar javax.inject-1.jar log4j-1.2.15.jar slf4j-api-1.7.7.jar slf4j-log4j12-1.7.7.jar 
Created-By: JavaFX Packager
Main-Class: com/javafx/main/Main

Мне также интересно, когда я увидел, что процесс создания jar добавляет файл com.javafx.main.Main.java в код автоматически, который сначала проверяет время выполнения (JRE и FX), а затем, если все успешные вызовы com.sun.javafx.Application.LauncherImp.

Может ли кто-нибудь помочь мне?

4b9b3361