Merge pull request 'start game stuff - both online and offline' (#13) from start-game into main
Reviewed-on: #13
This commit is contained in:
commit
fd5a97cd6e
|
@ -1,27 +1,86 @@
|
||||||
import java.io.BufferedReader;
|
import java.io.BufferedReader;
|
||||||
|
import java.io.BufferedWriter;
|
||||||
import java.io.IOException;
|
import java.io.IOException;
|
||||||
import java.io.InputStreamReader;
|
import java.io.InputStreamReader;
|
||||||
import java.io.OutputStreamWriter;
|
import java.io.OutputStreamWriter;
|
||||||
import java.io.PrintWriter;
|
import java.net.InetSocketAddress;
|
||||||
|
import java.net.ServerSocket;
|
||||||
import java.net.Socket;
|
import java.net.Socket;
|
||||||
|
|
||||||
public class AsyncSocket {
|
public class AsyncSocket {
|
||||||
private Socket socket;
|
private Socket socket;
|
||||||
private Thread checkerThread;
|
private Thread checkerThread;
|
||||||
|
private Thread connectorThread;
|
||||||
private AsyncSocketListener handler;
|
private AsyncSocketListener handler;
|
||||||
private boolean shouldStop = false;
|
private boolean shouldStop = false;
|
||||||
|
|
||||||
|
private String sendBuffer = "";
|
||||||
|
|
||||||
private BufferedReader in;
|
private BufferedReader in;
|
||||||
private PrintWriter out;
|
private BufferedWriter out;
|
||||||
|
|
||||||
|
public AsyncSocket(int port, AsyncSocketListener handler) {
|
||||||
|
this.setHandler(handler);
|
||||||
|
|
||||||
|
// start server in new thread
|
||||||
|
this.connectorThread = new Thread(() -> {
|
||||||
|
try {
|
||||||
|
ServerSocket serverSocket = new ServerSocket(port);
|
||||||
|
|
||||||
|
System.out.println("Waiting for client connection on port " + port);
|
||||||
|
|
||||||
|
Socket socket = serverSocket.accept();
|
||||||
|
|
||||||
|
System.out.println("Socket connected.");
|
||||||
|
|
||||||
|
serverSocket.close();
|
||||||
|
|
||||||
|
this.initSocket(socket);
|
||||||
|
|
||||||
|
} catch (IOException e) {
|
||||||
|
e.printStackTrace();
|
||||||
|
// TODO: proper error handling
|
||||||
|
}
|
||||||
|
});
|
||||||
|
this.connectorThread.start();
|
||||||
|
}
|
||||||
|
|
||||||
|
public AsyncSocket(InetSocketAddress address, AsyncSocketListener handler) {
|
||||||
|
this.setHandler(handler);
|
||||||
|
|
||||||
|
// start client in new thread
|
||||||
|
this.connectorThread = new Thread(() -> {
|
||||||
|
System.out.println("Connecting to " + address.toString());
|
||||||
|
|
||||||
|
Socket socket = new Socket();
|
||||||
|
try {
|
||||||
|
socket.connect(address, 10);
|
||||||
|
System.out.println("Socket connected.");
|
||||||
|
|
||||||
|
this.initSocket(socket);
|
||||||
|
|
||||||
|
} catch (IOException e) {
|
||||||
|
e.printStackTrace();
|
||||||
|
throw new RuntimeException("Connection timed out");
|
||||||
|
}
|
||||||
|
|
||||||
|
});
|
||||||
|
this.connectorThread.start();
|
||||||
|
}
|
||||||
|
|
||||||
public AsyncSocket(Socket socket, AsyncSocketListener handler) throws IOException {
|
public AsyncSocket(Socket socket, AsyncSocketListener handler) throws IOException {
|
||||||
|
this.setHandler(handler);
|
||||||
|
this.initSocket(socket);
|
||||||
|
}
|
||||||
|
|
||||||
|
private void initSocket(Socket socket) throws IOException {
|
||||||
|
System.out.println("Initialising sockets");
|
||||||
this.socket = socket;
|
this.socket = socket;
|
||||||
|
|
||||||
this.in = new BufferedReader(new InputStreamReader(this.socket.getInputStream()));
|
this.in = new BufferedReader(new InputStreamReader(this.socket.getInputStream()));
|
||||||
this.out = new PrintWriter(new OutputStreamWriter(this.socket.getOutputStream()));
|
this.out = new BufferedWriter(new OutputStreamWriter(this.socket.getOutputStream()));
|
||||||
|
|
||||||
this.handler = handler;
|
|
||||||
|
|
||||||
|
this.shouldStop = false;
|
||||||
this.checkerThread = new Thread(() -> {
|
this.checkerThread = new Thread(() -> {
|
||||||
while (!this.shouldStop) {
|
while (!this.shouldStop) {
|
||||||
try {
|
try {
|
||||||
|
@ -29,21 +88,38 @@ public class AsyncSocket {
|
||||||
} catch (InterruptedException e) {
|
} catch (InterruptedException e) {
|
||||||
e.printStackTrace();
|
e.printStackTrace();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (!this.connectorThread.isAlive()) {
|
||||||
try {
|
try {
|
||||||
if (!this.in.ready()) continue;
|
this.connectorThread.join();
|
||||||
if (this.handler == null) continue;
|
} catch (InterruptedException e) {
|
||||||
|
e.printStackTrace();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
try {
|
||||||
|
if (!this.in.ready()) {
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
if (this.handler == null) {
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
|
||||||
String message = this.in.readLine();
|
String message = this.in.readLine();
|
||||||
if (message.length() <= 0) continue;
|
if (message.length() <= 0) continue;
|
||||||
|
|
||||||
|
|
||||||
message = message.strip();
|
message = message.strip();
|
||||||
|
System.out.println("RECEIVED - " + message);
|
||||||
this.handler.receive(message);
|
this.handler.receive(message);
|
||||||
} catch (IOException e) {
|
} catch (IOException e) {
|
||||||
e.printStackTrace();
|
e.printStackTrace();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
System.out.println("starting checker thread");
|
||||||
this.checkerThread.start();
|
this.checkerThread.start();
|
||||||
|
this.flushBuffer();
|
||||||
}
|
}
|
||||||
|
|
||||||
public void setHandler(AsyncSocketListener handler) {
|
public void setHandler(AsyncSocketListener handler) {
|
||||||
|
@ -51,21 +127,36 @@ public class AsyncSocket {
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
public void send(SocketPackage socketPackage) {
|
public synchronized void send(SocketPackage socketPackage) {
|
||||||
this.sendLine(socketPackage.toString());
|
this.sendLine(socketPackage.toString());
|
||||||
}
|
}
|
||||||
public void send(String packageName) {
|
public synchronized void send(String packageName) {
|
||||||
this.send(packageName, "");
|
this.send(packageName, "");
|
||||||
}
|
}
|
||||||
public void send(String packageName, String packageContent) {
|
public synchronized void send(String packageName, String packageContent) {
|
||||||
if (packageContent.length() > 0) {
|
if (packageContent.length() > 0) {
|
||||||
packageContent = " " + packageContent;
|
packageContent = " " + packageContent;
|
||||||
}
|
}
|
||||||
this.sendLine(packageName + packageContent);
|
this.sendLine(packageName + packageContent);
|
||||||
}
|
}
|
||||||
|
|
||||||
public void sendLine(String message) {
|
public synchronized void sendLine(String message) {
|
||||||
this.out.print(message + "\r\n");
|
sendBuffer = sendBuffer + message + "\r\n";
|
||||||
|
this.flushBuffer();
|
||||||
|
}
|
||||||
|
|
||||||
|
private synchronized void flushBuffer() {
|
||||||
|
if (!this.sendBuffer.isEmpty() && this.out != null) {
|
||||||
|
try {
|
||||||
|
this.out.write(sendBuffer);
|
||||||
|
System.out.println("SENT - " + sendBuffer);
|
||||||
|
sendBuffer = "";
|
||||||
|
this.out.flush();
|
||||||
|
} catch (IOException e) {
|
||||||
|
e.printStackTrace();
|
||||||
|
// TODO: handle writing error
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
public void close() {
|
public void close() {
|
||||||
|
@ -73,8 +164,11 @@ public class AsyncSocket {
|
||||||
|
|
||||||
try {
|
try {
|
||||||
this.socket.close();
|
this.socket.close();
|
||||||
|
this.checkerThread.join();
|
||||||
} catch (IOException e) {
|
} catch (IOException e) {
|
||||||
e.printStackTrace();
|
e.printStackTrace();
|
||||||
|
} catch (InterruptedException e) {
|
||||||
|
e.printStackTrace();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
|
@ -1,4 +1,5 @@
|
||||||
|
|
||||||
|
import java.util.ArrayList;
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
|
|
||||||
public class Board {
|
public class Board {
|
||||||
|
@ -10,6 +11,8 @@ public class Board {
|
||||||
|
|
||||||
public Board(int size) {
|
public Board(int size) {
|
||||||
this.size = size;
|
this.size = size;
|
||||||
|
this.ships = new ArrayList<>();
|
||||||
|
this.hits = new ArrayList<>();
|
||||||
this.createShip(size - 13);
|
this.createShip(size - 13);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -2,14 +2,32 @@ import javax.swing.*;
|
||||||
import java.awt.*;
|
import java.awt.*;
|
||||||
import java.awt.event.MouseAdapter;
|
import java.awt.event.MouseAdapter;
|
||||||
import java.awt.event.MouseEvent;
|
import java.awt.event.MouseEvent;
|
||||||
|
import java.util.ArrayList;
|
||||||
|
import java.util.List;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* TODO Klassenbeschreibung
|
||||||
|
*/
|
||||||
public class BoardDisplay extends JPanel {
|
public class BoardDisplay extends JPanel {
|
||||||
public BoardDisplay(int gridSize, Icon buttonIcon) {
|
private JButton[][] fields;
|
||||||
super(new GridLayout(gridSize + 1, gridSize + 1)); // +1 wegen extra Zeile/Splate
|
private int gridSize;
|
||||||
|
private List <Ship> ships;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Konstruktor der startLocalGame.
|
||||||
|
* TODO fertig schreiben
|
||||||
|
* @param gridSize
|
||||||
|
* @param player
|
||||||
|
*/
|
||||||
|
public BoardDisplay(int gridSize, Player player) {
|
||||||
|
super(new GridLayout(gridSize + 1, gridSize + 1)); // +1 wegen extra Zeile/Splate
|
||||||
|
this.fields = new JButton[gridSize][gridSize];
|
||||||
|
this.ships = new ArrayList<>();
|
||||||
// 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++) {
|
||||||
|
final int x = i; // Temporäre Variable
|
||||||
|
final int y = j; // Temporäre Variable
|
||||||
if (i == 0 && j == 0) {
|
if (i == 0 && j == 0) {
|
||||||
add(new JLabel(" "));
|
add(new JLabel(" "));
|
||||||
} else if (i == 0) {
|
} else if (i == 0) {
|
||||||
|
@ -28,27 +46,116 @@ public class BoardDisplay extends JPanel {
|
||||||
field.setBackground(Color.LIGHT_GRAY);
|
field.setBackground(Color.LIGHT_GRAY);
|
||||||
field.setOpaque(true);
|
field.setOpaque(true);
|
||||||
field.setBorderPainted(true);
|
field.setBorderPainted(true);
|
||||||
|
fields[i - 1][j - 1] = field;
|
||||||
|
add(field);
|
||||||
|
//field.addMouseListener(new MouseAdapter() {
|
||||||
|
// @Override
|
||||||
|
//public void mouseClicked(MouseEvent e) {
|
||||||
|
// if (SwingUtilities.isRightMouseButton(e)) {
|
||||||
|
// handleFieldClick(field);
|
||||||
|
// }
|
||||||
|
// }
|
||||||
|
|
||||||
|
//@Override
|
||||||
|
//public void mouseExited(MouseEvent e) {
|
||||||
|
// field.setBackground(Color.LIGHT_GRAY);
|
||||||
|
// }
|
||||||
|
// });
|
||||||
|
int finalI = i;
|
||||||
|
int finalJ = j;
|
||||||
field.addMouseListener(new MouseAdapter() {
|
field.addMouseListener(new MouseAdapter() {
|
||||||
@Override
|
@Override
|
||||||
public void mouseClicked(MouseEvent e) {
|
public void mouseClicked(MouseEvent e) {
|
||||||
if(SwingUtilities.isRightMouseButton(e)) {
|
Point o= new Point(finalI, finalJ);
|
||||||
handleFieldClick(field);
|
System.out.println(o);
|
||||||
}
|
handleFieldClick(field, o,player);
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public void mouseExited(MouseEvent e) {
|
|
||||||
// field.setBackground(Color.LIGHT_GRAY);
|
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
add(field);
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
// this.ships = new ArrayList<Ship>();
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* TODO Funktion beschreiben etc.
|
||||||
|
* @param ship
|
||||||
|
* @param o
|
||||||
|
* @param horizontal
|
||||||
|
* @param player
|
||||||
|
* @return
|
||||||
|
*/
|
||||||
|
private boolean setShip(Ship ship, Point o, boolean horizontal,Player player) {
|
||||||
|
//boolean a = true;
|
||||||
|
if (placeable(ship, ship.getPosition(), horizontal)) {
|
||||||
|
ship.setPosition(new Point(o.getX(),o.getY()),player.getBoard().getShips(),gridSize);
|
||||||
|
ship.setHorizontal(horizontal);
|
||||||
|
ships.add(ship);
|
||||||
|
List<Point> occupied = ship.getOccupiedPoints();
|
||||||
|
for(Point p: occupied) {
|
||||||
|
fields[p.getX()][p.getY()].setBackground(Color.LIGHT_GRAY);
|
||||||
|
}
|
||||||
|
return true;
|
||||||
|
}else{
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/*private boolean placeable(Ship ship,Point o, boolean horizontal) {
|
||||||
|
if (horizontal && (o.getX() + ship.getSize() > gridSize)) { // Fehler
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
if (!horizontal && (o.getY() + ship.getSize() > gridSize)) {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
return true;
|
||||||
|
}*/
|
||||||
|
|
||||||
|
/**
|
||||||
|
* TODO Funktion beschreiben etc.
|
||||||
|
* @param ship
|
||||||
|
* @param o
|
||||||
|
* @param horizontal
|
||||||
|
* @return
|
||||||
|
*/
|
||||||
|
private boolean placeable(Ship ship, Point o, boolean horizontal) {
|
||||||
|
if (horizontal && (o.getX() + ship.getSize() > gridSize)) {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
if (!horizontal && (o.getY() + ship.getSize() > gridSize)) {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
// Prüfen auf Kollision mit bestehenden Schiffen
|
||||||
|
for (Ship other : ships) {
|
||||||
|
for (Point p : other.getOccupiedPoints()) {
|
||||||
|
for (Point newP : ship.getOccupiedPoints()) {
|
||||||
|
if (p.equals(newP)) {
|
||||||
|
return false; // Überschneidung gefunden
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
private void handleFieldClick(JButton field) {
|
return true;
|
||||||
field.setBackground(Color.RED);
|
}
|
||||||
|
|
||||||
|
|
||||||
|
private void selectShip(MouseEvent e) {
|
||||||
|
Ship current = (Ship) e.getSource();
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* TODO Funktion beschreiben etc.
|
||||||
|
* @param field
|
||||||
|
* @param o
|
||||||
|
* @param player
|
||||||
|
*/
|
||||||
|
private void handleFieldClick(JButton field, Point o,Player player) {
|
||||||
|
// Beispiel: Setze ein Schiff bei einem Klick
|
||||||
|
if (setShip(new Ship(3, "TestShip"), o, true,player)) {
|
||||||
|
field.setBackground(Color.BLUE); // Visualisiere Schiff
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
|
@ -1,10 +1,17 @@
|
||||||
import javafx.scene.control.ToggleGroup;
|
// import javafx.scene.control.ToggleGroup;
|
||||||
|
|
||||||
import javax.swing.*;
|
import javax.swing.*;
|
||||||
import java.awt.*;
|
import java.awt.*;
|
||||||
import java.awt.event.ActionEvent;
|
import java.awt.event.ActionEvent;
|
||||||
import java.awt.event.ActionListener;
|
import java.awt.event.ActionListener;
|
||||||
|
import java.awt.event.MouseEvent;
|
||||||
|
import java.awt.event.MouseAdapter;
|
||||||
|
import java.util.List;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Das GameBoard dient als Panel, in dem das tatsächliche Spiel stattfindet.
|
||||||
|
* Der Benutzer kann hier seine Schiffe platzieren, das Spiel starten etc.
|
||||||
|
*/
|
||||||
public class GameBoard extends JPanel {
|
public class GameBoard extends JPanel {
|
||||||
// Funktionshilfen
|
// Funktionshilfen
|
||||||
//int semesterCounter = 1; //TODO: ersetzen durch param von vorpanel
|
//int semesterCounter = 1; //TODO: ersetzen durch param von vorpanel
|
||||||
|
@ -21,6 +28,15 @@ public class GameBoard extends JPanel {
|
||||||
|
|
||||||
JButton backButton = new JButton(backButtonIcon);
|
JButton backButton = new JButton(backButtonIcon);
|
||||||
// Eigene ModulButtons
|
// Eigene ModulButtons
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Konstruktor von GameBoard.
|
||||||
|
* @param frame Der Mainframe der Anwendung über den alle Panels angezeigt werden.
|
||||||
|
* @param semesterCounter Ausgewähltes Semester
|
||||||
|
* @param p1 Erstes Spielerobjekt
|
||||||
|
* @param p2 Zweites Spielerobjekt
|
||||||
|
*/
|
||||||
|
GameBoard(MainFrame frame, int semesterCounter,Player p1, Player p2) {
|
||||||
JToggleButton leftPlayerModul1 = new JToggleButton("Modul 1"); //TODO: Dynamische Namen durch abgleich mit Semester
|
JToggleButton leftPlayerModul1 = new JToggleButton("Modul 1"); //TODO: Dynamische Namen durch abgleich mit Semester
|
||||||
JToggleButton leftPlayerModul2 = new JToggleButton("Modul 2");
|
JToggleButton leftPlayerModul2 = new JToggleButton("Modul 2");
|
||||||
JToggleButton leftPlayerModul3 = new JToggleButton("Modul 3");
|
JToggleButton leftPlayerModul3 = new JToggleButton("Modul 3");
|
||||||
|
@ -29,6 +45,11 @@ public class GameBoard extends JPanel {
|
||||||
JToggleButton leftPlayerModul6 = new JToggleButton("Modul 6");
|
JToggleButton leftPlayerModul6 = new JToggleButton("Modul 6");
|
||||||
JToggleButton leftPlayerModul7 = new JToggleButton("Reset");
|
JToggleButton leftPlayerModul7 = new JToggleButton("Reset");
|
||||||
|
|
||||||
|
JToggleButton[] leftPlayerButtons=new JToggleButton[]{
|
||||||
|
leftPlayerModul1, leftPlayerModul2, leftPlayerModul3, leftPlayerModul4,
|
||||||
|
leftPlayerModul5, leftPlayerModul6, leftPlayerModul7,
|
||||||
|
};
|
||||||
|
|
||||||
// Gegnerische ModulButtons
|
// Gegnerische ModulButtons
|
||||||
JToggleButton rightPlayerModul1 = new JToggleButton("Modul 1");
|
JToggleButton rightPlayerModul1 = new JToggleButton("Modul 1");
|
||||||
JToggleButton rightPlayerModul2 = new JToggleButton("Modul 2");
|
JToggleButton rightPlayerModul2 = new JToggleButton("Modul 2");
|
||||||
|
@ -38,7 +59,39 @@ public class GameBoard extends JPanel {
|
||||||
JToggleButton rightPlayerModul6 = new JToggleButton("Modul 6");
|
JToggleButton rightPlayerModul6 = new JToggleButton("Modul 6");
|
||||||
JToggleButton rightPlayerModul7 = new JToggleButton("Bereit");
|
JToggleButton rightPlayerModul7 = new JToggleButton("Bereit");
|
||||||
|
|
||||||
public void buildPanel(MainFrame frame, int semesterCounter) {
|
JToggleButton[] rightlayerButtons=new JToggleButton[]{
|
||||||
|
rightPlayerModul1, rightPlayerModul2, rightPlayerModul3, rightPlayerModul4,
|
||||||
|
rightPlayerModul5, rightPlayerModul6, rightPlayerModul7,
|
||||||
|
};
|
||||||
|
|
||||||
|
buildPanel(frame, semesterCounter,p1,p2,leftPlayerButtons,rightlayerButtons);
|
||||||
|
List<Ship> shipsP1 =p1.getBoard().getShips();
|
||||||
|
updateButtonLabels(shipsP1,leftPlayerButtons);
|
||||||
|
backButton.addActionListener(e -> frame.showPanel("MainMenu"));
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* TODO Funktion beschreiben etc.
|
||||||
|
* @param ships
|
||||||
|
* @param buttons
|
||||||
|
*/
|
||||||
|
private void updateButtonLabels(List<Ship> ships,JToggleButton[] buttons) {
|
||||||
|
for(int i=0;i<buttons.length &&i<ships.size();i++ ) {
|
||||||
|
Ship ship = ships.get(i);
|
||||||
|
buttons[i].setText(ship.getName());
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* TODO Funktion beschreiben etc.
|
||||||
|
* @param frame
|
||||||
|
* @param semesterCounter
|
||||||
|
* @param p1
|
||||||
|
* @param p2
|
||||||
|
* @param leftButtons
|
||||||
|
* @param rightButtons
|
||||||
|
*/
|
||||||
|
public void buildPanel(MainFrame frame, int semesterCounter,Player p1,Player p2,JToggleButton[] leftButtons,JToggleButton[] rightButtons) {
|
||||||
// Hauptlayout - BorderLayout für die Anordnung der Komponenten
|
// Hauptlayout - BorderLayout für die Anordnung der Komponenten
|
||||||
setLayout(new BorderLayout());
|
setLayout(new BorderLayout());
|
||||||
|
|
||||||
|
@ -51,51 +104,51 @@ public class GameBoard extends JPanel {
|
||||||
// Panel für die Buttons des linken Spielers (ganz links)
|
// 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(leftPlayerModul1);
|
leftButtonsPanel.add(leftButtons[0]);
|
||||||
leftButtonsPanel.add(leftPlayerModul2);
|
leftButtonsPanel.add(leftButtons[1]);
|
||||||
leftButtonsPanel.add(leftPlayerModul3);
|
leftButtonsPanel.add(leftButtons[2]);
|
||||||
leftButtonsPanel.add(leftPlayerModul4);
|
leftButtonsPanel.add(leftButtons[3]);
|
||||||
leftButtonsPanel.add(leftPlayerModul5);
|
leftButtonsPanel.add(leftButtons[4]);
|
||||||
leftButtonsPanel.add(leftPlayerModul6);
|
leftButtonsPanel.add(leftButtons[5]);
|
||||||
leftButtonsPanel.add(leftPlayerModul7);
|
leftButtonsPanel.add(leftButtons[6]);
|
||||||
|
|
||||||
// Panel für die Buttons des rechten Spielers (ganz rechts)
|
// 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)); // 6 Buttons untereinander
|
||||||
rightButtonsPanel.add(rightPlayerModul1);
|
rightButtonsPanel.add(rightButtons[0]);
|
||||||
rightButtonsPanel.add(rightPlayerModul2);
|
rightButtonsPanel.add(rightButtons[1]);
|
||||||
rightButtonsPanel.add(rightPlayerModul3);
|
rightButtonsPanel.add(rightButtons[2]);
|
||||||
rightButtonsPanel.add(rightPlayerModul4);
|
rightButtonsPanel.add(rightButtons[3]);
|
||||||
rightButtonsPanel.add(rightPlayerModul5);
|
rightButtonsPanel.add(rightButtons[4]);
|
||||||
rightButtonsPanel.add(rightPlayerModul6);
|
rightButtonsPanel.add(rightButtons[5]);
|
||||||
rightButtonsPanel.add(rightPlayerModul7);
|
rightButtonsPanel.add(rightButtons[6]);
|
||||||
|
|
||||||
// Spielfelder erstellen (eigenes und gegnerisches)
|
// Spielfelder erstellen (eigenes und gegnerisches)
|
||||||
int gridSize = GameController.semesterToBoardSize(semesterCounter); // Größe des Spielfelds
|
int gridSize = GameController.semesterToBoardSize(semesterCounter); // Größe des Spielfelds
|
||||||
// Spielfelder werden in BoardDisplay erstellt
|
// 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, gameBoardEmtpy);
|
JPanel ownBoardPanel = new BoardDisplay(gridSize,p1);
|
||||||
JPanel opponentBoardPanel = new BoardDisplay(gridSize, gameBoardEmtpy);
|
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(rightPlayerModul1);
|
leftButtonGroup.add(leftButtons[0]);
|
||||||
leftButtonGroup.add(rightPlayerModul2);
|
leftButtonGroup.add(leftButtons[1]);
|
||||||
leftButtonGroup.add(rightPlayerModul3);
|
leftButtonGroup.add(leftButtons[2]);
|
||||||
leftButtonGroup.add(rightPlayerModul4);
|
leftButtonGroup.add(leftButtons[3]);
|
||||||
leftButtonGroup.add(rightPlayerModul5);
|
leftButtonGroup.add(leftButtons[4]);
|
||||||
leftButtonGroup.add(rightPlayerModul6);
|
leftButtonGroup.add(leftButtons[5]);
|
||||||
leftButtonGroup.add(rightPlayerModul7);
|
leftButtonGroup.add(leftButtons[6]);
|
||||||
|
|
||||||
ButtonGroup rightButtonGroup= new ButtonGroup();
|
ButtonGroup rightButtonGroup= new ButtonGroup();
|
||||||
rightButtonGroup.add(leftPlayerModul1);
|
rightButtonGroup.add(rightButtons[0]);
|
||||||
rightButtonGroup.add(leftPlayerModul2);
|
rightButtonGroup.add(rightButtons[1]);
|
||||||
rightButtonGroup.add(leftPlayerModul3);
|
rightButtonGroup.add(rightButtons[2]);
|
||||||
rightButtonGroup.add(leftPlayerModul4);
|
rightButtonGroup.add(rightButtons[3]);
|
||||||
rightButtonGroup.add(leftPlayerModul5);
|
rightButtonGroup.add(rightButtons[4]);
|
||||||
rightButtonGroup.add(leftPlayerModul6);
|
rightButtonGroup.add(rightButtons[5]);
|
||||||
rightButtonGroup.add(leftPlayerModul7);
|
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();
|
||||||
|
@ -108,18 +161,6 @@ 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);
|
||||||
}
|
|
||||||
|
|
||||||
GameBoard(MainFrame frame, int semesterCounter,Player p1, Player p2) {
|
|
||||||
buildPanel(frame, semesterCounter);
|
|
||||||
/*
|
|
||||||
rightPlayerRightButton.addActionListener(new ActionListener() {
|
|
||||||
@Override
|
|
||||||
public void actionPerformed(ActionEvent e) {
|
|
||||||
toggleRightPlayerIcon();
|
|
||||||
updateTextFields();
|
|
||||||
}
|
|
||||||
}); */
|
|
||||||
backButton.addActionListener(e -> frame.showPanel("MainMenu"));
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -1,8 +1,5 @@
|
||||||
import java.io.IOException;
|
import java.io.IOException;
|
||||||
import java.net.InetSocketAddress;
|
import java.net.InetSocketAddress;
|
||||||
import java.net.ServerSocket;
|
|
||||||
import java.net.Socket;
|
|
||||||
import java.net.SocketTimeoutException;
|
|
||||||
import java.util.ArrayList;
|
import java.util.ArrayList;
|
||||||
import java.util.HashMap;
|
import java.util.HashMap;
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
|
@ -19,12 +16,12 @@ 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;
|
||||||
}
|
}
|
||||||
|
public static int boardSizeToSemester(int size) {
|
||||||
|
return size - 13;
|
||||||
|
}
|
||||||
|
|
||||||
public static HashMap<String, Class<? extends OnlinePlayer>> supportedVersions = new HashMap<>(Map.of(
|
public static HashMap<String, Class<? extends OnlinePlayer>> supportedVersions = new HashMap<>(Map.of(
|
||||||
"1.1.0", OnlinePlayer_1_1_0.class
|
"1.1.0", OnlinePlayer_1_1_0.class
|
||||||
|
@ -33,34 +30,15 @@ public class GameController {
|
||||||
public static void startOnlineGame(Class<? extends LocalPlayer> localPlayerClass, String localPlayerName, InetSocketAddress address, int size) throws IOException {
|
public static void startOnlineGame(Class<? extends LocalPlayer> localPlayerClass, String localPlayerName, InetSocketAddress address, int size) throws IOException {
|
||||||
AsyncSocket clientSocket;
|
AsyncSocket clientSocket;
|
||||||
|
|
||||||
boolean localPlayerIsServer = address.getHostName() == null;
|
boolean localPlayerIsServer = address.getHostName() == null || address.getHostName().isEmpty() || address.getHostName().equals("0.0.0.0");
|
||||||
|
|
||||||
if (localPlayerIsServer) {
|
if (localPlayerIsServer) {
|
||||||
// SERVER MODE
|
// SERVER MODE
|
||||||
|
clientSocket = new AsyncSocket(address.getPort(), null);
|
||||||
|
|
||||||
ServerSocket serverSocket = new ServerSocket(address.getPort());
|
|
||||||
|
|
||||||
System.out.println("Waiting for client connection...");
|
|
||||||
|
|
||||||
clientSocket = new AsyncSocket(serverSocket.accept(), null);
|
|
||||||
|
|
||||||
serverSocket.close();
|
|
||||||
} else {
|
} else {
|
||||||
// CLIENT MODE
|
// CLIENT MODE
|
||||||
|
clientSocket = new AsyncSocket(address, null);
|
||||||
Socket socket = new Socket();
|
|
||||||
|
|
||||||
try {
|
|
||||||
socket.connect(address, CONNECTION_TIMEOUT);
|
|
||||||
|
|
||||||
clientSocket = new AsyncSocket(socket, null);
|
|
||||||
} catch (SocketTimeoutException e) {
|
|
||||||
e.printStackTrace();
|
|
||||||
throw new RuntimeException("Connection timed out");
|
|
||||||
} finally {
|
|
||||||
socket.close();
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
clientSocket.send("VERSION", "Gruppe03 " + String.join(" ", supportedVersions.keySet()));
|
clientSocket.send("VERSION", "Gruppe03 " + String.join(" ", supportedVersions.keySet()));
|
||||||
|
@ -84,17 +62,24 @@ public class GameController {
|
||||||
OnlinePlayer onlinePlayer;
|
OnlinePlayer onlinePlayer;
|
||||||
try {
|
try {
|
||||||
localPlayer = localPlayerClass.getDeclaredConstructor().newInstance();
|
localPlayer = localPlayerClass.getDeclaredConstructor().newInstance();
|
||||||
onlinePlayer = onlinePlayerClass.getDeclaredConstructor().newInstance((Integer)size, clientSocket);
|
onlinePlayer = onlinePlayerClass.getDeclaredConstructor(Integer.class, AsyncSocket.class).newInstance((Integer)size, clientSocket);
|
||||||
} catch (Exception e) {
|
} catch (Exception e) {
|
||||||
e.printStackTrace();
|
e.printStackTrace();
|
||||||
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;
|
||||||
|
|
||||||
startGameWithInstancedPlayers(localPlayer, onlinePlayer);
|
localPlayer.setName(localPlayerName);
|
||||||
|
|
||||||
|
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");
|
||||||
}
|
}
|
||||||
|
@ -178,12 +163,14 @@ public class GameController {
|
||||||
localPlayer.createBoard(size);
|
localPlayer.createBoard(size);
|
||||||
aiPlayer.createBoard(size);
|
aiPlayer.createBoard(size);
|
||||||
|
|
||||||
startGameWithInstancedPlayers(localPlayer, aiPlayer);
|
localPlayer.setEnemy(aiPlayer);
|
||||||
|
aiPlayer.setEnemy(localPlayer);
|
||||||
|
|
||||||
|
startGameWithInstancedPlayers(localPlayer, aiPlayer, size);
|
||||||
}
|
}
|
||||||
|
|
||||||
private static void startGameWithInstancedPlayers(LocalPlayer p1, Player p2) {
|
public static void startGameWithInstancedPlayers(LocalPlayer p1, Player p2, int boardSize) {
|
||||||
p1.setEnemy(p2);
|
mainFrame.showPanelSLG("GameBoard", boardSizeToSemester(boardSize), p1, p2);
|
||||||
p2.setEnemy(p1);
|
|
||||||
|
|
||||||
// TODO: frontend configuration
|
// TODO: frontend configuration
|
||||||
}
|
}
|
||||||
|
|
|
@ -2,35 +2,53 @@ import java.awt.*;
|
||||||
import javax.swing.*;
|
import javax.swing.*;
|
||||||
import java.awt.event.ActionEvent;
|
import java.awt.event.ActionEvent;
|
||||||
import java.awt.event.ActionListener;
|
import java.awt.event.ActionListener;
|
||||||
|
import java.io.IOException;
|
||||||
|
import java.net.InetSocketAddress;
|
||||||
|
|
||||||
/*
|
/**
|
||||||
TODO: evtl an Lucas: die "JoinGame" muss noch informationen erhalten, welche Spieler erstellt wurden und welches Semester
|
* Das JoinGame Panel dient zum setzten des Ports/IP-Adresse.
|
||||||
Also die startMultiplayerGame muss JoinGame mit parametern für (HumanPlayer/AiEasy/AiNormal/AiHard, Semesteranzahl, Spielername) (3 Parameter) erhalten
|
* Anschließend kann das Verbinden Panel gezeigt werden.
|
||||||
|
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
|
||||||
public class JoinGame extends JPanel {
|
public class JoinGame extends JPanel {
|
||||||
|
// Grafiken
|
||||||
ImageIcon backButtonIcon = new ImageIcon("graphics/backButton.png");
|
ImageIcon backButtonIcon = new ImageIcon("graphics/backButton.png");
|
||||||
|
|
||||||
|
// Labels
|
||||||
JLabel spielBeitretenLabel;
|
JLabel spielBeitretenLabel;
|
||||||
JLabel ipLabel = new JLabel("IP-Adresse");
|
JLabel ipLabel = new JLabel("IP-Adresse");
|
||||||
JLabel portLabel = new JLabel("Port");
|
JLabel portLabel = new JLabel("Port");
|
||||||
|
|
||||||
|
// Textfelder
|
||||||
JTextField ipTextField = new JTextField(20);
|
JTextField ipTextField = new JTextField(20);
|
||||||
JTextField portTextField = new JTextField(20);
|
JTextField portTextField = new JTextField(20);
|
||||||
|
|
||||||
|
// Buttons
|
||||||
JButton losButton = new JButton("Los!");
|
JButton losButton = new JButton("Los!");
|
||||||
JButton backButton = new JButton(backButtonIcon);
|
JButton backButton = new JButton(backButtonIcon);
|
||||||
|
|
||||||
|
// Font
|
||||||
Font robotoFont = new Font("Roboto", Font.BOLD, 45);
|
Font robotoFont = new Font("Roboto", Font.BOLD, 45);
|
||||||
|
|
||||||
public JoinGame(MainFrame frame,int g) {
|
/**
|
||||||
|
* Erstellt mittels Funktionsaufrufen das Panel.
|
||||||
|
* @param frame Der Mainframe der Anwendung über den alle Panels angezeigt werden.
|
||||||
|
* @param g int-Anzeige, ob es sich um "spiel erstellen" oder "spiel beitreten" handelt.
|
||||||
|
* @param playerType int-Anzeige, ob es sich um einen HumanPlayer,AIEasy... handelt.
|
||||||
|
* @param playerName Name des Spielers
|
||||||
|
*/
|
||||||
|
public JoinGame(MainFrame frame,int g,int playerType,String playerName) {
|
||||||
setLayout(null);
|
setLayout(null);
|
||||||
buildPanel(frame,g);
|
buildPanel(frame,g,playerType,playerName);
|
||||||
}
|
}
|
||||||
|
|
||||||
private void buildPanel(MainFrame frame,int g) {
|
/**
|
||||||
|
* Erstellt das Panel.
|
||||||
|
* @param frame Der Mainframe der Anwendung über den alle Panels angezeigt werden.
|
||||||
|
* @param g int-Anzeige, ob es sich um "spiel erstellen" oder "spiel beitreten" handelt.
|
||||||
|
* @param playerType int-Anzeige, ob es sich um einen HumanPlayer,AIEasy... handelt.
|
||||||
|
* @param playerName Name des Spielers
|
||||||
|
*/
|
||||||
|
private void buildPanel(MainFrame frame,int g,int playerType,String playerName) {
|
||||||
if(g==1){
|
if(g==1){
|
||||||
spielBeitretenLabel= new JLabel("Spiel beitreten");
|
spielBeitretenLabel= new JLabel("Spiel beitreten");
|
||||||
}else{
|
}else{
|
||||||
|
@ -41,12 +59,14 @@ public class JoinGame extends JPanel {
|
||||||
losButton.setBounds(320, 225, 100, 50);
|
losButton.setBounds(320, 225, 100, 50);
|
||||||
backButton.setBounds(1380, 20, 80, 80);
|
backButton.setBounds(1380, 20, 80, 80);
|
||||||
|
|
||||||
ipLabel.setBounds(50, 125, 200, 30);
|
|
||||||
portLabel.setBounds(50, 200, 200, 30);
|
portLabel.setBounds(50, 200, 200, 30);
|
||||||
|
|
||||||
|
if(g==1) { //Wenn man Spiel erstellen will werden IP-Felder nicht angezeigt.
|
||||||
|
ipLabel.setBounds(50, 125, 200, 30);
|
||||||
ipTextField.setBounds(50, 150, 250, 50);
|
ipTextField.setBounds(50, 150, 250, 50);
|
||||||
portTextField.setBounds(50, 225, 250, 50);
|
}
|
||||||
|
|
||||||
|
portTextField.setBounds(50, 225, 250, 50);
|
||||||
|
|
||||||
spielBeitretenLabel.setFont(robotoFont.deriveFont(50f));
|
spielBeitretenLabel.setFont(robotoFont.deriveFont(50f));
|
||||||
|
|
||||||
|
@ -57,22 +77,45 @@ public class JoinGame extends JPanel {
|
||||||
add(ipTextField);
|
add(ipTextField);
|
||||||
add(portTextField);
|
add(portTextField);
|
||||||
add(backButton);
|
add(backButton);
|
||||||
|
// ActionListener für Buttons
|
||||||
|
// Um in das MultiplayerGame zurückzuwechseln.
|
||||||
|
backButton.addActionListener(new ActionListener() {
|
||||||
|
@Override
|
||||||
|
public void actionPerformed(ActionEvent e) {
|
||||||
|
frame.showPanel("MultiplayerGame");
|
||||||
|
}
|
||||||
|
});
|
||||||
|
|
||||||
backButton.addActionListener(e -> frame.showPanel("MultiplayerGame"));
|
// Um das Verbinden Panel anzuzeigen und Daten an Backend weiterzureichen.
|
||||||
losButton.addActionListener(e -> frame.showPanel("Verbinden"));
|
|
||||||
/*
|
|
||||||
losButton.addActionListener(new ActionListener() {
|
losButton.addActionListener(new ActionListener() {
|
||||||
@Override
|
@Override
|
||||||
public void actionPerformed(ActionEvent e) {
|
public void actionPerformed(ActionEvent e) {
|
||||||
frame.showPanel("Verbinden");
|
|
||||||
//public static void startOnlineGame(Class<? extends LocalPlayer> localPlayerClass, String localPlayerName, InetSocketAddress
|
|
||||||
// address, int size) throws IOException {
|
|
||||||
if(playerType == 1) { //Beispiel (für playertape wäre z.B. 1 humanPlayer etc.)
|
|
||||||
GameController.startOnlineGame(HumanPlayer.class, playerName, adress); //
|
|
||||||
}
|
|
||||||
|
|
||||||
|
String ipAddress = ipTextField.getText();
|
||||||
|
if (ipAddress.isEmpty()) {
|
||||||
|
ipAddress = "0.0.0.0";
|
||||||
|
}
|
||||||
|
String portText = portTextField.getText();
|
||||||
|
|
||||||
|
int port = Integer.parseInt(portText);
|
||||||
|
InetSocketAddress address = new InetSocketAddress(ipAddress, port);
|
||||||
|
|
||||||
|
frame.showPanel("Verbinden");
|
||||||
|
|
||||||
|
try {
|
||||||
|
if(playerType == 0) {
|
||||||
|
GameController.startOnlineGame(HumanPlayer.class, playerName, address,GameController.semesterToBoardSize(2));
|
||||||
|
} else if(playerType == 1) {
|
||||||
|
GameController.startOnlineGame(SpecificAiPlayerEasy.class, playerName, address,GameController.semesterToBoardSize(2));
|
||||||
|
} else if (playerType == 2) {
|
||||||
|
GameController.startOnlineGame(SpecificAiPlayerMedium.class, playerName, address,GameController.semesterToBoardSize(2));
|
||||||
|
} else if (playerType == 3) {
|
||||||
|
GameController.startOnlineGame(SpecificAiPlayerHard.class, playerName, address,GameController.semesterToBoardSize(2));
|
||||||
|
}
|
||||||
|
} catch (IOException ex) {
|
||||||
|
throw new RuntimeException(ex);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
*/
|
|
||||||
}
|
}
|
||||||
}
|
}
|
|
@ -1,6 +1,10 @@
|
||||||
import javax.swing.*;
|
import javax.swing.*;
|
||||||
import java.awt.*;
|
import java.awt.*;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Der MainFrame dient als Hub und Übergreifendes Fenster auf dem alle weiteren Panel angezeigt werden.
|
||||||
|
* Dadurch werden keine weiteren Fenster geöffnet.
|
||||||
|
*/
|
||||||
public class MainFrame extends JFrame {
|
public class MainFrame extends JFrame {
|
||||||
|
|
||||||
private CardLayout cardLayout;
|
private CardLayout cardLayout;
|
||||||
|
@ -16,40 +20,36 @@ public class MainFrame extends JFrame {
|
||||||
int semesterCounter;
|
int semesterCounter;
|
||||||
// ---------- //
|
// ---------- //
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Konstruktor von MainFrame.
|
||||||
|
* Ermöglicht es Panel anzuzeigen.
|
||||||
|
*/
|
||||||
public MainFrame() {
|
public MainFrame() {
|
||||||
|
|
||||||
|
GameController.setMainFrame(this);
|
||||||
|
|
||||||
setTitle("Studium Versenken");
|
setTitle("Studium Versenken");
|
||||||
setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE);
|
setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE);
|
||||||
setSize(1500, 1000);
|
setSize(1500, 1000);
|
||||||
setLocationRelativeTo(null);
|
setLocationRelativeTo(null);
|
||||||
|
|
||||||
//JLabel backgroundLabel = new JLabel(new ImageIcon("graphics/mainmenubackground.png"));
|
|
||||||
// backgroundLabel.setBounds(0, 0, 1500, 1000);
|
|
||||||
// getContentPane().add(backgroundLabel);
|
|
||||||
|
|
||||||
// backgroundLabel.setOpaque(true);
|
|
||||||
|
|
||||||
// CardLayout und Hauptpanel erstellen
|
// CardLayout und Hauptpanel erstellen
|
||||||
cardLayout = new CardLayout();
|
cardLayout = new CardLayout();
|
||||||
mainPanel = new JPanel(cardLayout);
|
mainPanel = new JPanel(cardLayout);
|
||||||
|
|
||||||
// Verschiedene Panels erstellen und hinzufügen
|
// Panels erstellen
|
||||||
MainMenuView mainMenuView = new MainMenuView(this);
|
MainMenuView mainMenuView = new MainMenuView(this);
|
||||||
startLocalGame localGame = new startLocalGame(this);
|
startLocalGame localGame = new startLocalGame(this);
|
||||||
//startLocalGameLoadingScreen LocalGameLoadingScreen = new startLocalGameLoadingScreen(this);
|
|
||||||
startMultiplayerGame multiplayerGame = new startMultiplayerGame(this);
|
startMultiplayerGame multiplayerGame = new startMultiplayerGame(this);
|
||||||
coinToss coinToss = new coinToss(this);
|
coinToss coinToss = new coinToss(this);
|
||||||
Verbinden verbinden = new Verbinden(this);
|
Verbinden verbinden = new Verbinden(this);
|
||||||
//JoinGame joinGame = new JoinGame(this,localMult);
|
|
||||||
//GameBoard gameBoard = new GameBoard(this, localMult);
|
|
||||||
|
|
||||||
|
// Panels hinzufügen
|
||||||
mainPanel.add(mainMenuView, "MainMenu");
|
mainPanel.add(mainMenuView, "MainMenu");
|
||||||
mainPanel.add(localGame, "LocalGame");
|
mainPanel.add(localGame, "LocalGame");
|
||||||
mainPanel.add(multiplayerGame, "MultiplayerGame");
|
mainPanel.add(multiplayerGame, "MultiplayerGame");
|
||||||
mainPanel.add(coinToss, "coinToss");
|
mainPanel.add(coinToss, "coinToss");
|
||||||
mainPanel.add(verbinden, "Verbinden");
|
mainPanel.add(verbinden, "Verbinden");
|
||||||
//mainPanel.add(joinGame, "JoinGame");
|
|
||||||
//mainPanel.add(gameBoard, "GameBoard");
|
|
||||||
|
|
||||||
// Hauptpanel in JFrame hinzufügen
|
// Hauptpanel in JFrame hinzufügen
|
||||||
add(mainPanel);
|
add(mainPanel);
|
||||||
|
@ -58,81 +58,60 @@ public class MainFrame extends JFrame {
|
||||||
cardLayout.show(mainPanel, "MainMenu");
|
cardLayout.show(mainPanel, "MainMenu");
|
||||||
}
|
}
|
||||||
|
|
||||||
// Methode, um die Ansicht zu wechseln
|
/**
|
||||||
|
* Methode, um die Ansicht zu wechseln
|
||||||
|
* @param panelName Name des anzuzeigenden Panels
|
||||||
|
*/
|
||||||
public void showPanel(String panelName) {
|
public void showPanel(String panelName) {
|
||||||
cardLayout.show(mainPanel, panelName);
|
cardLayout.show(mainPanel, panelName);
|
||||||
}
|
}
|
||||||
|
|
||||||
// --- ShowPanel der startMultiplayerGame Klasse
|
/**
|
||||||
public void showPanelSMG(String panelName, int num) {
|
* Spezifische ShowPanel-Funktion der startMultiplayerGame Klasse
|
||||||
|
* @param panelName Name des anzuzeigenden Panels
|
||||||
|
* @param num Hilfsvariable um abzugleichen, ob "Spiel erstellen" oder "Spiel beitreten" ausgewählt wurde
|
||||||
|
* @param playerType Spielertyp(HumanPlayer, AIEasy etc.)
|
||||||
|
* @param playerName Name des Spielers
|
||||||
|
*/
|
||||||
|
public void showPanelSMG(String panelName, int num, int playerType,String playerName) {
|
||||||
this.localMult = num;
|
this.localMult = num;
|
||||||
|
|
||||||
//if (!isPanelPresent(panelName)) { //TODO potentiell raus
|
JoinGame joinGame = new JoinGame(this, localMult, playerType, playerName);
|
||||||
JoinGame joinGame = new JoinGame(this, localMult);
|
|
||||||
mainPanel.add(joinGame, panelName);
|
mainPanel.add(joinGame, panelName);
|
||||||
mainPanel.revalidate(); // Refresh
|
mainPanel.revalidate(); // Refresh
|
||||||
mainPanel.repaint();
|
mainPanel.repaint();
|
||||||
//}
|
|
||||||
|
|
||||||
cardLayout.show(mainPanel, panelName); // Show the panel
|
cardLayout.show(mainPanel, panelName); // Show the panel
|
||||||
}
|
}
|
||||||
// --- ShowPanel der startLocalGameLoadingScreen Klasse (DURCH BACKEND AUFGERUFEN)
|
|
||||||
|
/**
|
||||||
|
* Spezifische ShowPanel der startLocalGameLoadingScreen Klasse (DURCH BACKEND AUFGERUFEN)
|
||||||
|
* @param panelName Name des anzuzeigenden Panels
|
||||||
|
* @param semesterCounter Ausgewähltes Semester
|
||||||
|
* @param p1 Erstes Spielerobjekt
|
||||||
|
* @param p2 Zweites Spielerobjekt
|
||||||
|
*/
|
||||||
public void showPanelSLG(String panelName,int semesterCounter, Player p1, Player p2) {
|
public void showPanelSLG(String panelName,int semesterCounter, Player p1, Player p2) {
|
||||||
this.semesterCounter = semesterCounter;
|
this.semesterCounter = semesterCounter;
|
||||||
|
|
||||||
//if (!isPanelPresent(panelName)) { //TODO potentiell raus
|
|
||||||
// gameBoard muss player übergeben bekommen
|
|
||||||
GameBoard gameBoard = new GameBoard(this, semesterCounter, p1, p2);
|
GameBoard gameBoard = new GameBoard(this, semesterCounter, p1, p2);
|
||||||
//mainPanel.add(mainMenuView, "MainMenu");
|
|
||||||
mainPanel.add(gameBoard, panelName);
|
mainPanel.add(gameBoard, panelName);
|
||||||
mainPanel.revalidate(); // Refresh
|
mainPanel.revalidate();
|
||||||
mainPanel.repaint();
|
mainPanel.repaint();
|
||||||
//}
|
|
||||||
|
|
||||||
cardLayout.show(mainPanel, panelName); // Show the panel
|
cardLayout.show(mainPanel, panelName); // Show the panel
|
||||||
}
|
}
|
||||||
|
|
||||||
// --- ShowPanel der startLocalGame Klasse
|
/**
|
||||||
|
* Spezifische ShowPanel der startLocalGame Klasse
|
||||||
|
* @param panelName Name des anzuzeigenden Panels
|
||||||
|
* @param semesterCounter Ausgewähltes Semester
|
||||||
|
*/
|
||||||
public void showPanelSLGLS(String panelName,int semesterCounter) {
|
public void showPanelSLGLS(String panelName,int semesterCounter) {
|
||||||
this.semesterCounter = semesterCounter;
|
this.semesterCounter = semesterCounter;
|
||||||
// gameBoard muss player übergeben bekommen
|
|
||||||
startLocalGameLoadingScreen LocalGameLoadingScreen = new startLocalGameLoadingScreen(this, semesterCounter);
|
startLocalGameLoadingScreen LocalGameLoadingScreen = new startLocalGameLoadingScreen(this, semesterCounter);
|
||||||
mainPanel.add(LocalGameLoadingScreen, panelName);
|
mainPanel.add(LocalGameLoadingScreen, panelName);
|
||||||
mainPanel.revalidate(); // Refresh
|
mainPanel.revalidate(); // Refresh
|
||||||
mainPanel.repaint();
|
mainPanel.repaint();
|
||||||
//}
|
|
||||||
|
|
||||||
cardLayout.show(mainPanel, panelName); // Show the panel
|
cardLayout.show(mainPanel, panelName); // Show the panel
|
||||||
}
|
}
|
||||||
|
|
||||||
/* TODO ist dies unnötig?
|
|
||||||
private boolean isPanelPresent(String panelName) {
|
|
||||||
for (Component component : mainPanel.getComponents()) {
|
|
||||||
if (panelName.equals(mainPanel.getClientProperty("name"))) {
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
return false;
|
|
||||||
} */
|
|
||||||
|
|
||||||
// Methoden für übergabe von playern an GameBoard
|
|
||||||
/*
|
|
||||||
public void setPlayerData() {
|
|
||||||
this.semesterCounter = semesterCounter;
|
|
||||||
|
|
||||||
//if (!isPanelPresent(panelName)) { //TODO potentiell raus
|
|
||||||
// gameBoard muss player übergeben bekommen
|
|
||||||
GameBoard gameBoard = new GameBoard(this, semesterCounter);
|
|
||||||
mainPanel.add(gameBoard, panelName);
|
|
||||||
mainPanel.revalidate(); // Refresh
|
|
||||||
mainPanel.repaint();
|
|
||||||
}*/
|
|
||||||
|
|
||||||
|
|
||||||
public static void main(String[] args) {
|
|
||||||
SwingUtilities.invokeLater(() -> {
|
|
||||||
MainFrame frame = new MainFrame();
|
|
||||||
frame.setVisible(true);
|
|
||||||
});
|
|
||||||
}
|
|
||||||
}
|
}
|
|
@ -4,13 +4,15 @@ public abstract class OnlinePlayer extends Player implements AsyncSocketListener
|
||||||
|
|
||||||
protected boolean hasReceivedCoinPackage;
|
protected boolean hasReceivedCoinPackage;
|
||||||
|
|
||||||
public OnlinePlayer(int size, AsyncSocket socket) {
|
public OnlinePlayer(Integer size, AsyncSocket socket) {
|
||||||
this.socket = socket;
|
this.socket = socket;
|
||||||
this.wantedBoardSize = size;
|
this.wantedBoardSize = size;
|
||||||
socket.setHandler(this);
|
socket.setHandler(this);
|
||||||
//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
|
||||||
|
|
|
@ -1,12 +1,11 @@
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
|
|
||||||
public class OnlinePlayer_1_1_0 extends OnlinePlayer {
|
public class OnlinePlayer_1_1_0 extends OnlinePlayer {
|
||||||
public OnlinePlayer_1_1_0(int size, AsyncSocket socket) {
|
public OnlinePlayer_1_1_0(Integer size, AsyncSocket socket) {
|
||||||
super(size, socket);
|
super(size, socket);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
@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()));
|
||||||
|
|
|
@ -43,6 +43,9 @@ public abstract class Player {
|
||||||
return this.name;
|
return this.name;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public Board getBoard() {
|
||||||
|
return this.board;
|
||||||
|
}
|
||||||
|
|
||||||
public abstract void receiveCoin(boolean coin);
|
public abstract void receiveCoin(boolean coin);
|
||||||
}
|
}
|
||||||
|
|
|
@ -159,4 +159,15 @@ public class Ship {
|
||||||
public boolean isSunk() {
|
public boolean isSunk() {
|
||||||
return sunk;
|
return sunk;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public void setHorizontal(boolean horizontal) {
|
||||||
|
this.horizontal = horizontal;
|
||||||
|
}
|
||||||
|
|
||||||
|
public int getSize() {
|
||||||
|
return size;
|
||||||
|
}
|
||||||
|
public String getName() {
|
||||||
|
return name;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -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,8 +31,22 @@ public class SoundHandler {
|
||||||
e.printStackTrace();
|
e.printStackTrace();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}).start();
|
});
|
||||||
|
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();
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -1,6 +1,9 @@
|
||||||
import javax.swing.*;
|
import javax.swing.*;
|
||||||
import java.awt.*;
|
import java.awt.*;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Das Verbinden Panel dient als "Überblende", während im Backend das Spiel erstellt/ eine Verbindung hergestellt wird.
|
||||||
|
*/
|
||||||
public class Verbinden extends JPanel{
|
public class Verbinden extends JPanel{
|
||||||
|
|
||||||
ImageIcon backButtonIcon = new ImageIcon("graphics/backButton.png");
|
ImageIcon backButtonIcon = new ImageIcon("graphics/backButton.png");
|
||||||
|
@ -9,11 +12,19 @@ public class Verbinden extends JPanel{
|
||||||
|
|
||||||
Font robotoFont = new Font("Roboto", Font.BOLD, 45);
|
Font robotoFont = new Font("Roboto", Font.BOLD, 45);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Konstruktor der startLocalGame.
|
||||||
|
* @param frame Der Mainframe der Anwendung über den alle Panels angezeigt werden.
|
||||||
|
*/
|
||||||
public Verbinden(MainFrame frame) {
|
public Verbinden(MainFrame frame) {
|
||||||
setLayout(null);
|
setLayout(null);
|
||||||
buildPanel(frame);
|
buildPanel(frame);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Baut Panel auf.
|
||||||
|
* @param frame Der Mainframe der Anwendung über den alle Panels angezeigt werden.
|
||||||
|
*/
|
||||||
private void buildPanel(MainFrame frame) {
|
private void buildPanel(MainFrame frame) {
|
||||||
setLayout(new BorderLayout());
|
setLayout(new BorderLayout());
|
||||||
verbindenLabel.setFont(robotoFont.deriveFont(50f));
|
verbindenLabel.setFont(robotoFont.deriveFont(50f));
|
||||||
|
|
|
@ -2,12 +2,13 @@ import javax.swing.*;
|
||||||
import java.awt.event.ActionEvent;
|
import java.awt.event.ActionEvent;
|
||||||
import java.awt.event.ActionListener;
|
import java.awt.event.ActionListener;
|
||||||
|
|
||||||
// TODO
|
/**
|
||||||
// Evtl. ist Namen selber setzten noch unmöglich
|
* Das startLocalGame Panel dient dem Erstellen eines lokalen Spiels.
|
||||||
//
|
* Hier kann der Benutzer Spieler inklusive Namen und das Semester, in dem sich der Benutzer befindet, einstellen.
|
||||||
|
*/
|
||||||
public class startLocalGame extends JPanel {
|
public class startLocalGame extends JPanel {
|
||||||
// Player
|
// Player
|
||||||
|
// TODO: entfernen
|
||||||
Player p1;
|
Player p1;
|
||||||
Player p2;
|
Player p2;
|
||||||
|
|
||||||
|
@ -23,7 +24,7 @@ public class startLocalGame extends JPanel {
|
||||||
ImageIcon aiPlayerNormalIcon = new ImageIcon("graphics/botPlayerNormal.png");
|
ImageIcon aiPlayerNormalIcon = new ImageIcon("graphics/botPlayerNormal.png");
|
||||||
ImageIcon aiPlayerHardIcon = new ImageIcon("graphics/botPlayerHard.png");
|
ImageIcon aiPlayerHardIcon = new ImageIcon("graphics/botPlayerHard.png");
|
||||||
|
|
||||||
// Labels und Buttons
|
// Labels
|
||||||
JLabel frameTitle = new JLabel("Lokales Spiel");
|
JLabel frameTitle = new JLabel("Lokales Spiel");
|
||||||
JLabel semesterLabel = new JLabel("Semester");
|
JLabel semesterLabel = new JLabel("Semester");
|
||||||
JLabel leftPlayerName = new JLabel("Name");
|
JLabel leftPlayerName = new JLabel("Name");
|
||||||
|
@ -32,6 +33,7 @@ public class startLocalGame extends JPanel {
|
||||||
JLabel rightPlayerIcon = new JLabel(aiPlayerEasyIcon);
|
JLabel rightPlayerIcon = new JLabel(aiPlayerEasyIcon);
|
||||||
JLabel semesterCounterLabel = new JLabel(String.valueOf(semesterCounter));
|
JLabel semesterCounterLabel = new JLabel(String.valueOf(semesterCounter));
|
||||||
|
|
||||||
|
// Buttons
|
||||||
JButton backButton = new JButton(backButtonIcon);
|
JButton backButton = new JButton(backButtonIcon);
|
||||||
JButton leftPlayerLeftButton = new JButton("<-");
|
JButton leftPlayerLeftButton = new JButton("<-");
|
||||||
JButton leftPlayerRightButton = new JButton("->");
|
JButton leftPlayerRightButton = new JButton("->");
|
||||||
|
@ -42,12 +44,20 @@ public class startLocalGame extends JPanel {
|
||||||
JButton startButton = new JButton("Start!");
|
JButton startButton = new JButton("Start!");
|
||||||
JButton testButton = new JButton("Test");
|
JButton testButton = new JButton("Test");
|
||||||
|
|
||||||
|
// Textfelder
|
||||||
JTextField leftPlayerTextField = new JTextField(20);
|
JTextField leftPlayerTextField = new JTextField(20);
|
||||||
JTextField rightPlayerTextField = new JTextField(20);
|
JTextField rightPlayerTextField = new JTextField(20);
|
||||||
|
|
||||||
// Methode zur Erstellung des Panels
|
/**
|
||||||
|
* Konstruktor der startLocalGame.
|
||||||
|
* Fügt Buttons, Textfelder und Label hinzu.
|
||||||
|
* Fügt ebenfalls ActionListeners hinzu, damit Buttons etc. ihre gewünschte Funktion haben
|
||||||
|
*
|
||||||
|
* @param frame Der Mainframe der Anwendung über den alle Panels angezeigt werden.
|
||||||
|
*/
|
||||||
startLocalGame(MainFrame frame) {
|
startLocalGame(MainFrame frame) {
|
||||||
setLayout(null); // Stelle das Layout des Panels ein
|
// Layout des Panels
|
||||||
|
setLayout(null);
|
||||||
|
|
||||||
// Setze Komponentenpositionen
|
// Setze Komponentenpositionen
|
||||||
frameTitle.setBounds(20, 20, 200, 30);
|
frameTitle.setBounds(20, 20, 200, 30);
|
||||||
|
@ -107,8 +117,8 @@ public class startLocalGame extends JPanel {
|
||||||
rightPlayerTextField.setText(rightPlayerNickname);
|
rightPlayerTextField.setText(rightPlayerNickname);
|
||||||
add(rightPlayerTextField);
|
add(rightPlayerTextField);
|
||||||
|
|
||||||
|
|
||||||
// ActionListener für Buttons
|
// ActionListener für Buttons
|
||||||
|
// Um das Semester zu erhöhen.
|
||||||
semesterUpButton.addActionListener(e -> {
|
semesterUpButton.addActionListener(e -> {
|
||||||
if (semesterCounter < 6) {
|
if (semesterCounter < 6) {
|
||||||
semesterCounter++;
|
semesterCounter++;
|
||||||
|
@ -116,6 +126,7 @@ public class startLocalGame extends JPanel {
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
|
||||||
|
// Um das Semester zu senken.
|
||||||
semesterDownButton.addActionListener(e -> {
|
semesterDownButton.addActionListener(e -> {
|
||||||
if (semesterCounter > 1) {
|
if (semesterCounter > 1) {
|
||||||
semesterCounter--;
|
semesterCounter--;
|
||||||
|
@ -123,6 +134,7 @@ public class startLocalGame extends JPanel {
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
|
||||||
|
// Um linken Player nach links zu "rotieren".
|
||||||
leftPlayerLeftButton.addActionListener(new ActionListener() {
|
leftPlayerLeftButton.addActionListener(new ActionListener() {
|
||||||
@Override
|
@Override
|
||||||
public void actionPerformed(ActionEvent e) {
|
public void actionPerformed(ActionEvent e) {
|
||||||
|
@ -131,6 +143,7 @@ public class startLocalGame extends JPanel {
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
|
||||||
|
// Um linken Player nach rechts zu "rotieren".
|
||||||
leftPlayerRightButton.addActionListener(new ActionListener() {
|
leftPlayerRightButton.addActionListener(new ActionListener() {
|
||||||
@Override
|
@Override
|
||||||
public void actionPerformed(ActionEvent e) {
|
public void actionPerformed(ActionEvent e) {
|
||||||
|
@ -139,6 +152,7 @@ public class startLocalGame extends JPanel {
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
|
||||||
|
// Um rechten Player nach links zu "rotieren".
|
||||||
rightPlayerLeftButton.addActionListener(new ActionListener() {
|
rightPlayerLeftButton.addActionListener(new ActionListener() {
|
||||||
@Override
|
@Override
|
||||||
public void actionPerformed(ActionEvent e) {
|
public void actionPerformed(ActionEvent e) {
|
||||||
|
@ -147,6 +161,7 @@ public class startLocalGame extends JPanel {
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
|
||||||
|
// Um den rechten Player nach rechts zu "rotieren".
|
||||||
rightPlayerRightButton.addActionListener(new ActionListener() {
|
rightPlayerRightButton.addActionListener(new ActionListener() {
|
||||||
@Override
|
@Override
|
||||||
public void actionPerformed(ActionEvent e) {
|
public void actionPerformed(ActionEvent e) {
|
||||||
|
@ -155,9 +170,38 @@ public class startLocalGame extends JPanel {
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
|
||||||
backButton.addActionListener(e -> frame.showPanel("MainMenu"));
|
// Um Namen des linken Spielers zu speichern.
|
||||||
testButton.addActionListener(e -> frame.showPanelSLG("GameBoard",1,p1,p2));
|
leftPlayerTextField.addActionListener(e -> {
|
||||||
//startButton.addActionListener(e -> frame.showPanelSLG("GameBoard", semesterCounter,p1, p2)); // TODO ECHTE FUNKTION EINFÜGEN
|
leftPlayerNickname = leftPlayerTextField.getText();
|
||||||
|
System.out.println("Linker Spielername geändert zu: " + leftPlayerNickname); // Debugging-Ausgabe
|
||||||
|
});
|
||||||
|
|
||||||
|
// Um Namen des linken Spielers zu speichern, auch wenn nicht Enter gedrückt wird.
|
||||||
|
leftPlayerTextField.addFocusListener(new java.awt.event.FocusAdapter() {
|
||||||
|
@Override
|
||||||
|
public void focusLost(java.awt.event.FocusEvent evt) {
|
||||||
|
leftPlayerNickname = leftPlayerTextField.getText();
|
||||||
|
System.out.println("Linker Spielername geändert zu: " + leftPlayerNickname); // Debugging-Ausgabe
|
||||||
|
}
|
||||||
|
});
|
||||||
|
|
||||||
|
// Um zum MainMenu zu wechseln.
|
||||||
|
backButton.addActionListener(new ActionListener() {
|
||||||
|
@Override
|
||||||
|
public void actionPerformed(ActionEvent e) {
|
||||||
|
frame.showPanel("MainMenu");
|
||||||
|
}
|
||||||
|
});
|
||||||
|
|
||||||
|
// Um zum Gameboard zu wechseln.
|
||||||
|
testButton.addActionListener(new ActionListener() {
|
||||||
|
@Override
|
||||||
|
public void actionPerformed(ActionEvent e) {
|
||||||
|
frame.showPanelSLG("GameBoard",1,p1,p2);
|
||||||
|
}
|
||||||
|
});
|
||||||
|
|
||||||
|
// Um zum startLocalGameLoadingScreen zu wechseln und Daten an Backend weiterzureichen.
|
||||||
startButton.addActionListener(new ActionListener() {
|
startButton.addActionListener(new ActionListener() {
|
||||||
@Override
|
@Override
|
||||||
public void actionPerformed(ActionEvent e) {
|
public void actionPerformed(ActionEvent e) {
|
||||||
|
@ -200,7 +244,11 @@ public class startLocalGame extends JPanel {
|
||||||
});
|
});
|
||||||
|
|
||||||
}
|
}
|
||||||
|
// Hilfsfunktionen
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Setzt das jeweils "nächste" Icon, wenn der leftPlayerLeftButton gedrückt wird.
|
||||||
|
*/
|
||||||
private void toggleLeftPlayerIconLeft() {
|
private void toggleLeftPlayerIconLeft() {
|
||||||
if (leftPlayerIcon.getIcon() == humanPlayerIcon) {
|
if (leftPlayerIcon.getIcon() == humanPlayerIcon) {
|
||||||
leftPlayerIcon.setIcon(aiPlayerHardIcon);
|
leftPlayerIcon.setIcon(aiPlayerHardIcon);
|
||||||
|
@ -213,6 +261,9 @@ public class startLocalGame extends JPanel {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Setzt das jeweils "nächste" Icon, wenn der leftPlayerRightButton gedrückt wird.
|
||||||
|
*/
|
||||||
private void toggleLeftPlayerIconRight() {
|
private void toggleLeftPlayerIconRight() {
|
||||||
if (leftPlayerIcon.getIcon() == humanPlayerIcon) {
|
if (leftPlayerIcon.getIcon() == humanPlayerIcon) {
|
||||||
leftPlayerIcon.setIcon(aiPlayerEasyIcon);
|
leftPlayerIcon.setIcon(aiPlayerEasyIcon);
|
||||||
|
@ -225,6 +276,9 @@ public class startLocalGame extends JPanel {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Setzt das jeweils "nächste" Icon, wenn der RightPlayerLeftButton gedrückt wird.
|
||||||
|
*/
|
||||||
private void toggleRightPlayerIconLeft() {
|
private void toggleRightPlayerIconLeft() {
|
||||||
if (rightPlayerIcon.getIcon() == aiPlayerEasyIcon) {
|
if (rightPlayerIcon.getIcon() == aiPlayerEasyIcon) {
|
||||||
rightPlayerIcon.setIcon(aiPlayerHardIcon);
|
rightPlayerIcon.setIcon(aiPlayerHardIcon);
|
||||||
|
@ -235,6 +289,9 @@ public class startLocalGame extends JPanel {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Setzt das jeweils "nächste" Icon, wenn der RightPlayerRightButton gedrückt wird.
|
||||||
|
*/
|
||||||
private void toggleRightPlayerIconRight() {
|
private void toggleRightPlayerIconRight() {
|
||||||
if (rightPlayerIcon.getIcon() == aiPlayerEasyIcon) {
|
if (rightPlayerIcon.getIcon() == aiPlayerEasyIcon) {
|
||||||
rightPlayerIcon.setIcon(aiPlayerNormalIcon);
|
rightPlayerIcon.setIcon(aiPlayerNormalIcon);
|
||||||
|
@ -245,11 +302,13 @@ public class startLocalGame extends JPanel {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
// Methode zum Aktualisieren der Textfelder basierend auf den ausgewählten Icons
|
/**
|
||||||
|
* Aktualisiert die Textfelder basierend auf den Icons
|
||||||
|
*/
|
||||||
private void updateTextFields() {
|
private void updateTextFields() {
|
||||||
// Linker Spieler
|
// Für Linken Spieler
|
||||||
if (leftPlayerIcon.getIcon() == humanPlayerIcon) {
|
if (leftPlayerIcon.getIcon() == humanPlayerIcon) {
|
||||||
leftPlayerTextField.setText("Spieler 1");
|
leftPlayerTextField.setText(leftPlayerNickname);
|
||||||
} else if (leftPlayerIcon.getIcon() == aiPlayerEasyIcon){
|
} else if (leftPlayerIcon.getIcon() == aiPlayerEasyIcon){
|
||||||
leftPlayerTextField.setText("Einfach");
|
leftPlayerTextField.setText("Einfach");
|
||||||
} else if (leftPlayerIcon.getIcon() == aiPlayerNormalIcon) {
|
} else if (leftPlayerIcon.getIcon() == aiPlayerNormalIcon) {
|
||||||
|
@ -258,7 +317,7 @@ public class startLocalGame extends JPanel {
|
||||||
leftPlayerTextField.setText("Schwer");
|
leftPlayerTextField.setText("Schwer");
|
||||||
}
|
}
|
||||||
|
|
||||||
// Rechter Spieler
|
// Für Rechten Spieler
|
||||||
if (rightPlayerIcon.getIcon() == aiPlayerEasyIcon){
|
if (rightPlayerIcon.getIcon() == aiPlayerEasyIcon){
|
||||||
rightPlayerTextField.setText("Einfach");
|
rightPlayerTextField.setText("Einfach");
|
||||||
} else if (rightPlayerIcon.getIcon() == aiPlayerNormalIcon) {
|
} else if (rightPlayerIcon.getIcon() == aiPlayerNormalIcon) {
|
||||||
|
|
|
@ -1,9 +1,19 @@
|
||||||
import javax.swing.*;
|
import javax.swing.*;
|
||||||
import java.awt.*;
|
import java.awt.*;
|
||||||
//Kann evtl. als genereller LoadingScreen verwendet werden und nicht "nur" für localGame
|
|
||||||
|
/**
|
||||||
|
* Das startLocalGameLoadingScreen Panel dient als "Überblende", während im Backend das Spiel erstellt wird.
|
||||||
|
* Hier wird lediglich Text angezeigt
|
||||||
|
*/
|
||||||
public class startLocalGameLoadingScreen extends JPanel{
|
public class startLocalGameLoadingScreen extends JPanel{
|
||||||
|
/**
|
||||||
|
* Konstruktor der startLocalGameLoadingScreen.
|
||||||
|
* @param frame Der Mainframe der Anwendung über den alle Panels angezeigt werden.
|
||||||
|
* @param semesterCounter Ein Zähler, der das gewählte Semester speichert (hier unbenutzt)
|
||||||
|
*/
|
||||||
startLocalGameLoadingScreen(MainFrame frame, int semesterCounter) {
|
startLocalGameLoadingScreen(MainFrame frame, int semesterCounter) {
|
||||||
// Layout setzen
|
|
||||||
|
// Layout des Panels
|
||||||
setLayout(new BorderLayout());
|
setLayout(new BorderLayout());
|
||||||
|
|
||||||
// Label mit dem Text erstellen
|
// Label mit dem Text erstellen
|
||||||
|
@ -11,8 +21,8 @@ public class startLocalGameLoadingScreen extends JPanel{
|
||||||
loadingLabel.setHorizontalAlignment(SwingConstants.CENTER); // Horizontal zentrieren
|
loadingLabel.setHorizontalAlignment(SwingConstants.CENTER); // Horizontal zentrieren
|
||||||
loadingLabel.setVerticalAlignment(SwingConstants.CENTER); // Vertikal zentrieren
|
loadingLabel.setVerticalAlignment(SwingConstants.CENTER); // Vertikal zentrieren
|
||||||
|
|
||||||
// Schriftgröße anpassen (optional)
|
// Schriftgröße anpassen
|
||||||
loadingLabel.setFont(new Font("Arial", Font.PLAIN, 18));
|
loadingLabel.setFont(new Font("Roboto", Font.BOLD, 45));
|
||||||
|
|
||||||
// Label zum Panel hinzufügen
|
// Label zum Panel hinzufügen
|
||||||
add(loadingLabel, BorderLayout.CENTER);
|
add(loadingLabel, BorderLayout.CENTER);
|
||||||
|
|
|
@ -1,13 +1,17 @@
|
||||||
import javax.swing.*;
|
import javax.swing.*;
|
||||||
|
import java.awt.event.ActionEvent;
|
||||||
|
import java.awt.event.ActionListener;
|
||||||
|
|
||||||
// TODO
|
/**
|
||||||
// Evtl. ist Namen selber setzten noch unmöglich
|
* Das startMultiplayerGame Panel dient dem Erstellen eines Online Spiels.
|
||||||
//
|
* Hier kann der Benutzer Spieler inklusive Namen und das Semester, in dem sich der Benutzer befindet, einstellen.
|
||||||
|
*/
|
||||||
public class startMultiplayerGame extends JPanel {
|
public class startMultiplayerGame extends JPanel {
|
||||||
|
|
||||||
// Funktionshilfen
|
// Funktionshilfen
|
||||||
int semesterCounter = 1; // Semester Counter Label
|
int semesterCounter = 1;
|
||||||
String PlayerNickname = "Spieler 1";
|
String PlayerNickname = "Spieler 1";
|
||||||
|
|
||||||
// Grafiken
|
// Grafiken
|
||||||
ImageIcon backButtonIcon = new ImageIcon("graphics/backButton.png");
|
ImageIcon backButtonIcon = new ImageIcon("graphics/backButton.png");
|
||||||
ImageIcon humanPlayerIcon = new ImageIcon("graphics/humanPlayer.png");
|
ImageIcon humanPlayerIcon = new ImageIcon("graphics/humanPlayer.png");
|
||||||
|
@ -34,11 +38,18 @@ public class startMultiplayerGame extends JPanel {
|
||||||
// Textfelder
|
// Textfelder
|
||||||
JTextField PlayerTextField = new JTextField(20);
|
JTextField PlayerTextField = new JTextField(20);
|
||||||
|
|
||||||
// Konstruktor
|
/**
|
||||||
|
* Konstruktor der startLocalGame.
|
||||||
|
* Fügt Buttons, Textfelder und Label hinzu.
|
||||||
|
* Fügt ebenfalls ActionListeners hinzu, damit Buttons etc. ihre gewünschte Funktion haben
|
||||||
|
* @param frame Der Mainframe der Anwendung über den alle Panels angezeigt werden.
|
||||||
|
*/
|
||||||
startMultiplayerGame(MainFrame frame) {
|
startMultiplayerGame(MainFrame frame) {
|
||||||
setLayout(null); // Setze das Layout für das Panel auf null
|
|
||||||
|
|
||||||
// Setze Komponentenpositionen und füge sie dem Panel hinzu
|
// Layout des Panels
|
||||||
|
setLayout(null);
|
||||||
|
|
||||||
|
// Setze Komponentenpositionen
|
||||||
frameTitle.setBounds(20, 20, 200, 30);
|
frameTitle.setBounds(20, 20, 200, 30);
|
||||||
add(frameTitle);
|
add(frameTitle);
|
||||||
|
|
||||||
|
@ -55,7 +66,6 @@ public class startMultiplayerGame extends JPanel {
|
||||||
semesterCounterLabel.setHorizontalAlignment(SwingConstants.CENTER);
|
semesterCounterLabel.setHorizontalAlignment(SwingConstants.CENTER);
|
||||||
add(semesterCounterLabel);
|
add(semesterCounterLabel);
|
||||||
|
|
||||||
// Füge Buttons hinzu und setze ihre Positionen
|
|
||||||
backButton.setBounds(1380, 20, 80, 80);
|
backButton.setBounds(1380, 20, 80, 80);
|
||||||
add(backButton);
|
add(backButton);
|
||||||
|
|
||||||
|
@ -77,22 +87,12 @@ public class startMultiplayerGame extends JPanel {
|
||||||
createGameButton.setBounds(1100, 550, 200, 50);
|
createGameButton.setBounds(1100, 550, 200, 50);
|
||||||
add(createGameButton);
|
add(createGameButton);
|
||||||
|
|
||||||
// Füge das Textfeld hinzu
|
|
||||||
PlayerTextField.setBounds(50, 650, 250, 50);
|
PlayerTextField.setBounds(50, 650, 250, 50);
|
||||||
PlayerTextField.setText(PlayerNickname);
|
PlayerTextField.setText(PlayerNickname);
|
||||||
add(PlayerTextField);
|
add(PlayerTextField);
|
||||||
|
|
||||||
/* TODO: Muss in Lucas klasse rein.
|
|
||||||
public static void startOnlineGame(Class<? extends LocalPlayer> localPlayerClass, String localPlayerName, InetSocketAddress
|
|
||||||
address, int size) throws IOException {
|
|
||||||
*/
|
|
||||||
|
|
||||||
//GameController.startOnlineGame(...);
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
// ActionListener für Buttons
|
// ActionListener für Buttons
|
||||||
// SEMESTERBUTTONS
|
// Um das Semester zu erhöhen.
|
||||||
semesterUpButton.addActionListener(e -> {
|
semesterUpButton.addActionListener(e -> {
|
||||||
if (semesterCounter < 6) {
|
if (semesterCounter < 6) {
|
||||||
semesterCounter++;
|
semesterCounter++;
|
||||||
|
@ -100,6 +100,7 @@ public class startMultiplayerGame extends JPanel {
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
|
||||||
|
// Um das Semester zu senken.
|
||||||
semesterDownButton.addActionListener(e -> {
|
semesterDownButton.addActionListener(e -> {
|
||||||
if (semesterCounter > 1) {
|
if (semesterCounter > 1) {
|
||||||
semesterCounter--;
|
semesterCounter--;
|
||||||
|
@ -107,25 +108,80 @@ public class startMultiplayerGame extends JPanel {
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
|
||||||
// PLAYERTOGGLEBUTTONS
|
// Um Player nach links zu "rotieren".
|
||||||
PlayerLeftButton.addActionListener(e -> {
|
PlayerLeftButton.addActionListener(e -> {
|
||||||
togglePlayerIconLeft();
|
togglePlayerIconLeft();
|
||||||
updateTextFields();
|
updateTextFields();
|
||||||
});
|
});
|
||||||
|
|
||||||
|
// Um Player nach rechts zu "rotieren".
|
||||||
PlayerRightButton.addActionListener(e -> {
|
PlayerRightButton.addActionListener(e -> {
|
||||||
togglePlayerIconRight();
|
togglePlayerIconRight();
|
||||||
updateTextFields();
|
updateTextFields();
|
||||||
});
|
});
|
||||||
|
|
||||||
// ActionListener für den "Back" Button, um zum vorherigen Panel zurückzukehren
|
// Um Namen des linken Spielers zu speichern.
|
||||||
|
PlayerTextField.addActionListener(e -> {
|
||||||
|
PlayerNickname = PlayerTextField.getText();
|
||||||
|
System.out.println("Linker Spielername geändert zu: " + PlayerNickname); // Debugging-Ausgabe
|
||||||
|
});
|
||||||
|
|
||||||
backButton.addActionListener(e -> frame.showPanel("MainMenu"));
|
// Um Namen des linken Spielers zu speichern, auch wenn nicht Enter gedrückt wird.
|
||||||
joinGameButton.addActionListener(e -> frame.showPanelSMG("JoinGame",1));
|
PlayerTextField.addFocusListener(new java.awt.event.FocusAdapter() {
|
||||||
createGameButton.addActionListener(e -> frame.showPanelSMG("JoinGame",0));
|
@Override
|
||||||
|
public void focusLost(java.awt.event.FocusEvent evt) {
|
||||||
|
PlayerNickname = PlayerTextField.getText();
|
||||||
|
System.out.println("Linker Spielername geändert zu: " + PlayerNickname); // Debugging-Ausgabe
|
||||||
|
}
|
||||||
|
});
|
||||||
|
|
||||||
|
// Um zum MainMenu zu wechseln.
|
||||||
|
backButton.addActionListener(new ActionListener() {
|
||||||
|
@Override
|
||||||
|
public void actionPerformed(ActionEvent e) {
|
||||||
|
frame.showPanel("MainMenu");
|
||||||
|
}
|
||||||
|
});
|
||||||
|
|
||||||
|
// Um zu JoinGame mit richtigen Parametern zu wechseln.
|
||||||
|
joinGameButton.addActionListener(new ActionListener() {
|
||||||
|
@Override
|
||||||
|
public void actionPerformed(ActionEvent e) {
|
||||||
|
if (PlayerIcon.getIcon() == humanPlayerIcon) {
|
||||||
|
frame.showPanelSMG("JoinGame",1,0, PlayerNickname);
|
||||||
|
} else if ( PlayerIcon.getIcon() == aiPlayerEasyIcon) {
|
||||||
|
frame.showPanelSMG("JoinGame",1,1, PlayerNickname);
|
||||||
|
} else if ( PlayerIcon.getIcon() == aiPlayerNormalIcon) {
|
||||||
|
frame.showPanelSMG("JoinGame",1,2, PlayerNickname);
|
||||||
|
} else if ( PlayerIcon.getIcon() == aiPlayerHardIcon) {
|
||||||
|
frame.showPanelSMG("JoinGame",1,3, PlayerNickname);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
});
|
||||||
|
|
||||||
|
// Um zu JoinGame mit richtigen Parametern zu wechseln.
|
||||||
|
createGameButton.addActionListener(new ActionListener() {
|
||||||
|
@Override
|
||||||
|
public void actionPerformed(ActionEvent e) {
|
||||||
|
//Parameter -> panelName, Spiel erstellen oder beitreten (int), Spielertyp(int 0-3), Spielername
|
||||||
|
if (PlayerIcon.getIcon() == humanPlayerIcon) { // TODO Wird name wirklich weitergegeben?
|
||||||
|
frame.showPanelSMG("JoinGame",0,0, PlayerNickname);
|
||||||
|
} else if ( PlayerIcon.getIcon() == aiPlayerEasyIcon) {
|
||||||
|
frame.showPanelSMG("JoinGame",0,1, PlayerNickname);
|
||||||
|
} else if ( PlayerIcon.getIcon() == aiPlayerNormalIcon) {
|
||||||
|
frame.showPanelSMG("JoinGame",0,2, PlayerNickname);
|
||||||
|
} else if ( PlayerIcon.getIcon() == aiPlayerHardIcon) {
|
||||||
|
frame.showPanelSMG("JoinGame",0,3, PlayerNickname);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
// TOGGLE METHODEN
|
// Hilfsfunktionen
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Setzt das jeweils "nächste" Icon, wenn der PlayerLeftButton gedrückt wird.
|
||||||
|
*/
|
||||||
private void togglePlayerIconLeft() {
|
private void togglePlayerIconLeft() {
|
||||||
if (PlayerIcon.getIcon() == humanPlayerIcon) {
|
if (PlayerIcon.getIcon() == humanPlayerIcon) {
|
||||||
PlayerIcon.setIcon(aiPlayerHardIcon);
|
PlayerIcon.setIcon(aiPlayerHardIcon);
|
||||||
|
@ -138,6 +194,9 @@ public class startMultiplayerGame extends JPanel {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Setzt das jeweils "nächste" Icon, wenn der PlayerRightButton gedrückt wird.
|
||||||
|
*/
|
||||||
private void togglePlayerIconRight() {
|
private void togglePlayerIconRight() {
|
||||||
if (PlayerIcon.getIcon() == humanPlayerIcon) {
|
if (PlayerIcon.getIcon() == humanPlayerIcon) {
|
||||||
PlayerIcon.setIcon(aiPlayerEasyIcon);
|
PlayerIcon.setIcon(aiPlayerEasyIcon);
|
||||||
|
@ -150,9 +209,12 @@ public class startMultiplayerGame extends JPanel {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Aktualisiert die Textfelder basierend auf den Icons
|
||||||
|
*/
|
||||||
private void updateTextFields() {
|
private void updateTextFields() {
|
||||||
if (PlayerIcon.getIcon() == humanPlayerIcon) {
|
if (PlayerIcon.getIcon() == humanPlayerIcon) {
|
||||||
PlayerTextField.setText("Spieler 1");
|
PlayerTextField.setText(PlayerNickname);
|
||||||
} else if (PlayerIcon.getIcon() == aiPlayerEasyIcon){
|
} else if (PlayerIcon.getIcon() == aiPlayerEasyIcon){
|
||||||
PlayerTextField.setText("Einfach");
|
PlayerTextField.setText("Einfach");
|
||||||
} else if (PlayerIcon.getIcon() == aiPlayerNormalIcon) {
|
} else if (PlayerIcon.getIcon() == aiPlayerNormalIcon) {
|
||||||
|
|
Loading…
Reference in New Issue