-
Notifications
You must be signed in to change notification settings - Fork 2
/
Copy pathRei.java
77 lines (58 loc) · 1.96 KB
/
Rei.java
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
import javax.swing.JOptionPane;
/**
* Classe Cavalo, Define as regras e movimento para essa peca.
*
* @author (Andre Soares)
* @author Aurenívia Gomes da Costa
* @version (002 12/09/2020)
*/
public class Rei extends Peca
{
/**
* Construtor da Classe Rei
*/
public Rei (Casa casa, CorDaPeca cor)
{
super(casa, TipoDaPeca.REI, cor);
}
/**
* movimenta a peca para o local de destino caso esteja correto.
*/
@Override
public Boolean mover(Casa destino, Tabuleiro tabuleiro) {
if(this.verificaDestino(this, destino)) {
if(this.podeMover(this.casa, destino)){
this.casa.removerPeca();
destino.colocarPeca(this);
this.casa = destino;
return true;
}
return false;
}
return false;
}
/**
* Verifica se o movimento e valido, retorna um boolean.
*/
private Boolean podeMover(Casa casa, Casa destino) {
// variaveis para simplificar o codigo (Andre)
int x = destino.x;
int y = destino.y;
if((x <= casa.x + 1 && x >= casa.x - 1) && (y <= casa.y + 1 && y >= casa.y - 1)){
//Verifica se o destino nao esta no mesmo eixo x e y. (Andre)
if(casa.x == x || casa.y == y){
//Verifica se o destino nao esta nas diagonais. (Andre)
for(int i = -2; i <= 2; i++) {
if( (casa.x + i == x && casa.y + i == y) || (casa.x + i == x && casa.y + (i * -1) == y)){
return true;
}
}
return true;
}else{
return true;
}
}else {
return false;
}
}
}