Перелистывание игровых фигур в реверси на Java
Я не могу заставить мою игру правильно переворачивать плитки. Я застрял на этом в течение бесчисленных часов и не могу понять это. Я проверил другие примеры кода Реверси и, к сожалению, до сих пор нет кубиков. Я заметил, что всякий раз, когда я щелкаю по занятому элементу BoardPiece в графическом интерфейсе, программа не чувствует, что он занят. Любая критика / помощь приветствуется! Заранее спасибо.
Индекс класса {
int row;
int column;
public Index(int row, int column) {
this.row = row;
this.column = column;
}
public int getRow() {
return row;
}
public int getColumn() {
return column;
}
public boolean equals(Index other){
if(this.row == other.row && this.column == other.column){
return true;
}
return false;
}
}
класс GameBoard расширяет JPanel {
static ArrayList<BoardSquare> possibleCaptures = new ArrayList<>();
public BoardSquare BoardSquares[][] = new BoardSquare[8][8];
BoardSquare bs;
Index index;
GameBoard() {
setLayout(new GridLayout(8, 8));
for (int row = 0; row < 8; row++) {
for (int column = 0; column < 8; column++) {
index = new Index(row, column);
BoardSquares[row][column] = new BoardSquare(index, Color.white);
add(BoardSquares[row][column]);
}
}
}
public BoardSquare getBoardSquare(Index index) {
return BoardSquares[index.row][index.column];
}
public void StartingPieces(HumanPlayer p1, aiPlayer p2) {
BoardSquares[3][3].setColor(p1);
BoardSquares[3][4].setColor(p2);
BoardSquares[4][4].setColor(p1);
BoardSquares[4][3].setColor(p2);
}
class BoardSquare extends JLabel {
private Index index;
private Color c = Color.white;
private Border b = BorderFactory.createLineBorder(Color.BLACK, 2);
BoardSquare(Index index, final Color c) {
addMouseListener(new MouseAdapter() {
public void mouseClicked(MouseEvent e) {
if (e.getButton() == 1) {
if (c == Color.white) {
checkCaptures();
System.out.println("Checking");
} else {
System.out.println("This square is already occupied.");
}
}
}
});
this.index = index;
this.c = c;
setBorder(b);
}
public Index getIndex(){
return index;
}
public void setColor(Player p) {
if (p instanceof HumanPlayer) {
c = Color.blue;
}
if (p instanceof aiPlayer) {
c = Color.red;
}
}
public Color getColor() {
return c;
}
private void checkCaptures() {
Direction[] directions = Direction.values();
for (Direction direction : directions) {
// get next piece's index along the direction
Index nextIndex = direction.next(this.index);
if (isValid(nextIndex)) { // if the index is not valid (i.e. edge of the board) ignore it
// get next piece in the same direction
BoardSquare bs = getBoardSquare(nextIndex);
// find all pieces that should be captured in this direction
ArrayList<BoardSquare> squaresToCapture = new ArrayList<>();
bs.findCaptures(squaresToCapture, this.c, direction);
for (BoardSquare candidate : squaresToCapture) {
// flip the color (WHITE to BLACK and vice-versa)
candidate.capture();
}
}
}
}
public void findCaptures(ArrayList<BoardSquare> possibleCaptures, Color col, Direction d) {
Index next = d.next(this.index);
if (this.c == col) {
// This piece has the same color with the first one.
// No need to search further for this direction. All pieces collected in the list
// between the first one and this one, have opposite color and should be captured.
} else if (this.c == Color.white) {
// found a blank piece. Stop the search and clear any captured pieces found so far
possibleCaptures.clear();
} else {
// this piece has the opposite color of the first
if (isValid(next)) {
// this is not the last piece in this direction.
// Since it has a flipped color it is a candidate for capturing
possibleCaptures.add(this);
// ask the next piece recursively to also check itself
BoardSquare bs = getBoardSquare(next);
bs.findCaptures(possibleCaptures, col, d);
} else {
// next index is not valid i.e. we have reached board edge.
// Stop the search and clear any captured pieces found so far
possibleCaptures.clear();
}
}
}
public void capture() {
if (c == Color.red) {
c = Color.blue;
}
if (c == Color.blue) {
c = Color.red;
}
}
public String colorStatus() {
if (c == Color.white) {
return "white";
}
if (c == Color.red) {
return "red";
} else {
return "blue";
}
}
public void paintComponent(Graphics g) {
super.paintComponent(g);
Graphics2D g2 = (Graphics2D) g;
setText(colorStatus());
}
public boolean isValid(Index index) {
if (index.getRow() <= 7 && index.getRow() >= 0) {
if (index.getColumn() <= 7 && index.getColumn() >= 0) {
return true;
}
}
return false;
}
}
}
1 ответ
У вас есть разные переменные с одним и тем же именем.
class BoardSquare extends JLabel {
private Index index;
private Color c = Color.white;
private Border b = BorderFactory.createLineBorder(Color.BLACK, 2);
BoardSquare(Index index, final Color c) {
addMouseListener(new MouseAdapter() {
public void mouseClicked(MouseEvent e) {
if (e.getButton() == 1) {
if (c == Color.white) {
Который c
ты имеешь ввиду здесь? final Color c
или private Color c
? Я думаю ты имеешь ввиду private Color c
, но вы используете final Color c
,
Я бы предложил:
class BoardSquare extends JLabel {
private Index index;
private Color myColor = Color.white;
private Border b = BorderFactory.createLineBorder(Color.BLACK, 2);
BoardSquare(Index index, final Color initialColor) {
addMouseListener(new MouseAdapter() {
public void mouseClicked(MouseEvent e) {
if (e.getButton() == 1) {
if (myColor.equals(Color.white)) {
(Не испытано)
Еще лучше добавить mouseListener на один уровень выше. (Вы протекаете this
в конструкторе, что плохо)
for (int column = 0; column < 8; column++) {
index = new Index(row, column);
BoardSquares[row][column] = new BoardSquare(index, Color.white);
BoardSquares[row][column].addMouseListener( .. );