updates java's tp

master
antoine.perederii 1 year ago
parent fa87fa45ae
commit 6421ad9e37

@ -1,6 +1,6 @@
<?xml version="1.0" encoding="UTF-8"?> <?xml version="1.0" encoding="UTF-8"?>
<project version="4"> <project version="4">
<component name="ProjectRootManager" version="2" languageLevel="JDK_21" default="true" project-jdk-name="18" project-jdk-type="JavaSDK"> <component name="ProjectRootManager" version="2" languageLevel="JDK_18" default="true" project-jdk-name="18" project-jdk-type="JavaSDK">
<output url="file://$PROJECT_DIR$/out" /> <output url="file://$PROJECT_DIR$/out" />
</component> </component>
</project> </project>

@ -28,11 +28,15 @@ public class DeplaceurJoueur {
Case caseActuelle = joueurActuel.getMyCase(); Case caseActuelle = joueurActuel.getMyCase();
Case caseSuivante = joueurSuivant.getMyCase(); Case caseSuivante = joueurSuivant.getMyCase();
if(caseActuelle == null) {
caseActuelle.setCurrentJoueur(null);
} else {
caseActuelle.setCurrentJoueur(joueurSuivant);
}
caseSuivante.setCurrentJoueur(joueurActuel);
joueurActuel.setMyCase(caseSuivante); joueurActuel.setMyCase(caseSuivante);
joueurSuivant.setMyCase(caseActuelle); joueurSuivant.setMyCase(caseActuelle);
caseActuelle.setCurrentJoueur(joueurSuivant);
caseSuivante.setCurrentJoueur(joueurActuel);
} }
// public void deplacerJoueur(Joueur currentJoueur, int nbCases, Plateau plateau) { // public void deplacerJoueur(Joueur currentJoueur, int nbCases, Plateau plateau) {
// if (verifPresenceJoueur(currentJoueur, nbCases, plateau)) { // if (verifPresenceJoueur(currentJoueur, nbCases, plateau)) {

@ -11,24 +11,24 @@ import java.util.List;
public class GestionnaireJoueur { public class GestionnaireJoueur {
private static int index = 0; private static int index = 0;
private ObservableList<Joueur> myList = FXCollections.observableArrayList(); private final ObservableList<Joueur> myList = FXCollections.observableArrayList();
private ListProperty<Joueur> lesJoueurs = new SimpleListProperty(myList); private final ListProperty<Joueur> lesJoueurs = new SimpleListProperty(myList);
public ObservableList<Joueur> getLesJoueurs() { public ObservableList<Joueur> getLesJoueurs() {
return lesJoueurs.get(); return lesJoueurs.get();
} }
public ListProperty<Joueur> lesJoueursProperty() { public ListProperty<Joueur> lesJoueursProperty() {
return lesJoueurs; return lesJoueurs;
} }
private Joueur currentJoueur; private ObjectProperty<Joueur> currentJoueur = new SimpleObjectProperty<>();
public Joueur getCurrentJoueur() { public Joueur getCurrentJoueur() {
return currentJoueur.get();
}
public ObjectProperty<Joueur> currentJoueurProperty() {
return currentJoueur; return currentJoueur;
} }
// public ObjectProperty<Joueur> currentJoueurProperty() { public void setCurrentJoueur(Joueur joueur) {
// return currentJoueur; currentJoueur.set(joueur);
// } }
// public void setCurrentJoueur(Joueur joueur) {
// currentJoueur.set(joueur);
// }
// private List<Joueur> lesJoueurs = new ArrayList<>(); // private List<Joueur> lesJoueurs = new ArrayList<>();
// private StringProperty name = new SimpleStringProperty(); // private StringProperty name = new SimpleStringProperty();
// public String getName() { return name.get(); } // public String getName() { return name.get(); }
@ -42,18 +42,18 @@ public class GestionnaireJoueur {
// return currentJoueur; // return currentJoueur;
// } // }
public Joueur getJoueurSuivant() { public Joueur getJoueurSuivant() {
return this.myList.get((currentJoueur.getIdJoueur() + 1) % lesJoueurs.size()); return this.myList.get((currentJoueur.get().getIdJoueur() + 1) % lesJoueurs.size());
} }
public void ajouterJoueur(Joueur joueur) { public void ajouterJoueur(Joueur joueur) {
myList.add(joueur); myList.add(joueur);
if(myList.size() == 1) { if(myList.size() == 1) {
currentJoueur = myList.get(0); currentJoueur.set(myList.get(0));
} }
} }
public Joueur nextPlayer() { public Joueur nextPlayer() {
index = (index +1) % this.myList.size(); index = (index +1) % this.myList.size();
currentJoueur = myList.get(index); setCurrentJoueur(myList.get(index));
return currentJoueur; return getCurrentJoueur();
// return myList.get((currentJoueur.getIdJoueur()) % lesJoueurs.size()); // return myList.get((currentJoueur.getIdJoueur()) % lesJoueurs.size());
} }
} }

@ -1,6 +1,8 @@
package view; package view;
import data.Stub; import data.Stub;
import javafx.beans.value.ChangeListener;
import javafx.beans.value.ObservableValue;
import javafx.fxml.FXML; import javafx.fxml.FXML;
import javafx.scene.control.Button; import javafx.scene.control.Button;
import javafx.scene.control.Label; import javafx.scene.control.Label;
@ -14,21 +16,22 @@ import models.Joueur;
public class Fenetre { public class Fenetre {
@FXML @FXML
private BorderPane myBorderPane = new BorderPane(); private BorderPane myBorderPane;
@FXML @FXML
private VBox labelContainer; private VBox labelContainer;
@FXML @FXML
private ListView joueursContainer = new ListView(); private ListView<Joueur> joueursContainer;
private final Jeu game = new Stub().loadPions(); private final Jeu game = new Stub().loadPions();
Joueur currentPion = game.getMyAdminPlayer().getCurrentJoueur(); Joueur currentPion = game.getMyAdminPlayer().getCurrentJoueur();
public void updateButtonLabels() { public void updateButtonLabels() {
for (int i = 1; i < game.getPlateau().getCaseList().size(); i++) { for (int i = 0; i < game.getPlateau().getCaseList().size(); i++) {
System.out.println((i + 1) + " " + game.getPlateau().getCaseList().size());
Label label = (Label) labelContainer.getChildren().get(i); Label label = (Label) labelContainer.getChildren().get(i);
if (game.getPlateau().getCaseList().get(i).getCurrentJoueur() != null) { if (game.getPlateau().getCaseList().get(i).getCurrentJoueur() != null) {
label.setText("Case " + (i) + "\n" + "Joueur: " + game.getPlateau().getCaseList().get(i).getCurrentJoueur().getIdJoueur()); label.setText("Case " + (i + 1) + "\n" + "Joueur: " + game.getPlateau().getCaseList().get(i).getCurrentJoueur().getIdJoueur());
} else { } else {
label.setText("Case " + (i)); label.setText("Case " + (i + 1));
} }
} }
} }
@ -41,105 +44,114 @@ public class Fenetre {
for (int i = 0; i < game.getPlateau().getCaseList().size(); i++) { for (int i = 0; i < game.getPlateau().getCaseList().size(); i++) {
Label label = new Label(); Label label = new Label();
if (game.getPlateau().getCaseList().get(i).getCurrentJoueur() != null) { if (game.getPlateau().getCaseList().get(i).getCurrentJoueur() != null) {
label.setText("Case " + i + "\n" + "Joueur: " + game.getPlateau().getCaseList().get(i).getCurrentJoueur().getIdJoueur()); label.setText("Case " + (i+1) + "\n" + "Joueur: " + game.getPlateau().getCaseList().get(i).getCurrentJoueur().getIdJoueur());
} else { } else {
label.setText("Case " + i); label.setText("Case " + (i+1));
} }
labelContainer.getChildren().add(label); labelContainer.getChildren().add(label);
} }
joueursContainer.itemsProperty().bind(game.getMyAdminPlayer().lesJoueursProperty()); joueursContainer.itemsProperty().bind(game.getMyAdminPlayer().lesJoueursProperty());
// joueursContainer.selectionModelProperty().bind(game.getMyAdminPlayer().currentJoueurProperty()); game.getMyAdminPlayer().currentJoueurProperty().addListener(new ChangeListener<Joueur>() {
}
public void initialize() {
de.setDisable(true);
jeu = new Jeu();
gestionnaireJoueur = new GestionnaireJoueur();
creationPlateau();
gestionnaireJoueur.getJoueurList().addListener(new ListChangeListener<Joueur>() {
@Override @Override
public void onChanged(Change<? extends Joueur> c) { public void changed(ObservableValue<? extends Joueur> observable, Joueur oldValue, Joueur newValue) {
while (c.next()) { joueursContainer.getSelectionModel().select(newValue);
if (c.wasAdded()) {
for (Joueur joueur : c.getAddedSubList()) {
addGridPlayer();
}
}
if (c.wasUpdated()) {
for (Joueur joueur : c.getAddedSubList()) {
changeGridPlayer(joueur);
}
}
}
} }
}); });
// == > se transforme en ça :
game.getMyAdminPlayer().currentJoueurProperty().addListener((__, ___, newValue) -> joueursContainer.getSelectionModel().select(newValue));
} }
// public void initialize() {
public void creationPlateau() { // de.setDisable(true);
int nombreColonnes = 16; // jeu = new Jeu();
// gestionnaireJoueur = new GestionnaireJoueur();
for (int i = 0; i < jeu.getPlateau().getSizeplateau(); i++) { // creationPlateau();
Text text = new Text(String.valueOf(i + 1)); // gestionnaireJoueur.getJoueurList().addListener(new ListChangeListener<Joueur>() {
text.setStyle("-fx-font-size: 35;"); // @Override
int row = i / nombreColonnes; // public void onChanged(Change<? extends Joueur> c) {
int col = i % nombreColonnes; // while (c.next()) {
// if (c.wasAdded()) {
gridPanel.add(text, col, row); // for (Joueur joueur : c.getAddedSubList()) {
gridPanel.setMargin(text, new Insets(30, 25, 50, 0)); // addGridPlayer();
gridPanel.setAlignment(Pos.CENTER); // }
} // }
} // if (c.wasUpdated()) {
// for (Joueur joueur : c.getAddedSubList()) {
public void addPlayer(){ // changeGridPlayer(joueur);
gestionnaireJoueur.ajouterJoueur(); // }
} // }
// }
public void addGridPlayer(){ // }
int rowIndex = gestionnaireJoueur.getJoueurList().size(); // });
Joueur joueur = gestionnaireJoueur.getJoueurList().get(rowIndex - 1); //
//
Label idJoueurLabel = new Label("Joueur numéro " + joueur.getId()); // }
gridPlayer.add(idJoueurLabel, 0, rowIndex); //
// public void creationPlateau() {
Label caseJoueurLabel = new Label(); // int nombreColonnes = 16;
caseJoueurLabel.setText("Case numéro: N/A"); //
// for (int i = 0; i < jeu.getPlateau().getSizeplateau(); i++) {
// Text text = new Text(String.valueOf(i + 1));
gridPlayer.add(caseJoueurLabel, 1, rowIndex); // text.setStyle("-fx-font-size: 35;");
// int row = i / nombreColonnes;
} // int col = i % nombreColonnes;
//
public void changeGridPlayer(Joueur joueur){ // gridPanel.add(text, col, row);
Label caseJoueurLabel = (Label) gridPlayer.getChildren().get(joueur.getId()); // gridPanel.setMargin(text, new Insets(30, 25, 50, 0));
if (joueur.getCurrentCase() != null) { // gridPanel.setAlignment(Pos.CENTER);
caseJoueurLabel.textProperty().bind(Bindings.concat("Case numéro " + joueur.getCurrentCase().getNum())); // }
} else { // }
caseJoueurLabel.textProperty().bind(Bindings.concat("Case numéro: N/A")); //
} // public void addPlayer(){
// gestionnaireJoueur.ajouterJoueur();
} // }
//
public void start() { // public void addGridPlayer(){
addPlay.setDisable(true); // int rowIndex = gestionnaireJoueur.getJoueurList().size();
de.setDisable(false); // Joueur joueur = gestionnaireJoueur.getJoueurList().get(rowIndex - 1);
btStart.setDisable(true); //
gestionnaireJoueur.InitaliseJoueur(); // Label idJoueurLabel = new Label("Joueur numéro " + joueur.getId());
currentJoueur = gestionnaireJoueur.getCurrentJoueur(); // gridPlayer.add(idJoueurLabel, 0, rowIndex);
} //
// Label caseJoueurLabel = new Label();
// caseJoueurLabel.setText("Case numéro: N/A");
//
public void lanceDe() { //
idPlayer.textProperty().bind(currentJoueur.idProperty().asString()); // gridPlayer.add(caseJoueurLabel, 1, rowIndex);
deSimple.lancer(); //
idValeur.textProperty().bind(deSimple.valProperty().asString()); // }
if (deSimple.getVal() == 0){ //
return; // public void changeGridPlayer(Joueur joueur){
} // Label caseJoueurLabel = (Label) gridPlayer.getChildren().get(joueur.getId());
System.out.println("Current Joueur = " + currentJoueur); // if (joueur.getCurrentCase() != null) {
jeu.CaseDeplacer(currentJoueur,deSimple.getVal() ); // caseJoueurLabel.textProperty().bind(Bindings.concat("Case numéro " + joueur.getCurrentCase().getNum()));
currentJoueur = gestionnaireJoueur.switchCurrentPlayer(); // } else {
System.out.println(); // caseJoueurLabel.textProperty().bind(Bindings.concat("Case numéro: N/A"));
} // }
//
// }
//
// public void start() {
// addPlay.setDisable(true);
// de.setDisable(false);
// btStart.setDisable(true);
// gestionnaireJoueur.InitaliseJoueur();
// currentJoueur = gestionnaireJoueur.getCurrentJoueur();
// }
//
//
//
// public void lanceDe() {
// idPlayer.textProperty().bind(currentJoueur.idProperty().asString());
// deSimple.lancer();
// idValeur.textProperty().bind(deSimple.valProperty().asString());
// if (deSimple.getVal() == 0){
// return;
// }
// System.out.println("Current Joueur = " + currentJoueur);
// jeu.CaseDeplacer(currentJoueur,deSimple.getVal() );
// currentJoueur = gestionnaireJoueur.switchCurrentPlayer();
// System.out.println();
// }
} }
Loading…
Cancel
Save