[Echecs] Dames : Saut correct

This commit is contained in:
Geoffrey Frogeye 2014-12-14 20:44:29 +01:00
parent ccdb4c1657
commit f32ce16e71

View file

@ -99,6 +99,7 @@ class LogiqueDames(Logique):
MVT_INCONNU = 'Cause inconnue'
MVT_OK = 'Valide'
MVT_SAUT = 'Saut'
MVT_SELECTION = 'Mauvais tour'
MVT_SUR_PLACE = 'Immobile'
MVT_N_AUTORISE = 'Non-autorisé'
@ -123,11 +124,11 @@ class LogiqueDames(Logique):
for y in range(0, 3+1):
for x in range(0, self.CASES_COTE):
if not self.eCaseBlanche(x, y):
self.grille[x][y] = self.DECALAGE_NOIRS + self.PCE_PION
self.grille[x][y] = self.DECALAGE_NOIRS + self.PCE_DAME
for y in range(self.CASES_COTE-3-1, self.CASES_COTE):
for x in range(0, self.CASES_COTE):
if not self.eCaseBlanche(x, y):
self.grille[x][y] = self.DECALAGE_BLANCS + self.PCE_PION
self.grille[x][y] = self.DECALAGE_BLANCS + self.PCE_DAME
def deplPossiblePion(self, x1, y1, x2, y2):
"""
@ -138,6 +139,18 @@ class LogiqueDames(Logique):
return self.MVT_OK
else:
return self.MVT_N_AUTORISE
elif abs(x2-x1) == 2 and abs(y2-y1) == 2:
xS = x1+(x2-x1)//2
yS = y1+(y2-y1)//2
if self.ePiece(self.grille[xS][yS]):
if self.aSonTour(self.grille[xS][yS]):
return self.MVT_SAUT_AMI
else:
return self.MVT_SAUT
else:
return self.MVT_N_AUTORISE
else:
return self.MVT_N_AUTORISE
def deplPossibleDame(self, x1, y1, x2, y2):
"""
@ -155,8 +168,8 @@ class LogiqueDames(Logique):
x += sensX
y += sensY
if self.ePiece(self.grille[x][y]):
if dist == distTot:
return self.MVT_OK # Saut
if dist == distTot - 1 and not self.aSonTour(self.grille[x][y]):
return self.MVT_SAUT # Saut
else:
return self.MVT_OBSTRUCTION
return self.MVT_OK # Vide
@ -213,7 +226,8 @@ class LogiqueDames(Logique):
tableau = []
for x2 in range(0, self.CASES_COTE):
for y2 in range(0, self.CASES_COTE):
if self.deplPossible(x1, y1, x2, y2) == self.MVT_OK:
if self.deplPossible(x1, y1, x2, y2) == self.MVT_OK \
or self.mvtPossible(x1, y1, x2, y2) == self.MVT_SAUT:
tableau.append([x2, y2])
return tableau
@ -224,7 +238,8 @@ class LogiqueDames(Logique):
tableau = []
for x2 in range(0, self.CASES_COTE):
for y2 in range(0, self.CASES_COTE):
if self.mvtPossible(x1, y1, x2, y2) == self.MVT_OK:
if self.mvtPossible(x1, y1, x2, y2) == self.MVT_OK \
or self.mvtPossible(x1, y1, x2, y2) == self.MVT_SAUT:
tableau.append([x2, y2])
return tableau
@ -265,13 +280,15 @@ class LogiqueDames(Logique):
'deplacer': [], # Pièces à déplacer
'supprimer': [], # Pièces à supprimer
}
if test == self.MVT_OK:
if test in [self.MVT_OK, self.MVT_SAUT]:
if test == self.MVT_SAUT:
xS = x2-(x2-x1)//abs(x2-x1)
yS = y2-(y2-y1)//abs(y2-y1)
self.grille[xS][yS] = self.PCE_VIDE
retour['supprimer'].append([xS, yS])
retour['valide'] = True
if self.ePiece(self.grille[x2][y2]):
retour['supprimer'].append([x2, y2])
retour['deplacer'].append([x1, y1, x2, y2])
self.grille[x1][y1], self.grille[x2][
y2] = self.PCE_VIDE, self.grille[x1][y1]
self.grille[x1][y1], self.grille[x2][y2] = self.PCE_VIDE, self.grille[x1][y1]
self.joueur = not self.joueur
self.vPartieFinie()
return retour