I have an issue with my app. I'm trying to make an app that works perfectly fine with the command prompt but with a nice interface to get a better user experience. To do so I chose Javafx that looks better than swing to me.
But it do not work. I don't understand what's wrong.
Here is my Main app code :
package ch.makery.adress;
import java.io.IOException;
import javafx.application.Application;
import javafx.fxml.FXMLLoader;
import javafx.scene.Scene;
import javafx.stage.Stage;
import javafx.scene.Parent;
public class MainApp extends Application {
@Override
public void start(Stage stage) throws Exception {
Parent parent = FXMLLoader.load(getClass().getResource("PersonOverview.fxml"));
Scene scene = new Scene(parent);
stage.setTitle("Appication Extraction et remplissage Excel");
stage.setScene(scene);
stage.show();
}
}
My Hexacontroller :
package ch.makery.adress;
import java.awt.FileDialog;
import java.awt.List;
import java.io.File;
import java.io.IOException;
import javafx.fxml.Initializable;
import java.net.URL;
import java.text.DecimalFormat;
import java.util.ArrayList;
import java.util.Iterator;
import java.util.ResourceBundle;
import javax.swing.JFrame;
import org.jdom2.Element;
import org.jdom2.input.SAXBuilder;
import javafx.collections.FXCollections;
import javafx.collections.ObservableList;
import javafx.event.ActionEvent;
import javafx.fxml.FXML;
import javafx.scene.control.ComboBox;
import javafx.scene.control.TextField;
import jxl.Workbook;
import jxl.read.biff.BiffException;
import jxl.write.Label;
import jxl.write.WritableCell;
import jxl.write.WritableCellFormat;
import jxl.write.WritableFont;
import jxl.write.Number;
import jxl.write.WritableWorkbook;
import jxl.write.WriteException;
import jxl.write.biff.RowsExceededException;
public class HexaController implements Initializable {
static org.jdom2.Document document;
static JFrame fileDialog;
static Element racine;
static String Nom_dar;
static java.util.List<Element> listeDAS;
static ArrayList <String> Nom_das=new ArrayList();
static ArrayList <String> Nom_task=new ArrayList();
static ArrayList <String> Nom_Variable1=new ArrayList();
static ArrayList <String> Resultat_Variable1=new ArrayList();
static ArrayList <Double> Resultat_Variabledouble1=new ArrayList<Double>();
static ArrayList <String> ResultatHexa_Variable1=new ArrayList<String>();
static ArrayList <String> Lien=new ArrayList();
static java.util.List<Element> ListeTRIAL;
static java.util.List<Element> listeTASK;
static java.util.List<Element> listeOperation;
static List listeOperation_delta;
static java.util.List<Element> listeArgument;
static List listeArgument_delta;
@FXML
private ComboBox<String> hexa;
ObservableList<String> list = FXCollections.observableArrayList();
@FXML
private TextField entree;
@FXML
private TextField nomfichier;
@FXML
private static TextField excel;
@FXML
private static TextField sortie;
@FXML
private void dar(ActionEvent event){
FileDialog fd1=new FileDialog(fileDialog,"Choisissez un fichier .dar",FileDialog.LOAD);
fd1.setDirectory("C:\\");
fd1.setVisible(true);
String filename1=fd1.getFile();
String Directory1=fd1.getDirectory();
String path1=Directory1 + filename1;
entree.setText(path1);
nomfichier.setText(filename1);
}
@FXML
private void modele(ActionEvent event){
JFrame parentFrame=new JFrame();
FileDialog filechooser = new FileDialog (parentFrame, "Choisir un modèle Excel à copier",FileDialog.LOAD);
filechooser.setDirectory("C:\\");
filechooser.setVisible(true);
String directory_copy = filechooser.getDirectory();
String name_copy= filechooser.getFile();
String path_copy = (directory_copy+name_copy);
excel.setText(path_copy);
}
@FXML
private void sortie (ActionEvent event){
JFrame parentFrame2=new JFrame();
FileDialog filechooser2 = new FileDialog (parentFrame2, "Choisir une destination d'enregistrement",FileDialog.SAVE);
filechooser2.setDirectory("C:\\");
filechooser2.setVisible(true);
String directory_save = filechooser2.getDirectory();
String name_save= filechooser2.getFile();
String path_save = (directory_save+name_save+".xls");
sortie.setText(path_save);
}
@FXML
private void annuler (ActionEvent event){
System.exit(0);
}
@FXML
private static ComboBox<Integer>methode;
ObservableList<Integer>nombre = FXCollections.observableArrayList();
@FXML
private void exe (ActionEvent event) throws Throwable{
SAXBuilder sxb = new SAXBuilder();
String filename1=nomfichier.getText();
if(filename1==null)
{
System.out.println("Annulation");
System.exit(0);
}
else
{
try
{
//On crée un nouveau document JDOM avec en argument le fichier XML
//Le parsing est terminé
String path1=entree.getText();
document = sxb.build(new File(path1));
//On initialise un nouvel élément racine avec l'élément racine du document.
racine = document.getRootElement();
System.out.println("Lecture du premier .dar");
}
catch(Exception e)
{
System.out.println("FATAL ERROR !");
System.exit(0);
}
}
afficheALL();
Xl();
}
//RECUPERATION DES DONNEES DU FICHIER DAR
static void afficheALL()
{
//Variables Locales
String Str;
String Str_bis;
Nom_dar=racine.getAttributeValue("label");
System.out.println("Nom du fichier dar : " + Nom_dar+"\n");
listeDAS= racine.getChildren("DAS");
//On crée un Iterator sur notre liste
Iterator<Element> i1 = listeDAS.iterator();
////TRAITEMENT POUR CHAQUE DAS
String m[] = new String[50];
m[0]="Marqueur de Sortie";
m[1]="Nb Occurences";
m[2]="Valeur Physique";
m[3]="Résultat";
m[4]="Valeur de Sortie";
int s = methode.getValue();
int n;
for(n=5;n<5+s;n++)
{
//System.out.println("Entrez le nom de la methode");
//Scanner methode = new Scanner(System.in);
//String name=methode.nextLine();
//m[n]=name;
}
int j;
for(j=0;j<5+s;j++)
{
System.out.println("Le nom de la methode "+j+" est :"+m[j]);
}
while(i1.hasNext())
{
Element courant = (Element)i1.next();
//On affiche le nom de l’élément courant
Str=courant.getAttributeValue("dasFullFileName").toString();
System.out.println("Nom du DAS: " + Str);
Nom_das.add(Str);
ListeTRIAL=courant.getChildren("TRIAL");
@SuppressWarnings("rawtypes")
Iterator T1=ListeTRIAL.iterator();
while(T1.hasNext())
{
Element courant2 =(Element)T1.next();
Lien.add(courant2.getAttributeValue("xconvFullFileName").toString());
}
listeTASK=courant.getChildren("TASK");
@SuppressWarnings("rawtypes")
Iterator k1=listeTASK.iterator();
while(k1.hasNext())
{
Element courant2 =(Element)k1.next();
Str_bis=courant2.getAttributeValue("label").toString();
System.out.println(Str_bis);
listeOperation=courant2.getChildren("Operation");
@SuppressWarnings("rawtypes")
Iterator l1=listeOperation.iterator();
while(l1.hasNext())
{
Element courant3=(Element)l1.next();
listeArgument=courant3.getChildren("Argument");
@SuppressWarnings("rawtypes")
Iterator m1=listeArgument.iterator();
while(m1.hasNext())
{
Element courant4=(Element)m1.next();
int l;
for(l=0;l<5+s;l++)
{
if(courant4.getAttributeValue("parameterName").compareTo(m[l])==0)
{
Nom_Variable1.add(courant4.getAttributeValue("argumentName"));
double d = Double.parseDouble(courant4.getAttributeValue("instantValue"));
DecimalFormat df = new DecimalFormat(".#");
df.setMaximumFractionDigits(20);
String sortie = df.format(d);
long entier = (long)d;
String hex = Long.toHexString(entier).toUpperCase();
//hex.toUpperCase();
Resultat_Variable1.add(sortie);
Resultat_Variabledouble1.add(d);
ResultatHexa_Variable1.add(hex);
}
}
}
}
}
System.out.println("Fin lecture XML File");
}
}
static void Xl() throws Throwable
{
try
{
System.out.println("Saisi utilisateur ok");
//CREATION DES FEUILLES NECESSAIRES A LA RECUPERATION DES DONNEES
String path_copy = excel.getText();
String path_save = sortie.getText();
Workbook copie = Workbook.getWorkbook(new File(path_copy));
WritableWorkbook sortie = Workbook.createWorkbook(new File(path_save),copie);
WritableFont bord=new WritableFont(WritableFont.ARIAL,11);
WritableCellFormat border=new WritableCellFormat(bord);
//REMPLISSAGE DE LA PREMIERE FEUILLE AVEC LES DONNEES MESUREES
System.out.println("---"+Nom_Variable1.size()+"---");
for(int x=0;x<=Nom_Variable1.size()-1;x++)
{
Label Col0= new Label(0,x,Nom_Variable1.get(x),border);
sortie.getSheet(1).addCell(Col0);
}
for(int y=0;y<=Resultat_Variabledouble1.size()-1;y++)
{
Number Col1= new Number(1,y,Resultat_Variabledouble1.get(y),border);
sortie.getSheet(1).addCell((WritableCell) Col1);
}
for(int y=0;y<=ResultatHexa_Variable1.size()-1;y++)
{
Label Col2= new Label(2,y,ResultatHexa_Variable1.get(y),border);
sortie.getSheet(1).addCell(Col2);
}
System.out.println("Fin Copie Excel");
sortie.write();
sortie.close();
}
catch (RowsExceededException e1)
{
}
catch(BiffException ex)
{
}
catch (WriteException e1)
{
}
catch (IOException e)
{
}
finally
{
System.out.println("Le fichier à été généré correctement.");
System.out.println ("Appuyez sur 'Entrée' pour terminer le programme");
System.exit(0);
}
System.exit(0);
}
public HexaController(){
}
public void initialize(URL url,ResourceBundle rb){
list.add(new String("OUI"));
list.add(new String("NON"));
hexa.setItems(list);
nombre.add(new Integer(0));
nombre.add(new Integer(1));
nombre.add(new Integer(2));
nombre.add(new Integer(3));
nombre.add(new Integer(4));
nombre.add(new Integer(5));
methode.setItems(nombre);
}
}
And my fxml file :
<?xml version="1.0" encoding="UTF-8"?>
<?import javafx.scene.effect.*?>
<?import javafx.scene.text.*?>
<?import javafx.geometry.*?>
<?import javafx.scene.control.*?>
<?import java.lang.*?>
<?import javafx.scene.layout.*?>
<?import javafx.scene.layout.AnchorPane?>
<AnchorPane prefHeight="350.0" prefWidth="720.0" xmlns="http://javafx.com/javafx/8.0.40" xmlns:fx="http://javafx.com/fxml/1" fx:controller="ch.makery.adress.HexaController">
<children>
<GridPane layoutX="-120.0" layoutY="-234.0" prefHeight="0.0" prefWidth="80.0" AnchorPane.bottomAnchor="0.0" AnchorPane.leftAnchor="0.0" AnchorPane.rightAnchor="0.0" AnchorPane.topAnchor="0.0">
<columnConstraints>
<ColumnConstraints hgrow="SOMETIMES" minWidth="10.0" prefWidth="100.0" />
<ColumnConstraints hgrow="SOMETIMES" minWidth="10.0" prefWidth="100.0" />
<ColumnConstraints hgrow="SOMETIMES" minWidth="10.0" prefWidth="100.0" />
<ColumnConstraints hgrow="SOMETIMES" minWidth="10.0" prefWidth="100.0" />
<ColumnConstraints hgrow="SOMETIMES" minWidth="10.0" prefWidth="100.0" />
<ColumnConstraints hgrow="SOMETIMES" minWidth="10.0" prefWidth="100.0" />
<ColumnConstraints hgrow="SOMETIMES" minWidth="10.0" prefWidth="100.0" />
</columnConstraints>
<rowConstraints>
<RowConstraints maxHeight="132.0" minHeight="10.0" prefHeight="64.0" vgrow="SOMETIMES" />
<RowConstraints maxHeight="270.0" minHeight="0.0" prefHeight="52.0" vgrow="SOMETIMES" />
<RowConstraints maxHeight="546.0" minHeight="10.0" prefHeight="61.0" vgrow="SOMETIMES" />
<RowConstraints maxHeight="589.0" minHeight="10.0" prefHeight="76.0" vgrow="SOMETIMES" />
<RowConstraints maxHeight="620.0" minHeight="10.0" prefHeight="63.0" vgrow="SOMETIMES" />
<RowConstraints maxHeight="641.0" minHeight="10.0" prefHeight="47.0" vgrow="SOMETIMES" />
</rowConstraints>
<children>
<Button mnemonicParsing="false" onAction="#dar" text="Parcourir" textAlignment="CENTER" GridPane.columnIndex="6" GridPane.halignment="CENTER" />
<Button mnemonicParsing="false" onAction="#modele" text="Parcourir" textAlignment="CENTER" GridPane.columnIndex="6" GridPane.halignment="CENTER" GridPane.rowIndex="1" />
<Button mnemonicParsing="false" onAction="#sortie" text="Enregistrer" textAlignment="CENTER" GridPane.columnIndex="6" GridPane.halignment="CENTER" GridPane.rowIndex="2" />
<Button mnemonicParsing="false" onAction="#exe" text="Executer" GridPane.columnIndex="5" GridPane.halignment="CENTER" GridPane.rowIndex="5">
<font>
<Font name="System Bold" size="12.0" />
</font>
</Button>
<Button mnemonicParsing="false" onAction="#annuler" text="Annuler" GridPane.columnIndex="6" GridPane.halignment="CENTER" GridPane.rowIndex="5">
<font>
<Font name="System Bold" size="12.0" />
</font>
</Button>
<Label text="Choisissez un fichier ".dar"" GridPane.columnSpan="2" GridPane.halignment="LEFT">
<GridPane.margin>
<Insets left="20.0" />
</GridPane.margin>
</Label>
<Label text="Choisissez un modèle format ".xls"" GridPane.columnSpan="2" GridPane.halignment="LEFT" GridPane.rowIndex="1">
<GridPane.margin>
<Insets left="20.0" />
</GridPane.margin>
</Label>
<Label prefHeight="17.0" prefWidth="278.0" text="Choisissez la destination et le nom d'enregistrement" GridPane.columnSpan="3" GridPane.halignment="LEFT" GridPane.rowIndex="2">
<GridPane.margin>
<Insets left="20.0" />
</GridPane.margin>
</Label>
<Label text="Nombre de méthodes à ajouter" GridPane.columnSpan="2" GridPane.rowIndex="3">
<padding>
<Insets left="20.0" />
</padding>
</Label>
<Label text="Conversion hexadecimale" GridPane.columnSpan="2" GridPane.rowIndex="4">
<padding>
<Insets left="20.0" />
</padding>
</Label>
<TextField fx:id="entree" GridPane.columnIndex="3" GridPane.columnSpan="3" />
<TextField fx:id="excel" GridPane.columnIndex="3" GridPane.columnSpan="3" GridPane.rowIndex="1" />
<TextField fx:id="sortie" GridPane.columnIndex="3" GridPane.columnSpan="3" GridPane.rowIndex="2" />
<ComboBox fx:id="methode" prefWidth="150.0" promptText="Choisir" GridPane.columnIndex="2" GridPane.rowIndex="3" />
<ComboBox fx:id="hexa" prefWidth="150.0" promptText="Choisir" GridPane.columnIndex="2" GridPane.rowIndex="4" />
</children>
</GridPane>
</children>
</AnchorPane>
When I run this I have this error :
Exception in Application start method
Exception in thread "main" 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 sun.launcher.LauncherHelper$FXHelper.main(Unknown Source)
Caused by: java.lang.RuntimeException: Exception in Application start method
at com.sun.javafx.application.LauncherImpl.launchApplication1(Unknown Source)
at com.sun.javafx.application.LauncherImpl.lambda$launchApplication$156(Unknown Source)
at java.lang.Thread.run(Unknown Source)
Caused by: javafx.fxml.LoadException:
/C:/workspace/Application_traitement/bin/ch/makery/adress/PersonOverview.fxml
at javafx.fxml.FXMLLoader.constructLoadException(Unknown Source)
at javafx.fxml.FXMLLoader.loadImpl(Unknown Source)
at javafx.fxml.FXMLLoader.loadImpl(Unknown Source)
at javafx.fxml.FXMLLoader.loadImpl(Unknown Source)
at javafx.fxml.FXMLLoader.loadImpl(Unknown Source)
at javafx.fxml.FXMLLoader.loadImpl(Unknown Source)
at javafx.fxml.FXMLLoader.loadImpl(Unknown Source)
at javafx.fxml.FXMLLoader.loadImpl(Unknown Source)
at javafx.fxml.FXMLLoader.load(Unknown Source)
at ch.makery.adress.MainApp.start(MainApp.java:16)
at com.sun.javafx.application.LauncherImpl.lambda$launchApplication1$163(Unknown Source)
at com.sun.javafx.application.PlatformImpl.lambda$runAndWait$176(Unknown Source)
at com.sun.javafx.application.PlatformImpl.lambda$null$174(Unknown Source)
at java.security.AccessController.doPrivileged(Native Method)
at com.sun.javafx.application.PlatformImpl.lambda$runLater$175(Unknown Source)
at com.sun.glass.ui.InvokeLaterDispatcher$Future.run(Unknown Source)
at com.sun.glass.ui.win.WinApplication._runLoop(Native Method)
at com.sun.glass.ui.win.WinApplication.lambda$null$149(Unknown Source)
... 1 more
Caused by: java.lang.NullPointerException
at ch.makery.adress.HexaController.initialize(HexaController.java:338)
... 18 more
Could you help me with it ?
Thanks