Merge branch 'devFeldRotieren'

cleanup
dstuck 2025-06-25 04:48:17 +02:00
commit 516ecb1b10
3 changed files with 77 additions and 38 deletions

View File

@ -44,6 +44,11 @@ public class ButtonMovePieceListener implements ActionListener {
} }
this.sf.setCursor(null); this.sf.setCursor(null);
//hier rotieren markieren
if(game.isRotieren())sf.setWechsel(!sf.isWechsel());
this.sf.erstelleBrett(); this.sf.erstelleBrett();
if (game.getLastMove() != null) { if (game.getLastMove() != null) {

View File

@ -13,7 +13,6 @@ import com.github.bhlangonijr.chesslib.Side;
import com.github.bhlangonijr.chesslib.Square; import com.github.bhlangonijr.chesslib.Square;
import com.github.bhlangonijr.chesslib.move.Move; import com.github.bhlangonijr.chesslib.move.Move;
import com.github.bhlangonijr.chesslib.move.MoveList; import com.github.bhlangonijr.chesslib.move.MoveList;
import com.github.bhlangonijr.chesslib.pgn.PgnHolder;
import de.mannheim.th.chess.App; import de.mannheim.th.chess.App;
import de.mannheim.th.chess.utl.Clock; import de.mannheim.th.chess.utl.Clock;
@ -335,4 +334,9 @@ public class Game {
this.board.doMove(this.movelist.get(i)); this.board.doMove(this.movelist.get(i));
} }
} }
public boolean isRotieren() {
return rotieren;
}
} }

View File

@ -61,12 +61,13 @@ public class SpielFrame extends JFrame {
private Game game; private Game game;
private Clock clock; private Clock clock;
private ArrayList<String> anzeigeMoves = new ArrayList<String>(); private ArrayList<String> anzeigeMoves = new ArrayList<String>();
private boolean wechsel = false;
private BoardMode mode; private BoardMode mode;
private Square selectedSquare; private Square selectedSquare;
public enum BoardMode { public enum BoardMode {
normal, pieceSelected, finished normal, pieceSelected, finished, gameEnd
} }
/** /**
@ -143,37 +144,45 @@ public class SpielFrame extends JFrame {
* holt sich FEN-Zeichenkette und extrahiert daraus die Positionen der Figuren * holt sich FEN-Zeichenkette und extrahiert daraus die Positionen der Figuren
*/ */
public void ladeBrett() { public void ladeBrett() {
// System.out.println(game.toFEN());
char[] fen = game.toFEN().replaceAll("/", "").split(" ")[0].toCharArray(); char[] fen = game.toFEN().replaceAll("/", "").split(" ")[0].toCharArray();
int i = 0; int i = 0;
for (int j = 0; j < fen.length; j++) { for (int j = 0; j < fen.length; j++) {
if (Character.isDigit(fen[j])) { if (Character.isDigit(fen[j])) {
int leerfelder = Character.getNumericValue(fen[j]); int leerfelder = Character.getNumericValue(fen[j]);
for (int k = 0; k < leerfelder; k++) { for (int k = 0; k < leerfelder; k++) {
belegungen.put(buttons.get(i), "n-n"); int idx;
// buttons.get(i).setEnabled(false); // erstmal deaktivieren, weil leere Felder if (game.isRotieren())
// nicht ckickbar sein sollten. idx = wechsel ? mirrowedGrid(i) : i;
else
idx = i;
belegungen.put(buttons.get(idx), "n-n");
i++; i++;
} }
continue; continue;
} else if (fen[j] >= 65 && fen[j] <= 90) { // ein Großbuchstabe, also } else if (fen[j] >= 65 && fen[j] <= 90) { // Großbuchstabe = weiß
belegungen.put(buttons.get(i), "w-" + fen[j]); int idx;
} else if (fen[j] >= 97 && fen[j] <= 122) { // ein Kleinbuchstabe, also if (game.isRotieren())
belegungen.put(buttons.get(i), "b-" + fen[j]); idx = wechsel ? mirrowedGrid(i) : i;
// buttons.get(i).setEnabled(false); // erstmal deaktivieren, damit weiß else
// beginnen kann idx = i;
belegungen.put(buttons.get(idx), "w-" + fen[j]);
} else if (fen[j] >= 97 && fen[j] <= 122) { // Kleinbuchstabe = schwarz
int idx;
if (game.isRotieren())
idx = wechsel ? mirrowedGrid(i) : i;
else
idx = i;
belegungen.put(buttons.get(idx), "b-" + fen[j]);
} }
buttons.get(i).setIcon(new ImageIcon("src/main/resources/" + (int) fen[j] + ".png")); int idx;
buttons.get(i).setDisabledIcon(new ImageIcon("src/main/resources/" + (int) fen[j] + ".png")); if (game.isRotieren())
idx = wechsel ? mirrowedGrid(i) : i;
else
idx = i;
buttons.get(idx).setIcon(new ImageIcon("src/main/resources/" + (int) fen[j] + ".png"));
buttons.get(idx).setDisabledIcon(new ImageIcon("src/main/resources/" + (int) fen[j] + ".png"));
i++; i++;
} }
panelLinks.revalidate();
panelLinks.repaint();
} }
/** /**
@ -233,47 +242,60 @@ public class SpielFrame extends JFrame {
List<Square> selectables; List<Square> selectables;
switch (this.mode) { switch (this.mode) {
case BoardMode.normal: case normal:
selectables = game.getAllLegalMoveableSquares(); selectables = game.getAllLegalMoveableSquares();
for (Square square : selectables) { for (Square square : selectables) {
JButton b = buttons.get(mirrowedGrid(square.ordinal())); int idx;
if (game.isRotieren())
idx = wechsel ? square.ordinal() : mirrowedGrid(square.ordinal());
else
idx = this.mirrowedGrid(square.ordinal());
JButton b = buttons.get(idx);
b.setEnabled(true); b.setEnabled(true);
// b.setBackground(Color.green);
b.addActionListener(new ButtonSelectPieceListener(this, square)); b.addActionListener(new ButtonSelectPieceListener(this, square));
} }
break; break;
case BoardMode.pieceSelected: case pieceSelected:
int idxSelected;
JButton s = buttons.get(mirrowedGrid(selectedSquare.ordinal())); if (game.isRotieren())
idxSelected = wechsel ? selectedSquare.ordinal() : mirrowedGrid(selectedSquare.ordinal());
else
idxSelected = mirrowedGrid(selectedSquare.ordinal());
JButton s = buttons.get(idxSelected);
s.setEnabled(true); s.setEnabled(true);
s.setBackground(new Color(165, 42, 42)); s.setBackground(new Color(165, 42, 42));
s.addActionListener(new ButtonToNormalListener(this)); s.addActionListener(new ButtonToNormalListener(this));
selectables = game.getLegalMoveableSquares(selectedSquare); selectables = game.getLegalMoveableSquares(selectedSquare);
for (Square square : selectables) { for (Square square : selectables) {
JButton b = buttons.get(mirrowedGrid(square.ordinal())); int idx;
if (game.isRotieren())
idx = wechsel ? square.ordinal() : mirrowedGrid(square.ordinal());
else
idx = mirrowedGrid(square.ordinal());
final Move move = new Move(selectedSquare, square); final Move move = new Move(selectedSquare, square);
JButton b = buttons.get(idx);
b.setEnabled(true); b.setEnabled(true);
b.setBackground(new Color(230, 100, 100)); b.setBackground(new Color(230, 100, 100));
b.addActionListener(new ButtonMovePieceListener(this, this.game, move)); b.addActionListener(new ButtonMovePieceListener(this, this.game, move));
} }
break; break;
case finished: case finished:
// this.enableControlPanelButtons(); clearButtons();
// this.viewPointer = this.game.getMoveList().size() - 1;
break; break;
case gameEnd:
break;
default: default:
break; break;
}
for (JButton b : buttons) {
panelLinks.add(b);
} }
} }
@ -632,4 +654,12 @@ public class SpielFrame extends JFrame {
this.aufgeben2 = aufgeben2; this.aufgeben2 = aufgeben2;
} }
public void setWechsel(boolean wechsel) {
this.wechsel = wechsel;
}
public boolean isWechsel() {
return wechsel;
}
} }