From 48e9fe0f23b9426856fda6e4f61b583a881e32b1 Mon Sep 17 00:00:00 2001 From: Manon Date: Sat, 25 May 2019 21:52:52 +0200 Subject: [PATCH] forcer le roi a bouger quand en echec --- src/piecesEchiquier/Piece.java | 4 ++-- src/visuel/main.java | 32 +++++++++++++++++++++++++------- 2 files changed, 27 insertions(+), 9 deletions(-) diff --git a/src/piecesEchiquier/Piece.java b/src/piecesEchiquier/Piece.java index 0c0d80d..86682a8 100755 --- a/src/piecesEchiquier/Piece.java +++ b/src/piecesEchiquier/Piece.java @@ -106,10 +106,10 @@ public class Piece { if(this.deplacable(e,p) == true) //1er cas : la pièce se deplace une seconde fois (pas vraiment) et verifie qu'elle tombe sur la position du roi (soit noir, soit blanc selon la couleur de la pièce) { System.out.println("Le roi est en échec"); - roiEchec=true; + p.roiEchec=true; return true; } - roiEchec=false; + p.roiEchec=false; return false; } diff --git a/src/visuel/main.java b/src/visuel/main.java index 44f78bd..7a93d26 100755 --- a/src/visuel/main.java +++ b/src/visuel/main.java @@ -37,7 +37,8 @@ public class main { //déclaration des variables de déplacement String A; //coordonées de départ - String B; //coordonées d'arrivée + String B; //coordonées d'arrivée + //déclaration de l'échiquier Echiquier e = new Echiquier(); @@ -97,14 +98,30 @@ public class main { System.out.println("\n" + "Tour de " + j1.getNom() + "\n"); do { - System.out.println( - "Quelle pièce voulez-vous déplacer ? Donnez le code correspondant de la pièce à déplacer(ex : A1).\n"); + if (e.getRoiB1().isRoiEchec() == true) + { + System.out.println( + "Comme votre roi est en echec la piec e a bouger est forcement cette derniere. Ou voulez vous la poser ?\n"); + A = e.getCodes()[8-e.getRoiB1().getPosition().getY()][e.getRoiB1().getPosition().getX()-1]; + B = sc.nextLine(); + } + else { + System.out.println( + "Quelle pièce voulez-vous déplacer ? Donnez le code correspondant de la pièce à déplacer(ex : A1).\n"); + A = sc.nextLine(); + System.out.println( + "À quel endroit la poser ? Donnez le code correspondant à l'endroit où poser la pièce.\n"); + B = sc.nextLine(); + } + - A = sc.nextLine(); - System.out.println( - "À quel endroit la poser ? Donnez le code correspondant à l'endroit où poser la pièce.\n"); - B = sc.nextLine(); + } while (e.verificationMouvement(j1, A, B) != true); // Tant que le mouvement n'est pas faisable on demande 2 coordonnées + /*if (e.getRoiN1().enEchec(e,j2) && e.getRoiN1().enEchecEtMat(e,j2)) + { + System.out.println("Le joueur 2 est echec et mat, il a perdu !"); + jeu = false; + }*/ //REAFFICHAGE ECHIQUIER System.out.println(e.toString()); @@ -115,6 +132,7 @@ public class main { do { System.out.println( "Quelle piece voulez-vous deplacer ? Donnez le code correspondant de la pièce à déplacer(ex : A1).\n"); + A = sc.nextLine(); System.out.println(