Compare commits

..

6 Commits

8 changed files with 121 additions and 90 deletions

View File

@ -12,6 +12,8 @@ public class BoardDisplay extends JPanel {
private JButton[][] fields; private JButton[][] fields;
private int gridSize; private int gridSize;
private List <Ship> ships; private List <Ship> ships;
private Ship currentShip;
private Player player;
/** /**
* Konstruktor der startLocalGame. * Konstruktor der startLocalGame.
@ -20,9 +22,11 @@ public class BoardDisplay extends JPanel {
* @param player * @param player
*/ */
public BoardDisplay(int gridSize, Player player) { public BoardDisplay(int gridSize, Player player) {
super(new GridLayout(gridSize + 1, gridSize + 1)); // +1 wegen extra Zeile/Splate super(new GridLayout(gridSize + 1, gridSize + 1)); // +1 wegen extra Zeile/Spalte
this.fields = new JButton[gridSize][gridSize]; this.fields = new JButton[gridSize][gridSize];
this.ships = new ArrayList<>(); this.ships = new ArrayList<>();
this.player = player;
// Erstellung von Spielfeld // Erstellung von Spielfeld
for (int i = 0; i <= gridSize; i++) { for (int i = 0; i <= gridSize; i++) {
for (int j = 0; j <= gridSize; j++) { for (int j = 0; j <= gridSize; j++) {
@ -43,7 +47,7 @@ public class BoardDisplay extends JPanel {
} else { } else {
// Spielfeld (interaktive Zellen) // Spielfeld (interaktive Zellen)
JButton field = new JButton(""); JButton field = new JButton("");
field.setBackground(Color.LIGHT_GRAY); field.setBackground(Color.BLUE);
field.setOpaque(true); field.setOpaque(true);
field.setBorderPainted(true); field.setBorderPainted(true);
fields[i - 1][j - 1] = field; fields[i - 1][j - 1] = field;
@ -68,16 +72,19 @@ public class BoardDisplay extends JPanel {
public void mouseClicked(MouseEvent e) { public void mouseClicked(MouseEvent e) {
Point o= new Point(finalI, finalJ); Point o= new Point(finalI, finalJ);
System.out.println(o); System.out.println(o);
handleFieldClick(field, o,player); handleFieldClick(o);
} }
}); });
} }
} }
} }
// this.ships = new ArrayList<Ship>(); // this.ships = new ArrayList<Ship>();
} }
public void selectCurrentShip(Ship ship) {
this.currentShip = ship;
}
/** /**
* TODO Funktion beschreiben etc. * TODO Funktion beschreiben etc.
* @param ship * @param ship
@ -148,14 +155,31 @@ public class BoardDisplay extends JPanel {
/** /**
* TODO Funktion beschreiben etc. * TODO Funktion beschreiben etc.
* @param field
* @param o * @param o
* @param player
*/ */
private void handleFieldClick(JButton field, Point o,Player player) { private void handleFieldClick(Point o) {
this.currentShip.setPosition(o,player.getBoard().getShips(),gridSize);
paintFields();
// Beispiel: Setze ein Schiff bei einem Klick // Beispiel: Setze ein Schiff bei einem Klick
if (setShip(new Ship(3, "TestShip"), o, true,player)) { //if (setShip(new Ship(3, "TestShip"), o, true,player)) {
field.setBackground(Color.BLUE); // Visualisiere Schiff // field.setBackground(Color.BLUE); // Visualisiere Schiff
//}
}
public void paintFields() {
for(int i = 0; i <= gridSize; i++) {
for(int j = 0; j <= gridSize; j++) {
if(fields[i][j] == null) {
continue;
}
fields[i][j].setBackground(Color.BLUE);
for(Ship ship: player.getBoard().getShips()) {
if(ship.isShipOnPos(new Point(i,j))) {
fields[i][j].setBackground(Color.LIGHT_GRAY);
break;
}
}
}
} }
} }
} }

View File

@ -37,36 +37,9 @@ public class GameBoard extends JPanel {
* @param p2 Zweites Spielerobjekt * @param p2 Zweites Spielerobjekt
*/ */
GameBoard(MainFrame frame, int semesterCounter,Player p1, Player p2) { GameBoard(MainFrame frame, int semesterCounter,Player p1, Player p2) {
JToggleButton leftPlayerModul1 = new JToggleButton("Modul 1"); //TODO: Dynamische Namen durch abgleich mit Semester buildPanel(frame, semesterCounter,p1,p2);
JToggleButton leftPlayerModul2 = new JToggleButton("Modul 2");
JToggleButton leftPlayerModul3 = new JToggleButton("Modul 3");
JToggleButton leftPlayerModul4 = new JToggleButton("Modul 4");
JToggleButton leftPlayerModul5 = new JToggleButton("Modul 5");
JToggleButton leftPlayerModul6 = new JToggleButton("Modul 6");
JToggleButton leftPlayerModul7 = new JToggleButton("Reset");
JToggleButton[] leftPlayerButtons=new JToggleButton[]{
leftPlayerModul1, leftPlayerModul2, leftPlayerModul3, leftPlayerModul4,
leftPlayerModul5, leftPlayerModul6, leftPlayerModul7,
};
// Gegnerische ModulButtons
JToggleButton rightPlayerModul1 = new JToggleButton("Modul 1");
JToggleButton rightPlayerModul2 = new JToggleButton("Modul 2");
JToggleButton rightPlayerModul3 = new JToggleButton("Modul 3");
JToggleButton rightPlayerModul4 = new JToggleButton("Modul 4");
JToggleButton rightPlayerModul5 = new JToggleButton("Modul 5");
JToggleButton rightPlayerModul6 = new JToggleButton("Modul 6");
JToggleButton rightPlayerModul7 = new JToggleButton("Bereit");
JToggleButton[] rightlayerButtons=new JToggleButton[]{
rightPlayerModul1, rightPlayerModul2, rightPlayerModul3, rightPlayerModul4,
rightPlayerModul5, rightPlayerModul6, rightPlayerModul7,
};
buildPanel(frame, semesterCounter,p1,p2,leftPlayerButtons,rightlayerButtons);
List<Ship> shipsP1 =p1.getBoard().getShips(); List<Ship> shipsP1 =p1.getBoard().getShips();
updateButtonLabels(shipsP1,leftPlayerButtons); List<Ship> shipsP2 =p2.getBoard().getShips();
backButton.addActionListener(e -> frame.showPanel("MainMenu")); backButton.addActionListener(e -> frame.showPanel("MainMenu"));
} }
@ -88,67 +61,52 @@ public class GameBoard extends JPanel {
* @param semesterCounter * @param semesterCounter
* @param p1 * @param p1
* @param p2 * @param p2
* @param leftButtons
* @param rightButtons
*/ */
public void buildPanel(MainFrame frame, int semesterCounter,Player p1,Player p2,JToggleButton[] leftButtons,JToggleButton[] rightButtons) { public void buildPanel(MainFrame frame, int semesterCounter,Player p1,Player p2) {
// Hauptlayout - BorderLayout für die Anordnung der Komponenten // Hauptlayout - BorderLayout für die Anordnung der Komponenten
setLayout(new BorderLayout()); setLayout(new BorderLayout());
// Spielfelder erstellen (eigenes und gegnerisches)
// Spielfelder werden in BoardDisplay erstellt
int gridSize = GameController.semesterToBoardSize(semesterCounter); // Größe des Spielfelds
BoardDisplay ownBoardPanel = new BoardDisplay(gridSize,p1);
BoardDisplay opponentBoardPanel = new BoardDisplay(gridSize, p2);
// Panel für das Kontext-Text-Feld // Panel für das Kontext-Text-Feld
JPanel headerPanel = new JPanel(); JPanel headerPanel = new JPanel();
headerPanel.setLayout(new BorderLayout()); headerPanel.setLayout(new BorderLayout());
headerPanel.add(kontextText, BorderLayout.WEST); headerPanel.add(kontextText, BorderLayout.WEST);
headerPanel.add(backButton, BorderLayout.EAST); headerPanel.add(backButton, BorderLayout.EAST);
// Panel für die Buttons des linken Spielers (ganz links)
JPanel leftButtonsPanel = new JPanel(); JPanel leftButtonsPanel = new JPanel();
leftButtonsPanel.setLayout(new GridLayout(7, 1)); // 6 Buttons untereinander leftButtonsPanel.setLayout(new GridLayout(7, 1)); // 6 Buttons untereinander
leftButtonsPanel.add(leftButtons[0]);
leftButtonsPanel.add(leftButtons[1]);
leftButtonsPanel.add(leftButtons[2]);
leftButtonsPanel.add(leftButtons[3]);
leftButtonsPanel.add(leftButtons[4]);
leftButtonsPanel.add(leftButtons[5]);
leftButtonsPanel.add(leftButtons[6]);
// Panel für die Buttons des rechten Spielers (ganz rechts)
JPanel rightButtonsPanel = new JPanel(); JPanel rightButtonsPanel = new JPanel();
rightButtonsPanel.setLayout(new GridLayout(7, 1)); // 6 Buttons untereinander rightButtonsPanel.setLayout(new GridLayout(7, 1));
rightButtonsPanel.add(rightButtons[0]);
rightButtonsPanel.add(rightButtons[1]); // Panel für die Buttons des linken Spielers (ganz links)
rightButtonsPanel.add(rightButtons[2]); for(Ship ship : p1.getBoard().getShips()) {
rightButtonsPanel.add(rightButtons[3]); ShipButton shipButton= new ShipButton(ship,ownBoardPanel);
rightButtonsPanel.add(rightButtons[4]); leftButtonsPanel.add(shipButton);
rightButtonsPanel.add(rightButtons[5]); }
rightButtonsPanel.add(rightButtons[6]);
for(Ship ship : p2.getBoard().getShips()) {
ShipButton shipButton= new ShipButton(ship,ownBoardPanel);
rightButtonsPanel.add(shipButton);
}
JToggleButton rightPlayerModul7 = new JToggleButton("Bereit");
rightButtonsPanel.add(rightPlayerModul7);
JToggleButton leftPlayerModul7 = new JToggleButton("Reset");
leftButtonsPanel.add(leftPlayerModul7);
// Panel für die Buttons des rechten Spielers (ganz rechts)
// Spielfelder erstellen (eigenes und gegnerisches)
int gridSize = GameController.semesterToBoardSize(semesterCounter); // Größe des Spielfelds
// Spielfelder werden in BoardDisplay erstellt
//JPanel ownBoardPanel = new JPanel(new GridLayout(gridSize, gridSize)); //JPanel ownBoardPanel = new JPanel(new GridLayout(gridSize, gridSize));
//JPanel opponentBoardPanel = new JPanel(new GridLayout(gridSize, gridSize)); //JPanel opponentBoardPanel = new JPanel(new GridLayout(gridSize, gridSize));
JPanel ownBoardPanel = new BoardDisplay(gridSize,p1);
JPanel opponentBoardPanel = new BoardDisplay(gridSize, p2);
//Buttons in eine Gruppe packen damit diese beim drücken eines anderen Buttons wieder entwählt werden //Buttons in eine Gruppe packen damit diese beim drücken eines anderen Buttons wieder entwählt werden
ButtonGroup leftButtonGroup= new ButtonGroup(); ButtonGroup leftButtonGroup= new ButtonGroup();
leftButtonGroup.add(leftButtons[0]);
leftButtonGroup.add(leftButtons[1]);
leftButtonGroup.add(leftButtons[2]);
leftButtonGroup.add(leftButtons[3]);
leftButtonGroup.add(leftButtons[4]);
leftButtonGroup.add(leftButtons[5]);
leftButtonGroup.add(leftButtons[6]);
ButtonGroup rightButtonGroup= new ButtonGroup(); ButtonGroup rightButtonGroup= new ButtonGroup();
rightButtonGroup.add(rightButtons[0]);
rightButtonGroup.add(rightButtons[1]);
rightButtonGroup.add(rightButtons[2]);
rightButtonGroup.add(rightButtons[3]);
rightButtonGroup.add(rightButtons[4]);
rightButtonGroup.add(rightButtons[5]);
rightButtonGroup.add(rightButtons[6]);
// Panel für beide Spielfelder (nebeneinander in der Mitte) // Panel für beide Spielfelder (nebeneinander in der Mitte)
JPanel centerPanel = new JPanel(); JPanel centerPanel = new JPanel();
@ -161,6 +119,5 @@ public class GameBoard extends JPanel {
add(rightButtonsPanel, BorderLayout.EAST); add(rightButtonsPanel, BorderLayout.EAST);
add(headerPanel, BorderLayout.NORTH); add(headerPanel, BorderLayout.NORTH);
add(centerPanel, BorderLayout.CENTER); add(centerPanel, BorderLayout.CENTER);
} }
} }

View File

@ -16,9 +16,6 @@ public class GameController {
GameController.mainFrame = mainFrame; GameController.mainFrame = mainFrame;
} }
// Connection timeout for client sockets in milliseconds
public static final int CONNECTION_TIMEOUT = 10 * 1000;
public static int semesterToBoardSize(int semester) { public static int semesterToBoardSize(int semester) {
return semester + 13; return semester + 13;
} }
@ -71,11 +68,18 @@ public class GameController {
throw new RuntimeException("Unable to instantiate players"); throw new RuntimeException("Unable to instantiate players");
} }
localPlayer.isServer = localPlayerIsServer; localPlayer.isServer = localPlayerIsServer;
onlinePlayer.isServer = !localPlayerIsServer; onlinePlayer.isServer = !localPlayerIsServer;
localPlayer.setName(localPlayerName);
startGameWithInstancedPlayers(localPlayer, onlinePlayer, size); localPlayer.setEnemy(onlinePlayer);
onlinePlayer.setEnemy(localPlayer);
onlinePlayer.sendIAM();
// Start game only after IAM Package was exchanged
} else { } else {
throw new RuntimeException("Unexpected Package received before game initialisation"); throw new RuntimeException("Unexpected Package received before game initialisation");
} }
@ -159,13 +163,13 @@ public class GameController {
localPlayer.createBoard(size); localPlayer.createBoard(size);
aiPlayer.createBoard(size); aiPlayer.createBoard(size);
localPlayer.setEnemy(aiPlayer);
aiPlayer.setEnemy(localPlayer);
startGameWithInstancedPlayers(localPlayer, aiPlayer, size); startGameWithInstancedPlayers(localPlayer, aiPlayer, size);
} }
private static void startGameWithInstancedPlayers(LocalPlayer p1, Player p2, int boardSize) { public static void startGameWithInstancedPlayers(LocalPlayer p1, Player p2, int boardSize) {
p1.setEnemy(p2);
p2.setEnemy(p1);
mainFrame.showPanelSLG("GameBoard", boardSizeToSemester(boardSize), p1, p2); mainFrame.showPanelSLG("GameBoard", boardSizeToSemester(boardSize), p1, p2);
// TODO: frontend configuration // TODO: frontend configuration

View File

@ -11,6 +11,8 @@ public abstract class OnlinePlayer extends Player implements AsyncSocketListener
//TODO Auto-generated constructor stub //TODO Auto-generated constructor stub
} }
public abstract void sendIAM();
public abstract void receive(String message); public abstract void receive(String message);
@Override @Override

View File

@ -6,7 +6,6 @@ public class OnlinePlayer_1_1_0 extends OnlinePlayer {
} }
@Override @Override
public void receive(String message) { public void receive(String message) {
SocketPackage p = new SocketPackage(message); SocketPackage p = new SocketPackage(message);
@ -26,6 +25,8 @@ public class OnlinePlayer_1_1_0 extends OnlinePlayer {
this.createBoard(usedBoardSize); this.createBoard(usedBoardSize);
this.enemy.createBoard(usedBoardSize); this.enemy.createBoard(usedBoardSize);
GameController.startGameWithInstancedPlayers((LocalPlayer)this.enemy, (Player)this, usedBoardSize);
break; break;
// TODO: IAMU // TODO: IAMU
@ -66,6 +67,12 @@ public class OnlinePlayer_1_1_0 extends OnlinePlayer {
} }
} }
@Override
public synchronized void sendIAM() {
if (this.enemy == null) throw new RuntimeException("enemy has not yet been defined");
socket.send(new SocketPackage("IAM", GameController.boardSizeToSemester(this.wantedBoardSize) + " " + this.enemy.name));
}
@Override @Override
public synchronized void receiveShoot(Point point){ public synchronized void receiveShoot(Point point){
super.socket.send(new SocketPackage("SHOOT",point.toString())); super.socket.send(new SocketPackage("SHOOT",point.toString()));

View File

@ -135,6 +135,9 @@ public class Ship {
} }
public boolean isShipOnPos(Point pos){ public boolean isShipOnPos(Point pos){
if(this.position == null){
return false;
}
if ((this.horizontal && pos.getY() == this.position.getY() && pos.getX() >= this.position.getX() && pos.getX() < this.position.getX() + size) || if ((this.horizontal && pos.getY() == this.position.getY() && pos.getX() >= this.position.getX() && pos.getX() < this.position.getX() + size) ||
(!(this.horizontal) && pos.getX() == this.position.getX() && pos.getY() >= this.position.getY() && pos.getY() < this.position.getY() + size)) { (!(this.horizontal) && pos.getX() == this.position.getX() && pos.getY() >= this.position.getY() && pos.getY() < this.position.getY() + size)) {
return true; return true;

16
src/ShipButton.java Normal file
View File

@ -0,0 +1,16 @@
import javax.swing.*;
import java.awt.event.ActionEvent;
import java.awt.event.ActionListener;
public class ShipButton extends JButton {
Ship ship;
public ShipButton(Ship ship, BoardDisplay boardDisplay) {
super(ship.getName());
this.ship = ship;
this.addActionListener((e)->{
boardDisplay.selectCurrentShip(ship);
});
}
}

View File

@ -1,8 +1,10 @@
import javazoom.jl.decoder.JavaLayerException; import javazoom.jl.decoder.JavaLayerException;
import javazoom.jl.player.Player; import javazoom.jl.player.Player;
import java.awt.List;
import java.io.FileInputStream; import java.io.FileInputStream;
import java.io.FileNotFoundException; import java.io.FileNotFoundException;
import java.util.ArrayList;
import java.util.HashMap; import java.util.HashMap;
import java.util.Map; import java.util.Map;
@ -10,6 +12,8 @@ public class SoundHandler {
private static boolean soundOn = true; private static boolean soundOn = true;
private static ArrayList<Thread> runningThreads = new ArrayList<Thread>();
// Wenn fehler beim erstellen von .jar mit sound hier gucken // Wenn fehler beim erstellen von .jar mit sound hier gucken
private static HashMap<String, String> sounds = new HashMap<String, String>(Map.of( private static HashMap<String, String> sounds = new HashMap<String, String>(Map.of(
"hit", "./Sound/water-drip.mp3" "hit", "./Sound/water-drip.mp3"
@ -17,7 +21,7 @@ public class SoundHandler {
public static void playSound(String soundName) { public static void playSound(String soundName) {
if (soundOn) { if (soundOn) {
new Thread(new Runnable() { Thread thread = new Thread(new Runnable() {
@Override @Override
public void run() { public void run() {
try { try {
@ -27,9 +31,23 @@ public class SoundHandler {
e.printStackTrace(); e.printStackTrace();
} }
} }
}).start(); });
// TODO: kill zombies thread.start();
runningThreads.add(thread);
} }
for (Thread oldThread : runningThreads) {
if (!oldThread.isAlive()) {
try {
oldThread.join();
runningThreads.remove(oldThread);
System.out.println("cleared thread");
} catch (InterruptedException e) {
e.printStackTrace();
}
}
}
} }