add playablility
parent
bffb1ff60f
commit
96e5648833
|
|
@ -8,6 +8,7 @@ import com.github.bhlangonijr.chesslib.Board;
|
||||||
import com.github.bhlangonijr.chesslib.File;
|
import com.github.bhlangonijr.chesslib.File;
|
||||||
import com.github.bhlangonijr.chesslib.Rank;
|
import com.github.bhlangonijr.chesslib.Rank;
|
||||||
import com.github.bhlangonijr.chesslib.Square;
|
import com.github.bhlangonijr.chesslib.Square;
|
||||||
|
import com.github.bhlangonijr.chesslib.move.Move;
|
||||||
|
|
||||||
import de.mannheim.th.chess.App;
|
import de.mannheim.th.chess.App;
|
||||||
import de.mannheim.th.chess.domain.Game;
|
import de.mannheim.th.chess.domain.Game;
|
||||||
|
|
@ -119,73 +120,14 @@ public class SpielFrame extends JFrame {
|
||||||
*/
|
*/
|
||||||
private void erstelleBrett() {
|
private void erstelleBrett() {
|
||||||
|
|
||||||
clearButtons();
|
this.clearButtons();
|
||||||
setDefaultBackground();
|
this.setDefaultBackground();
|
||||||
|
this.setButtonsActions();
|
||||||
|
|
||||||
List<Square> selectables;
|
ladeBrett();
|
||||||
|
|
||||||
switch (this.mode) {
|
panelLinks.revalidate();
|
||||||
case BoardMode.normal:
|
panelLinks.repaint();
|
||||||
selectables = game.getAllLegalMoveableSquares();
|
|
||||||
|
|
||||||
System.out.println(selectables);
|
|
||||||
|
|
||||||
for (Square square : selectables) {
|
|
||||||
final Square currentSquare = square; // ActionListener need it to be final
|
|
||||||
JButton b = buttons.get(63 - square.ordinal());
|
|
||||||
b.setEnabled(true);
|
|
||||||
b.setBackground(Color.green);
|
|
||||||
b.addActionListener(new ActionListener() {
|
|
||||||
@Override
|
|
||||||
public void actionPerformed(ActionEvent e) {
|
|
||||||
System.out.println("switch to selected");
|
|
||||||
mode = BoardMode.pieceSelected;
|
|
||||||
selectedSquare = currentSquare;
|
|
||||||
erstelleBrett();
|
|
||||||
}
|
|
||||||
});
|
|
||||||
}
|
|
||||||
|
|
||||||
break;
|
|
||||||
|
|
||||||
case BoardMode.pieceSelected:
|
|
||||||
JButton s = buttons.get(63 - selectedSquare.ordinal());
|
|
||||||
s.setEnabled(true);
|
|
||||||
s.setBackground(Color.orange);
|
|
||||||
s.addActionListener(new ActionListener() {
|
|
||||||
@Override
|
|
||||||
public void actionPerformed(ActionEvent e) {
|
|
||||||
mode = BoardMode.normal;
|
|
||||||
selectedSquare = null;
|
|
||||||
erstelleBrett();
|
|
||||||
}
|
|
||||||
}); // cancel action
|
|
||||||
|
|
||||||
selectables = game.getLegalMoveableSquares(selectedSquare);
|
|
||||||
|
|
||||||
for (Square square : selectables) {
|
|
||||||
JButton b = buttons.get(63 - square.ordinal());
|
|
||||||
b.setEnabled(true);
|
|
||||||
b.setBackground(Color.RED);
|
|
||||||
b.addActionListener(new ActionListener() {
|
|
||||||
@Override
|
|
||||||
public void actionPerformed(ActionEvent e) {
|
|
||||||
System.out.println("switch to normal");
|
|
||||||
mode = BoardMode.normal;
|
|
||||||
erstelleBrett();
|
|
||||||
}
|
|
||||||
});
|
|
||||||
}
|
|
||||||
|
|
||||||
break;
|
|
||||||
default:
|
|
||||||
break;
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
for (JButton b : this.buttons) {
|
|
||||||
panelLinks.add(b);
|
|
||||||
}
|
|
||||||
|
|
||||||
// int i = 0;i<64;i++)
|
// int i = 0;i<64;i++)
|
||||||
// {
|
// {
|
||||||
|
|
@ -329,8 +271,10 @@ public class SpielFrame extends JFrame {
|
||||||
//
|
//
|
||||||
// }
|
// }
|
||||||
|
|
||||||
ladeBrett();
|
}
|
||||||
|
|
||||||
|
private int mirrowedGrid(int i) {
|
||||||
|
return 63 - (((i / 8) * 8) + (7 - i % 8));
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
|
@ -355,7 +299,8 @@ public class SpielFrame extends JFrame {
|
||||||
belegungen.put(buttons.get(i), "w-" + fen[j]);
|
belegungen.put(buttons.get(i), "w-" + fen[j]);
|
||||||
} else if (fen[j] >= 97 && fen[j] <= 122) { // ein Kleinbuchstabe, also
|
} else if (fen[j] >= 97 && fen[j] <= 122) { // ein Kleinbuchstabe, also
|
||||||
belegungen.put(buttons.get(i), "b-" + fen[j]);
|
belegungen.put(buttons.get(i), "b-" + fen[j]);
|
||||||
buttons.get(i).setEnabled(false); // erstmal deaktivieren, damit weiß beginnen kann
|
// buttons.get(i).setEnabled(false); // erstmal deaktivieren, damit weiß
|
||||||
|
// beginnen kann
|
||||||
}
|
}
|
||||||
buttons.get(i).setIcon(new ImageIcon("src/main/resources/" + (int) fen[j] + ".png"));
|
buttons.get(i).setIcon(new ImageIcon("src/main/resources/" + (int) fen[j] + ".png"));
|
||||||
|
|
||||||
|
|
@ -383,6 +328,10 @@ public class SpielFrame extends JFrame {
|
||||||
|
|
||||||
buttons.add(b);
|
buttons.add(b);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
for (int i = 0; i < buttons.size(); i++) {
|
||||||
|
buttons.get(i).setText(String.valueOf(i)); // Update button text to its index
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
private void setDefaultBackground() {
|
private void setDefaultBackground() {
|
||||||
|
|
@ -398,4 +347,71 @@ public class SpielFrame extends JFrame {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
private void setButtonsActions() {
|
||||||
|
|
||||||
|
List<Square> selectables;
|
||||||
|
|
||||||
|
switch (this.mode) {
|
||||||
|
case BoardMode.normal:
|
||||||
|
selectables = game.getAllLegalMoveableSquares();
|
||||||
|
|
||||||
|
for (Square square : selectables) {
|
||||||
|
final Square currentSquare = square; // ActionListener need it to be final
|
||||||
|
JButton b = buttons.get(mirrowedGrid(square.ordinal()));
|
||||||
|
b.setEnabled(true);
|
||||||
|
b.setBackground(Color.green);
|
||||||
|
b.addActionListener(new ActionListener() {
|
||||||
|
@Override
|
||||||
|
public void actionPerformed(ActionEvent e) {
|
||||||
|
mode = BoardMode.pieceSelected;
|
||||||
|
selectedSquare = currentSquare;
|
||||||
|
erstelleBrett();
|
||||||
|
}
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
break;
|
||||||
|
|
||||||
|
case BoardMode.pieceSelected:
|
||||||
|
JButton s = buttons.get(mirrowedGrid(selectedSquare.ordinal()));
|
||||||
|
s.setEnabled(true);
|
||||||
|
s.setBackground(Color.orange);
|
||||||
|
s.addActionListener(new ActionListener() {
|
||||||
|
@Override
|
||||||
|
public void actionPerformed(ActionEvent e) {
|
||||||
|
mode = BoardMode.normal;
|
||||||
|
selectedSquare = null;
|
||||||
|
erstelleBrett();
|
||||||
|
}
|
||||||
|
}); // cancel action
|
||||||
|
|
||||||
|
selectables = game.getLegalMoveableSquares(selectedSquare);
|
||||||
|
|
||||||
|
for (Square square : selectables) {
|
||||||
|
JButton b = buttons.get(mirrowedGrid(square.ordinal()));
|
||||||
|
final Move move = new Move(selectedSquare, square);
|
||||||
|
b.setEnabled(true);
|
||||||
|
b.setBackground(Color.RED);
|
||||||
|
b.addActionListener(new ActionListener() {
|
||||||
|
@Override
|
||||||
|
public void actionPerformed(ActionEvent e) {
|
||||||
|
game.playMove(move);
|
||||||
|
mode = BoardMode.normal;
|
||||||
|
erstelleBrett();
|
||||||
|
}
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
break;
|
||||||
|
default:
|
||||||
|
break;
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
// Add reversed buttons to the panel
|
||||||
|
for (JButton b : buttons) {
|
||||||
|
panelLinks.add(b);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
|
||||||
Loading…
Reference in New Issue