list istället för arraylist

This commit is contained in:
Love 2022-11-24 18:47:37 +01:00
parent e8581663c7
commit ae692d1428
No known key found for this signature in database
GPG Key ID: A3C10DC241C8FA9F
10 changed files with 42 additions and 34 deletions

View File

@ -2,7 +2,7 @@ package schack;
import java.awt.Point; import java.awt.Point;
import java.io.IOException; import java.io.IOException;
import java.util.ArrayList; import java.util.List;
public class Bishop extends LongWalkers { public class Bishop extends LongWalkers {
@ -11,7 +11,7 @@ public class Bishop extends LongWalkers {
} }
@Override @Override
public ArrayList<Point> validMoves(Piece[][] pieces, boolean allowedToRecurse) { public List<Point> validMoves(Piece[][] pieces, boolean allowedToRecurse) {
return getMoves( return getMoves(
new int[][]{{-1, -1}, {1, 1}, {-1, 1}, {1, -1}}, new int[][]{{-1, -1}, {1, 1}, {-1, 1}, {1, -1}},
pieces, pieces,

View File

@ -9,6 +9,7 @@ import java.awt.event.MouseEvent;
import java.awt.event.MouseListener; import java.awt.event.MouseListener;
import java.io.IOException; import java.io.IOException;
import java.util.ArrayList; import java.util.ArrayList;
import java.util.List;
import javax.swing.JOptionPane; import javax.swing.JOptionPane;
import javax.swing.JPanel; import javax.swing.JPanel;
@ -16,7 +17,7 @@ public class Board extends JPanel implements MouseListener {
public static final int SIZE_OF_TILE = 100; public static final int SIZE_OF_TILE = 100;
private Piece[][] pieces = new Piece[8][8]; private Piece[][] pieces = new Piece[8][8];
private ArrayList<Point> validMovesToDraw = new ArrayList<>(); private List<Point> validMovesToDraw = new ArrayList<>();
private Point previouslyClickedPoint = new Point(); private Point previouslyClickedPoint = new Point();
private final Color moveableColor = new Color(255, 191, 0); private final Color moveableColor = new Color(255, 191, 0);
short turnCount = 0; short turnCount = 0;
@ -161,8 +162,8 @@ public class Board extends JPanel implements MouseListener {
* @return SCHACK, SCHACKMATT, PATT, NORMAL * @return SCHACK, SCHACKMATT, PATT, NORMAL
*/ */
private SchackState getSchackState() { private SchackState getSchackState() {
ArrayList<Point> allValidMoves = getMoves(whitesTurn); List<Point> allValidMoves = getMoves(whitesTurn);
ArrayList<Point> opposingAttacks = getAttacks(!whitesTurn); List<Point> opposingAttacks = getAttacks(!whitesTurn);
boolean weCanMove = !allValidMoves.isEmpty(); boolean weCanMove = !allValidMoves.isEmpty();
boolean inSchack = false; boolean inSchack = false;
@ -188,8 +189,8 @@ public class Board extends JPanel implements MouseListener {
return SchackState.NORMAL; return SchackState.NORMAL;
} }
private ArrayList<Point> getMoves(boolean whiteMovesAreWanted) { private List<Point> getMoves(boolean whiteMovesAreWanted) {
ArrayList<Point> allValidMoves = new ArrayList<>(); List<Point> allValidMoves = new ArrayList<>();
for (Piece[] pieceArr : pieces) { for (Piece[] pieceArr : pieces) {
for (Piece piece : pieceArr) { for (Piece piece : pieceArr) {
if (piece == null || whiteMovesAreWanted != piece.isWhite()) { if (piece == null || whiteMovesAreWanted != piece.isWhite()) {
@ -201,8 +202,8 @@ public class Board extends JPanel implements MouseListener {
return allValidMoves; return allValidMoves;
} }
public ArrayList<Point> getAttacks(boolean whiteAttacksAreWanted) { public List<Point> getAttacks(boolean whiteAttacksAreWanted) {
ArrayList attacks = new ArrayList(); List attacks = new ArrayList();
for (Piece[] pieceArr : pieces) { for (Piece[] pieceArr : pieces) {
for (Piece piece : pieceArr) { for (Piece piece : pieceArr) {
if (piece == null || whiteAttacksAreWanted != piece.isWhite()) { if (piece == null || whiteAttacksAreWanted != piece.isWhite()) {

View File

@ -3,6 +3,7 @@ package schack;
import java.awt.Point; import java.awt.Point;
import java.io.IOException; import java.io.IOException;
import java.util.ArrayList; import java.util.ArrayList;
import java.util.List;
public class Horse extends Piece { public class Horse extends Piece {
@ -11,8 +12,8 @@ public class Horse extends Piece {
} }
@Override @Override
public ArrayList<Point> validMoves(Piece[][] pieces, boolean allowedToRecurse) { public List<Point> validMoves(Piece[][] pieces, boolean allowedToRecurse) {
ArrayList<Point> movable = new ArrayList<>(); List<Point> movable = new ArrayList<>();
for (int dx : new int[]{-2, -1, 1, 2}) { for (int dx : new int[]{-2, -1, 1, 2}) {
for (int direction : new int[]{-1, 1}) { for (int direction : new int[]{-1, 1}) {

View File

@ -3,6 +3,7 @@ package schack;
import java.awt.Point; import java.awt.Point;
import java.io.IOException; import java.io.IOException;
import java.util.ArrayList; import java.util.ArrayList;
import java.util.List;
public final class King extends Piece { public final class King extends Piece {
@ -17,8 +18,8 @@ public final class King extends Piece {
* @param pieces * @param pieces
* @return * @return
*/ */
private ArrayList<Point> getCastlingIfPossible(Piece[][] pieces) { private List<Point> getCastlingIfPossible(Piece[][] pieces) {
ArrayList<Point> possibleCastling = new ArrayList<>(); List<Point> possibleCastling = new ArrayList<>();
if (this.isMoved()) { if (this.isMoved()) {
return possibleCastling; return possibleCastling;
} }
@ -78,8 +79,8 @@ public final class King extends Piece {
} }
@Override @Override
public ArrayList<Point> validMoves(Piece[][] pieces, boolean allowedToRecurse) { public List<Point> validMoves(Piece[][] pieces, boolean allowedToRecurse) {
ArrayList<Point> movable = new ArrayList<>(); List<Point> movable = new ArrayList<>();
for (int loopX = -1; loopX < 2; loopX++) { for (int loopX = -1; loopX < 2; loopX++) {
for (int loopY = -1; loopY < 2; loopY++) { for (int loopY = -1; loopY < 2; loopY++) {

View File

@ -3,6 +3,7 @@ package schack;
import java.awt.Point; import java.awt.Point;
import java.io.IOException; import java.io.IOException;
import java.util.ArrayList; import java.util.ArrayList;
import java.util.List;
public abstract class LongWalkers extends Piece { public abstract class LongWalkers extends Piece {
@ -21,8 +22,8 @@ public abstract class LongWalkers extends Piece {
* @param allowedToRecurse * @param allowedToRecurse
* @return * @return
*/ */
ArrayList<Point> getMoves(int[][] directions, Piece[][] pieces, boolean allowedToRecurse) { List<Point> getMoves(int[][] directions, Piece[][] pieces, boolean allowedToRecurse) {
ArrayList<Point> movable = new ArrayList<>(); List<Point> movable = new ArrayList<>();
for (int[] xy : directions) { for (int[] xy : directions) {
int loopX = this.position.x, loopY = this.position.y; int loopX = this.position.x, loopY = this.position.y;

View File

@ -4,6 +4,7 @@ import java.awt.HeadlessException;
import java.awt.Point; import java.awt.Point;
import java.io.IOException; import java.io.IOException;
import java.util.ArrayList; import java.util.ArrayList;
import java.util.List;
import javax.swing.JOptionPane; import javax.swing.JOptionPane;
public class Pawn extends Piece { public class Pawn extends Piece {
@ -21,8 +22,8 @@ public class Pawn extends Piece {
* @return Alla lämpliga attackMoves * @return Alla lämpliga attackMoves
*/ */
@Override @Override
public ArrayList<Point> validAttacks(Piece[][] pieces, boolean shouldNotCareIfAttackSpaceIsEmptyOrNot) { public List<Point> validAttacks(Piece[][] pieces, boolean shouldNotCareIfAttackSpaceIsEmptyOrNot) {
ArrayList<Point> movable = new ArrayList<>(); List<Point> movable = new ArrayList<>();
// Kolla ifall vi kan ta någon // Kolla ifall vi kan ta någon
for (int pawnX : new int[]{-1, 1}) { for (int pawnX : new int[]{-1, 1}) {
@ -42,8 +43,8 @@ public class Pawn extends Piece {
} }
@Override @Override
public ArrayList<Point> validMoves(Piece[][] pieces, boolean allowedToRecurse) { public List<Point> validMoves(Piece[][] pieces, boolean allowedToRecurse) {
ArrayList<Point> movable = new ArrayList<>(); List<Point> movable = new ArrayList<>();
// Om bonden har gått en gång, får 1 steg, annars 2 // Om bonden har gått en gång, får 1 steg, annars 2
final int upTo = this.isMoved() ? 1 : 2; final int upTo = this.isMoved() ? 1 : 2;
@ -75,8 +76,8 @@ public class Pawn extends Piece {
* @param movable * @param movable
* @param pieces * @param pieces
*/ */
private ArrayList<Point> addAttackMovesIfCan(Point pos, Piece[][] pieces) { private List<Point> addAttackMovesIfCan(Point pos, Piece[][] pieces) {
ArrayList<Point> movable = new ArrayList(); List<Point> movable = new ArrayList();
// Se till att vi inte är utanför brädet // Se till att vi inte är utanför brädet
if (pos.x >= pieces.length || pos.x < 0 || pos.y >= pieces[0].length || pos.y < 0) { if (pos.x >= pieces.length || pos.x < 0 || pos.y >= pieces[0].length || pos.y < 0) {
return movable; return movable;
@ -92,7 +93,7 @@ public class Pawn extends Piece {
} }
@Override @Override
protected boolean addMovesIfCan(Point pos, ArrayList movable, Piece[][] pieces, boolean allowedToRecurse) { protected boolean addMovesIfCan(Point pos, List movable, Piece[][] pieces, boolean allowedToRecurse) {
if (pos.x < 0 || pos.x > 7 || pos.y < 0 || pos.y > 7) { if (pos.x < 0 || pos.x > 7 || pos.y < 0 || pos.y > 7) {
return false; return false;
} }

View File

@ -6,6 +6,7 @@ import java.awt.image.BufferedImage;
import java.io.IOException; import java.io.IOException;
import java.io.InputStream; import java.io.InputStream;
import java.util.ArrayList; import java.util.ArrayList;
import java.util.List;
import javax.imageio.ImageIO; import javax.imageio.ImageIO;
public abstract class Piece { public abstract class Piece {
@ -18,7 +19,7 @@ public abstract class Piece {
/** /**
* Sant ifall pjäsens färg är vit, falskt ifall den är svart * Sant ifall pjäsens färg är vit, falskt ifall den är svart
*/ */
private boolean isWhite; private final boolean isWhite;
/** /**
* SPECIAL RULÖES APPLY TO THE KING, (ITS GOOD TO BE THE KING:) * SPECIAL RULÖES APPLY TO THE KING, (ITS GOOD TO BE THE KING:)
*/ */
@ -64,7 +65,7 @@ public abstract class Piece {
* @param allowedToRecurse * @param allowedToRecurse
* @return * @return
*/ */
public abstract ArrayList<Point> validMoves(Piece[][] pieces, boolean allowedToRecurse); public abstract List<Point> validMoves(Piece[][] pieces, boolean allowedToRecurse);
/** /**
* Ger tillbaks alla ställen pjäsen kan attackera * Ger tillbaks alla ställen pjäsen kan attackera
@ -74,7 +75,7 @@ public abstract class Piece {
* kolla ifall det är något i möjliga attackrutor ifall * kolla ifall det är något i möjliga attackrutor ifall
* @return Alla lämpliga attackMoves * @return Alla lämpliga attackMoves
*/ */
public ArrayList<Point> validAttacks(Piece[][] pieces, boolean shouldNotCareIfAttackSpaceIsEmptyOrNot) { public List<Point> validAttacks(Piece[][] pieces, boolean shouldNotCareIfAttackSpaceIsEmptyOrNot) {
return validMoves(pieces, false); return validMoves(pieces, false);
} }
@ -121,7 +122,7 @@ public abstract class Piece {
* *
* @return true ifall man inte kan längre i denna riktning * @return true ifall man inte kan längre i denna riktning
*/ */
protected boolean addMovesIfCan(Point pos, ArrayList<Point> movable, Piece[][] pieces, boolean allowedToRecurse) { protected boolean addMovesIfCan(Point pos, List<Point> movable, Piece[][] pieces, boolean allowedToRecurse) {
// Ifall vi är utanför brädet ge tillbaka false // Ifall vi är utanför brädet ge tillbaka false
if (pos.x > 7 || pos.x < 0 || pos.y > 7 || pos.y < 0) { if (pos.x > 7 || pos.x < 0 || pos.y > 7 || pos.y < 0) {
return false; return false;
@ -186,7 +187,7 @@ public abstract class Piece {
* @return true ifall det är schack * @return true ifall det är schack
*/ */
protected boolean isInSchack(Piece[][] pieces) { protected boolean isInSchack(Piece[][] pieces) {
ArrayList<Point> enemyAttacks = new ArrayList<>(); List<Point> enemyAttacks = new ArrayList<>();
// Fråga alla pjäser vart de kan /ta // Fråga alla pjäser vart de kan /ta
for (Piece[] pieceArr : pieces) { for (Piece[] pieceArr : pieces) {

View File

@ -2,7 +2,7 @@ package schack;
import java.awt.Point; import java.awt.Point;
import java.io.IOException; import java.io.IOException;
import java.util.ArrayList; import java.util.List;
public class Queen extends LongWalkers { public class Queen extends LongWalkers {
@ -11,7 +11,7 @@ public class Queen extends LongWalkers {
} }
@Override @Override
public ArrayList<Point> validMoves(Piece[][] pieces, boolean allowedToRecurse) { public List<Point> validMoves(Piece[][] pieces, boolean allowedToRecurse) {
return getMoves( return getMoves(
new int[][]{{1, 0}, {-1, 0}, {0, 1}, {-1, -1}, {0, -1}, {1, 1}, {-1, 1}, {1, -1}}, new int[][]{{1, 0}, {-1, 0}, {0, 1}, {-1, -1}, {0, -1}, {1, 1}, {-1, 1}, {1, -1}},
pieces, pieces,

View File

@ -2,7 +2,7 @@ package schack;
import java.awt.Point; import java.awt.Point;
import java.io.IOException; import java.io.IOException;
import java.util.ArrayList; import java.util.List;
public class Rook extends LongWalkers { public class Rook extends LongWalkers {
@ -11,7 +11,7 @@ public class Rook extends LongWalkers {
} }
@Override @Override
public ArrayList<Point> validMoves(Piece[][] pieces, boolean allowedToRecurse) { public List<Point> validMoves(Piece[][] pieces, boolean allowedToRecurse) {
return getMoves( return getMoves(
new int[][]{{1, 0}, {-1, 0}, {0, 1}, {0, -1}}, new int[][]{{1, 0}, {-1, 0}, {0, 1}, {0, -1}},
pieces, pieces,

View File

@ -1,9 +1,11 @@
package schack; package schack;
import java.awt.HeadlessException;
import java.awt.event.ActionEvent; import java.awt.event.ActionEvent;
import java.io.IOException; import java.io.IOException;
import java.net.Inet4Address; import java.net.Inet4Address;
import java.net.NetworkInterface; import java.net.NetworkInterface;
import java.net.UnknownHostException;
import javax.swing.JFrame; import javax.swing.JFrame;
import javax.swing.JMenu; import javax.swing.JMenu;
import javax.swing.JMenuBar; import javax.swing.JMenuBar;
@ -74,7 +76,7 @@ public class Schack {
String ip = Inet4Address.getLocalHost().toString(); String ip = Inet4Address.getLocalHost().toString();
JOptionPane.showMessageDialog(null, "IP: " + ip); JOptionPane.showMessageDialog(null, "IP: " + ip);
} catch (Exception e) { } catch (HeadlessException | UnknownHostException e) {
} }
}); });
connectToOpponent.addActionListener((ActionEvent ae) -> { connectToOpponent.addActionListener((ActionEvent ae) -> {