Récupération objet bdd

This commit is contained in:
Paul Gross 2020-05-05 13:13:21 +02:00
parent 40ad1cb599
commit 222605628c
14 changed files with 158 additions and 44 deletions

View File

@ -1,9 +1,15 @@
package carte; package carte;
import java.io.Serializable;
import main.Joueur; import main.Joueur;
public abstract class Carte { public abstract class Carte implements Serializable {
/**
*
*/
private static final long serialVersionUID = -3227553705226975570L;
private String nom; private String nom;
private String description; private String description;

View File

@ -1,9 +1,18 @@
package carte; package carte;
import main.Joueur; import main.Joueur;
import java.io.Serializable;
import condition.Condition; import condition.Condition;
public abstract class CarteCondition extends CarteEffet{ public abstract class CarteCondition extends CarteEffet implements Serializable{
/**
*
*/
private static final long serialVersionUID = 903022795821166067L;
public CarteCondition(String nom, String description) { public CarteCondition(String nom, String description) {
super(nom, description); super(nom, description);

View File

@ -1,10 +1,17 @@
package carte; package carte;
import main.Joueur; import main.Joueur;
import java.io.Serializable;
import effet.Effet; import effet.Effet;
public abstract class CarteEffet extends Carte{ public abstract class CarteEffet extends Carte implements Serializable{
/**
*
*/
private static final long serialVersionUID = -5248405395465365805L;
private Effet effet; private Effet effet;
public CarteEffet(String nom, String description) { public CarteEffet(String nom, String description) {

View File

@ -1,14 +1,25 @@
package carte; package carte;
import java.io.Serializable;
import condition.Condition;
import effet.Effet;
import main.Joueur; import main.Joueur;
import main.Type; import main.Type;
public class CartePiochable<T extends Type> extends CarteCondition{ public class CartePiochable<T extends Type> extends CarteCondition implements Serializable{
private static final long serialVersionUID = 2391013233873750967L;
public CartePiochable(String nom, String description) { public CartePiochable(String nom, String description) {
super(nom, description); super(nom, description);
// TODO Auto-generated constructor stub }
public CartePiochable(Effet e, Condition c) {
super("","");
this.setEffet(e);
this.setCondition(c);
} }
/* /*

View File

@ -1,8 +1,15 @@
package condition; package condition;
import java.io.Serializable;
import main.Joueur; import main.Joueur;
public class Condition { public class Condition implements Serializable{
/**
*
*/
private static final long serialVersionUID = 8276438989479754732L;
public boolean isTrue(Joueur joueur) { public boolean isTrue(Joueur joueur) {
return true; return true;
} }

View File

@ -3,7 +3,6 @@ package database;
import java.awt.image.BufferedImage; import java.awt.image.BufferedImage;
import java.io.ByteArrayInputStream; import java.io.ByteArrayInputStream;
import java.io.IOException; import java.io.IOException;
import java.io.InputStream;
import javax.imageio.ImageIO; import javax.imageio.ImageIO;

View File

@ -0,0 +1,93 @@
package database;
import java.io.ByteArrayInputStream;
import java.io.ByteArrayOutputStream;
import java.io.IOException;
import java.io.InputStream;
import java.io.ObjectInputStream;
import java.io.ObjectOutputStream;
import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.PreparedStatement;
import java.sql.ResultSet;
import java.sql.SQLException;
import java.sql.Statement;
import carte.CartePiochable;
import condition.Condition;
import effet.EffetSelf;
import effet.action.ActionAltererStatistiquesJoueur;
import main.Joueur;
public class TestAddingCard {
private final static String url = "jdbc:postgresql://localhost:5432/ShadowHunterDatabase";
private final static String user = "shManager";
private final static String password = "shadowhunter1234";
public static void main(String[] args) {
CartePiochable<?> instance = new CartePiochable(new EffetSelf(new ActionAltererStatistiquesJoueur(Joueur.PLAYER_HP, 2, true)), new Condition());
try {
insertCartePiochable(instance);
System.out.println(retrieveCartePiochable(0).getEffet());
} catch (IOException | SQLException e) {
// TODO Auto-generated catch block
e.printStackTrace();
} catch (ClassNotFoundException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
}
public static Connection connect() throws SQLException {
return DriverManager.getConnection(url, user, password);
}
public static void insertCartePiochable(CartePiochable<?> instance) throws IOException, SQLException {
ByteArrayOutputStream baos = new ByteArrayOutputStream();
ObjectOutputStream oos;
oos = new ObjectOutputStream(baos);
oos.writeObject(instance);
oos.close();
ByteArrayInputStream bais = new ByteArrayInputStream(baos.toByteArray());
byte[] object = bais.readAllBytes();
InputStream objectIS = new ByteArrayInputStream(object);
String sql = "INSERT INTO public.\"Test\"" + "VALUES(?)";
Connection conn = connect();
PreparedStatement pst = conn.prepareStatement(sql);
pst.setBinaryStream(1, objectIS);
pst.executeUpdate();
}
public static CartePiochable<?> retrieveCartePiochable(int pos) throws IOException, SQLException, ClassNotFoundException {
Connection conn = connect();
Statement st = conn.createStatement();
ResultSet rs = st.executeQuery("SELECT * FROM public.\"Test\"");
byte[] object = null;
if(rs.next()) {
object = rs.getBytes(1);
}
ByteArrayInputStream in = new ByteArrayInputStream(object);
ObjectInputStream is = new ObjectInputStream(in);
return (CartePiochable<?>) is.readObject();
}
}

View File

@ -1,9 +1,13 @@
package effet; package effet;
import java.io.Serializable;
import effet.action.Action; import effet.action.Action;
import main.Joueur; import main.Joueur;
public abstract class Effet { public abstract class Effet implements Serializable{
private static final long serialVersionUID = 1121660401755188715L;
private Action action; private Action action;

View File

@ -10,7 +10,6 @@ public class EffetCiblerAdjacents extends Effet{
super(action); super(action);
} }
@Override @Override
public void utiliser(Joueur joueur) public void utiliser(Joueur joueur)
{ {
@ -21,9 +20,5 @@ public class EffetCiblerAdjacents extends Effet{
{ {
action.affecte(joueur, j); action.affecte(joueur, j);
} }
} }
} }

View File

@ -1,8 +1,13 @@
package effet.action; package effet.action;
import java.io.Serializable;
import main.Joueur; import main.Joueur;
public abstract class Action { public abstract class Action implements Serializable{
private static final long serialVersionUID = 4290735254363171340L;
public abstract void affecte(Joueur j1, Joueur j2); public abstract void affecte(Joueur j1, Joueur j2);

View File

@ -13,7 +13,6 @@ import javafx.stage.StageStyle;
public class PopUpBoolean { public class PopUpBoolean {
@FXML private Pane rootPane; @FXML private Pane rootPane;
private Scene scene; private Scene scene;
private Stage popup; private Stage popup;
@ -23,26 +22,19 @@ public class PopUpBoolean {
public PopUpBoolean (Parent p, String titre) { public PopUpBoolean (Parent p, String titre) {
popup = new Stage(); popup = new Stage();
popup.initModality(Modality.WINDOW_MODAL); popup.initModality(Modality.WINDOW_MODAL);
popup.initStyle(StageStyle.UNDECORATED); popup.initStyle(StageStyle.UNDECORATED);
popup.setTitle(titre); popup.setTitle(titre);
scene = new Scene(p); scene = new Scene(p);
p.setOnMousePressed(new EventHandler<MouseEvent>() { p.setOnMousePressed(new EventHandler<MouseEvent>() {
@Override @Override
public void handle(MouseEvent event){ public void handle(MouseEvent event){
xOffSet = event.getSceneX(); xOffSet = event.getSceneX();
yOffSet = event.getSceneY(); yOffSet = event.getSceneY();
} }
}); });
p.setOnMouseDragged(new EventHandler<MouseEvent>() { p.setOnMouseDragged(new EventHandler<MouseEvent>() {
@ -52,18 +44,13 @@ public class PopUpBoolean {
popup.setX(event.getScreenX() - xOffSet); popup.setX(event.getScreenX() - xOffSet);
popup.setY(event.getScreenY() - yOffSet); popup.setY(event.getScreenY() - yOffSet);
} }
}); });
} }
public boolean display() { public boolean display() {
popup.setScene(scene); popup.setScene(scene);
popup.showAndWait(); popup.showAndWait();
return result; return result;
} }
} }

View File

@ -264,7 +264,6 @@ public class PlateauController implements Initializable {
public void rollDice(Joueur joueur, int typeDice, int[] rolls) { public void rollDice(Joueur joueur, int typeDice, int[] rolls) {
} }
public void afficherChoisir(Joueur j) throws IOException { public void afficherChoisir(Joueur j) throws IOException {

View File

@ -77,7 +77,6 @@ public class GestionnaireJeu {
e.printStackTrace(); e.printStackTrace();
} }
}); });
this.waitPlateau(); this.waitPlateau();
@ -113,17 +112,14 @@ public class GestionnaireJeu {
} }
public static void notifyPlateau() { public static void notifyPlateau() {
synchronized(plateau) { synchronized(plateau) {
plateau.notify(); plateau.notify();
} }
} }
public void rollDice(Joueur joueur, int typeDice, int ... rolls){ public void rollDice(Joueur joueur, int typeDice, int ... rolls){
pc.rollDice(joueur,typeDice,rolls); pc.rollDice(joueur,typeDice,rolls);
} }
public void setConfiguration(Configuration c) { public void setConfiguration(Configuration c) {
@ -131,13 +127,13 @@ public class GestionnaireJeu {
Map<Integer, Joueur> mapJoueurs = convertConfiguration(c); Map<Integer, Joueur> mapJoueurs = convertConfiguration(c);
this.mapJoueurs = mapJoueurs; this.mapJoueurs = mapJoueurs;
List<Joueur> joueurs = new ArrayList(); List<Joueur> joueurs = new ArrayList<Joueur>();
for(Joueur j : mapJoueurs.values()) { for(Joueur j : mapJoueurs.values()) {
joueurs.add(j); joueurs.add(j);
} }
this.plateau = new Plateau(joueurs); plateau = new Plateau(joueurs);
} }
@ -151,7 +147,7 @@ public class GestionnaireJeu {
} }
public void setPlateauController(PlateauController pc2) { public void setPlateauController(PlateauController pc2) {
this.pc = pc2; pc = pc2;
} }

View File

@ -356,13 +356,9 @@ public class Plateau extends Thread{
Collections.shuffle(lieux); Collections.shuffle(lieux);
for(int i = 0; i < lieux.size(); i += 2) { for(int i = 0; i < lieux.size(); i += 2) {
lieux.get(i).setVoisin(lieux.get(i+1)); lieux.get(i).setVoisin(lieux.get(i+1));
lieux.get(i+1).setVoisin(lieux.get(i)); lieux.get(i+1).setVoisin(lieux.get(i));
} }
}else {
} }
} }