This commit is contained in:
Johannes Schmelz 2024-12-12 17:38:46 +01:00
parent 7c79bb77e7
commit e2db058fc7
78 changed files with 1087 additions and 369 deletions

View File

@ -192,6 +192,11 @@ public class DialogManager {
dialogStack.peek().escape(); dialogStack.peek().escape();
} }
/**
* Updates all dialogs in the dialog stack.
*
* @param delta the time since the last update
*/
public void update(float delta) { public void update(float delta) {
for (Dialog dialog : dialogStack) for (Dialog dialog : dialogStack)
dialog.update(delta); dialog.update(delta);

View File

@ -1,5 +1,10 @@
package pp.dialog; package pp.dialog;
/** An interface for tagging Dialogs as PopUps for handling in the DialogManager */
public interface PopupDialog { public interface PopupDialog {
/**
* Shows the popup.
*/
void show(); void show();
} }

View File

@ -69,8 +69,14 @@ public class BoardAppState extends MonopolyAppState {
*/ */
private PopUpManager popUpManager; private PopUpManager popUpManager;
/**
* The camera controller for managing the camera's position and orientation.
*/
private CameraController cameraController; private CameraController cameraController;
/**
* The input handler for controlling the camera's movement and rotation.
*/
private CameraInputHandler cameraInputHandler; private CameraInputHandler cameraInputHandler;
@ -251,7 +257,7 @@ public class BoardAppState extends MonopolyAppState {
rotation.fromAngleAxis(FastMath.HALF_PI, Vector3f.UNIT_Y); rotation.fromAngleAxis(FastMath.HALF_PI, Vector3f.UNIT_Y);
seaGeo.setLocalRotation(rotation); seaGeo.setLocalRotation(rotation);
final Material seaMat = new Material(getApp().getAssetManager(), "Common/MatDefs/Light/Lighting.j3md"); final Material seaMat = new Material(getApp().getAssetManager(), "Common/MatDefs/Light/Lighting.j3md");
Texture texture = getApp().getAssetManager().loadTexture("Pictures/board2.png"); Texture texture = getApp().getAssetManager().loadTexture(BoardTexture);
seaMat.setTexture("DiffuseMap", texture); seaMat.setTexture("DiffuseMap", texture);
seaGeo.setMaterial(seaMat); seaGeo.setMaterial(seaMat);
seaGeo.setShadowMode(ShadowMode.CastAndReceive); seaGeo.setShadowMode(ShadowMode.CastAndReceive);
@ -261,9 +267,13 @@ public class BoardAppState extends MonopolyAppState {
sceneNode.attachChild(seaGeo); sceneNode.attachChild(seaGeo);
// Schneefall hinzufügen // Schneefall hinzufügen
// addSnowEffect(sceneNode); addSnowEffect(sceneNode);
} }
/**
* Creates a card deck with six event and six community cards.
* @return the node containing the card deck
*/
private Node createCardDeck() { private Node createCardDeck() {
Node cardDeck = new Node("cardDeck"); Node cardDeck = new Node("cardDeck");
@ -304,6 +314,10 @@ public class BoardAppState extends MonopolyAppState {
return cardDeck; return cardDeck;
} }
/**
* Adds a snow effect to the scene by creating a particle emitter with snowflakes.
* @param parentNode the parent node to attach the snow effect to
*/
private void addSnowEffect(Node parentNode) { private void addSnowEffect(Node parentNode) {
// ParticleEmitter für Schnee // ParticleEmitter für Schnee
ParticleEmitter snowEmitter = new ParticleEmitter("Snow", ParticleMesh.Type.Triangle, 5000); ParticleEmitter snowEmitter = new ParticleEmitter("Snow", ParticleMesh.Type.Triangle, 5000);
@ -333,6 +347,11 @@ public class BoardAppState extends MonopolyAppState {
parentNode.attachChild(snowEmitter); parentNode.attachChild(snowEmitter);
} }
/**
* Updates the state by moving the camera and updating the visual elements.
*
* @param tpf the time per frame
*/
@Override @Override
public void update(float tpf) { public void update(float tpf) {
super.update(tpf); super.update(tpf);

View File

@ -48,16 +48,27 @@ public class GameSound extends AbstractAppState implements GameEventListener {
*/ */
private static final String VOLUME_PREF = "volume"; //NON-NLS private static final String VOLUME_PREF = "volume"; //NON-NLS
/** The sound effect for passing the start field. */
private AudioNode passStartSound; private AudioNode passStartSound;
/** The sound effect for drawing an event card. */
private AudioNode eventCardSound; private AudioNode eventCardSound;
/** The sound effect for going to the gulag. */
private AudioNode gulagSound; private AudioNode gulagSound;
/** The sound effect for rolling the dice. */
private AudioNode diceRollSound; private AudioNode diceRollSound;
/** The sound effect for collecting money. */
private AudioNode moneyCollectSound; private AudioNode moneyCollectSound;
/** The sound effect for losing money. */
private AudioNode moneyLostSound; private AudioNode moneyLostSound;
/** The sound effect for accepting a trade. */
private AudioNode tradeAcceptedSound; private AudioNode tradeAcceptedSound;
/** The sound effect for rejecting a trade. */
private AudioNode tradeRejectedSound; private AudioNode tradeRejectedSound;
/** The sound effect for winning the game. */
private AudioNode winnerSound; private AudioNode winnerSound;
/** The sound effect for loosing the game. */
private AudioNode looserSound; private AudioNode looserSound;
/** The sound effect for pressing a button. */
private AudioNode buttonSound; private AudioNode buttonSound;
/** /**

View File

@ -172,16 +172,19 @@ public class MonopolyApp extends SimpleApplication implements MonopolyClient, Ga
private AppSettings makeSettings() { private AppSettings makeSettings() {
final AppSettings settings = new AppSettings(true); final AppSettings settings = new AppSettings(true);
settings.setTitle(lookup("monopoly.name")); settings.setTitle(lookup("monopoly.name"));
try {
// Prüfen, ob das Betriebssystem ein Mac-System ist // Set the icon for the application window
if (!System.getProperty("os.name").toLowerCase().contains("mac")) {
settings.setIcons(new Image[]{ImageIO.read(new File("src/main/resources/icons/Uniman.png"))}); // try {
} else { // // Prüfen, ob das Betriebssystem ein Mac-System ist
LOGGER.log(Level.INFO, "Icon setting skipped on macOS due to system restrictions."); // if (!System.getProperty("os.name").toLowerCase().contains("mac")) {
} // settings.setIcons(new Image[]{ImageIO.read(new File("src/main/resources/icons/Uniman.png"))});
} catch (IOException e) { // } else {
LOGGER.log(Level.ERROR, e.getMessage()); // LOGGER.log(Level.INFO, "Icon setting skipped on macOS due to system restrictions.");
} // }
// } catch (IOException e) {
// LOGGER.log(Level.ERROR, e.getMessage());
// }
settings.setResolution(config.getResolutionWidth(), config.getResolutionHeight()); settings.setResolution(config.getResolutionWidth(), config.getResolutionHeight());
settings.setFullscreen(config.fullScreen()); settings.setFullscreen(config.fullScreen());
settings.setUseRetinaFrameBuffer(config.useRetinaFrameBuffer()); settings.setUseRetinaFrameBuffer(config.useRetinaFrameBuffer());

View File

@ -27,15 +27,32 @@ import pp.monopoly.notification.EventCardEvent;
import pp.monopoly.notification.GameEventListener; import pp.monopoly.notification.GameEventListener;
import pp.monopoly.notification.PopUpEvent; import pp.monopoly.notification.PopUpEvent;
/**
* This class is responsible for managing the popups that are shown to the user.
* It listens for events that require a popup to be shown and then shows the
* appropriate popup.
*/
public class PopUpManager implements GameEventListener { public class PopUpManager implements GameEventListener {
/** The MonopolyApp instance */
private final MonopolyApp app; private final MonopolyApp app;
/**
* Constructor for the PopUpManager.
*
* @param app The MonopolyApp instance
*/
public PopUpManager(MonopolyApp app) { public PopUpManager(MonopolyApp app) {
this.app = app; this.app = app;
app.getGameLogic().addListener(this); app.getGameLogic().addListener(this);
} }
/**
* This method is called when a PopUpEvent is received.
* It checks the message of the event and shows the appropriate popup.
*
* @param event The PopUpEvent
*/
@Override @Override
public void receivedEvent(PopUpEvent event) { public void receivedEvent(PopUpEvent event) {
if (event.msg().equals("Buy")) { if (event.msg().equals("Buy")) {
@ -84,6 +101,12 @@ public class PopUpManager implements GameEventListener {
} }
} }
/**
* This method is called when an EventCardEvent is received.
* It shows the EventCardPopup.
*
* @param event The EventCardEvent
*/
@Override @Override
public void receivedEvent(EventCardEvent event) { public void receivedEvent(EventCardEvent event) {
Timer timer = new Timer(); Timer timer = new Timer();

View File

@ -17,18 +17,35 @@ import pp.monopoly.model.Figure;
import pp.monopoly.model.Hotel; import pp.monopoly.model.Hotel;
import pp.monopoly.model.House; import pp.monopoly.model.House;
import pp.monopoly.model.Item; import pp.monopoly.model.Item;
import pp.monopoly.notification.UpdatePlayerView;
/**
* The {@code BobTheBuilder} class is responsible for synchronizing the graphical
* representation of the figures and buildings on the board with the underlying data model.
* It extends the {@link GameBoardSynchronizer} to provide specific synchronization
* logic for the board.
*/
public class BobTheBuilder extends GameBoardSynchronizer { public class BobTheBuilder extends GameBoardSynchronizer {
/** The String representing the path to the unshaded material*/
private static final String UNSHADED = "Common/MatDefs/Misc/Unshaded.j3md"; //NON-NLS private static final String UNSHADED = "Common/MatDefs/Misc/Unshaded.j3md"; //NON-NLS
/** The String representing the color parameter in the material*/
private static final String COLOR = "Color"; //NON-NLS private static final String COLOR = "Color"; //NON-NLS
/** The String representing the figure node*/
private static final String FIGURE = "figure"; //NON-NLS private static final String FIGURE = "figure"; //NON-NLS
/** The String representing the house node*/
private static final String HOUSE = "house"; //NON-NLS private static final String HOUSE = "house"; //NON-NLS
/** The String representing the hotel node*/
private static final String HOTEL = "hotel"; //NON-NLS private static final String HOTEL = "hotel"; //NON-NLS
/** The {@link MonopolyApp} instance*/
private final MonopolyApp app; private final MonopolyApp app;
/**
* Creates a new {@code BobTheBuilder} instance with the specified {@link MonopolyApp} and root node.
*
* @param app the {@link MonopolyApp} instance
* @param root the root node of the scene graph
*/
public BobTheBuilder(MonopolyApp app, Node root) { public BobTheBuilder(MonopolyApp app, Node root) {
super(app.getGameLogic().getBoard(), root); super(app.getGameLogic().getBoard(), root);
this.app = app; this.app = app;
@ -83,16 +100,33 @@ public class BobTheBuilder extends GameBoardSynchronizer {
return node; return node;
} }
/**
* Creates a new spatial to represent the specified figure.
*
* @param figure the figure to be represented
* @return the geometry representing the figure
*/
private Spatial createFigure(Figure figure) { private Spatial createFigure(Figure figure) {
// Lade das Modell Spatial model;
Spatial model = app.getAssetManager().loadModel("models/" + "Spielfiguren/" + figure.getType() + "/" + figure.getType() + ".j3o");
// Skaliere und positioniere das Modell try {
model.scale(0.5f); // Lade das Modell
model = app.getAssetManager().loadModel("models/" + "Spielfiguren/" + figure.getType() + "/" + figure.getType() + ".j3o");
// Skaliere und positioniere das Modell
model.scale(0.5f);
} catch (Exception e) {
model = createBox(figure);
}
return model; return model;
} }
/**
* Creates a new spatial to represent the specified hotel.
* @param hotel the hotel to be represented
* @return the geometry representing the hotel
*/
private Spatial createHotel(Hotel hotel) { private Spatial createHotel(Hotel hotel) {
Spatial model = app.getAssetManager().loadModel("models/Hotel/Hotel.j3o"); Spatial model = app.getAssetManager().loadModel("models/Hotel/Hotel.j3o");
model.scale(0.2f); model.scale(0.2f);
@ -100,7 +134,11 @@ public class BobTheBuilder extends GameBoardSynchronizer {
return model; return model;
} }
/**
* Creates a new spatial to represent the specified house.
* @param house the house to be represented
* @return the geometry representing the house
*/
private Spatial createHouse(House house) { private Spatial createHouse(House house) {
Spatial model = app.getAssetManager().loadModel("models/Haus/"+house.getStage()+"Haus.j3o"); Spatial model = app.getAssetManager().loadModel("models/Haus/"+house.getStage()+"Haus.j3o");
model.scale(0.5f); model.scale(0.5f);

View File

@ -191,9 +191,6 @@ public class BuildingAdminMenu extends Dialog {
app.getGuiNode().attachChild(background); app.getGuiNode().attachChild(background);
} }
/**
* Closes the building administration menu and detaches its elements from the GUI.
*/
@Override @Override
public void close() { public void close() {
app.getGuiNode().detachChild(mainContainer); app.getGuiNode().detachChild(mainContainer);
@ -201,21 +198,8 @@ public class BuildingAdminMenu extends Dialog {
super.close(); super.close();
} }
/**
* Opens the settings menu when the escape key is pressed.
*/
@Override @Override
public void escape() { public void escape() {
new SettingsMenu(app).open(); new SettingsMenu(app).open();
} }
/**
* Periodic updates for the menu, if required.
*
* @param delta Time since the last update in seconds.
*/
@Override
public void update(float delta) {
// Periodic updates if necessary
}
} }

View File

@ -3,25 +3,39 @@ package pp.monopoly.client.gui;
import com.jme3.math.Vector3f; import com.jme3.math.Vector3f;
import com.jme3.renderer.Camera; import com.jme3.renderer.Camera;
import pp.monopoly.client.MonopolyApp; // Import MonopolyApp import pp.monopoly.client.MonopolyApp;
import pp.monopoly.game.server.PlayerHandler; import pp.monopoly.game.server.PlayerHandler;
import pp.monopoly.notification.GameEventListener; import pp.monopoly.notification.GameEventListener;
import pp.monopoly.notification.UpdatePlayerView; import pp.monopoly.notification.UpdatePlayerView;
/**
* Represents a camera controller for the Monopoly application.
*/
public class CameraController implements GameEventListener{ public class CameraController implements GameEventListener{
/**
* Enum representing the camera mode for the CameraController.
*/
public enum CameraMode { public enum CameraMode {
FOCUS_CURRENT_PLAYER, FOCUS_CURRENT_PLAYER,
FOCUS_SELF, FOCUS_SELF,
FREECAM FREECAM
} }
/** The camera to control */
private final Camera camera; private final Camera camera;
/** The current camera mode */
private CameraMode currentMode; private CameraMode currentMode;
/** The player handler instance */
private PlayerHandler playerHandler;
/** The {@link MonopolyApp} instance*/
private final MonopolyApp app;
private PlayerHandler playerHandler; // Reference to PlayerHandler for player data /**
private final MonopolyApp app; // Reference to MonopolyApp for self ID * Constructs a new CameraController instance.
* @param camera The camera to control
* @param app The MonopolyApp instance
*/
public CameraController(Camera camera, MonopolyApp app) { public CameraController(Camera camera, MonopolyApp app) {
this.camera = camera; this.camera = camera;
this.playerHandler = app.getGameLogic().getPlayerHandler(); this.playerHandler = app.getGameLogic().getPlayerHandler();
@ -30,10 +44,28 @@ public class CameraController implements GameEventListener{
setMode(CameraMode.FOCUS_SELF); // Initialize the camera mode setMode(CameraMode.FOCUS_SELF); // Initialize the camera mode
} }
/**
* Sets the camera mode to the specified mode.
* @param mode The camera mode to set
*/
public void setMode(CameraMode mode) { public void setMode(CameraMode mode) {
this.currentMode = mode; this.currentMode = mode;
} }
/**
* Updates the camera behavior based on the current mode and the time-per-frame (tpf).
* <p>
* This method checks the current mode of the camera and updates its position or behavior accordingly.
* Supported modes include:
* <ul>
* <li>FOCUS_CURRENT_PLAYER: Updates the camera position to focus on the current player.</li>
* <li>FOCUS_SELF: Updates the camera position to focus on the self (the object controlled by the player).</li>
* <li>FREECAM: Leaves the camera position unchanged, allowing free movement.</li>
* </ul>
*
* @param tpf The time-per-frame value, typically provided by the game engine,
* which represents the elapsed time since the last frame.
*/
public void update(float tpf) { public void update(float tpf) {
switch (currentMode) { switch (currentMode) {
@ -53,6 +85,9 @@ public class CameraController implements GameEventListener{
} }
} }
/**
* Updates the camera position depending on the current mode.
*/
public void updatePosition() { public void updatePosition() {
Vector3f newPosition = getPos(); Vector3f newPosition = getPos();
camera.setLocation(newPosition); camera.setLocation(newPosition);
@ -61,6 +96,10 @@ public class CameraController implements GameEventListener{
camera.update(); camera.update();
} }
/**
* Returns the position for the camera depending on the current mode.
* @return The position for the camera
*/
private Vector3f getPos() { private Vector3f getPos() {
Vector3f pos = new Vector3f(); Vector3f pos = new Vector3f();
switch (currentMode) { switch (currentMode) {
@ -83,6 +122,10 @@ public class CameraController implements GameEventListener{
} }
/**
* Calculates the offset for the camera depending on the field the player is on.
* @return The offset for the camera
*/
private Vector3f getOffset() { private Vector3f getOffset() {
Vector3f offset = new Vector3f(); Vector3f offset = new Vector3f();

View File

@ -5,9 +5,19 @@ import com.jme3.input.KeyInput;
import com.jme3.input.controls.ActionListener; import com.jme3.input.controls.ActionListener;
import com.jme3.input.controls.KeyTrigger; import com.jme3.input.controls.KeyTrigger;
/**
* Class to handle the input for the camera.
*/
public class CameraInputHandler { public class CameraInputHandler {
/**The camera controller */
private CameraController cameraController; private CameraController cameraController;
/**
* Constructor for the CameraInputHandler.
* @param cameraController The camera controller.
* @param inputManager The input manager.
*/
public CameraInputHandler(CameraController cameraController, InputManager inputManager) { public CameraInputHandler(CameraController cameraController, InputManager inputManager) {
this.cameraController = cameraController; this.cameraController = cameraController;
@ -19,6 +29,9 @@ public class CameraInputHandler {
inputManager.addListener(actionListener, "FocusCurrentPlayer", "FocusSelf", "FreeCam"); inputManager.addListener(actionListener, "FocusCurrentPlayer", "FocusSelf", "FreeCam");
} }
/**
* ActionListener for the camera.
*/
private final ActionListener actionListener = (name, isPressed, tpf) -> { private final ActionListener actionListener = (name, isPressed, tpf) -> {
if (!isPressed) return; if (!isPressed) return;

View File

@ -22,21 +22,34 @@ import pp.monopoly.message.client.ViewAssetsRequest;
import pp.monopoly.model.TradeHandler; import pp.monopoly.model.TradeHandler;
import pp.monopoly.notification.Sound; import pp.monopoly.notification.Sound;
/**
* Dialog for choosing a trade partner.
*/
public class ChoosePartner extends Dialog { public class ChoosePartner extends Dialog {
/** The {@link MonopolyApp} instance*/
private final MonopolyApp app; private final MonopolyApp app;
/** Selector for selecting the player */
private Selector<String> playerSelector; private Selector<String> playerSelector;
/** Button for cancel*/
private final Button cancelButton = new Button("Abbrechen"); private final Button cancelButton = new Button("Abbrechen");
/** Button for confirm*/
private final Button confirmButton = new Button("Bestätigen"); private final Button confirmButton = new Button("Bestätigen");
/** Main container for the UI components */
private final Container mainContainer; private final Container mainContainer;
/** Container for the lower left menu */
private Container lowerLeftMenu; private Container lowerLeftMenu;
/** Container for the lower right menu */
private Container lowerRightMenu; private Container lowerRightMenu;
/** The background image */
private Geometry background; private Geometry background;
/** The trade handler */
private TradeHandler tradeHandler; private TradeHandler tradeHandler;
private VersionedReference<Set<Integer>> selectionRef; // Reference to track selector changes /** Reference to track selector changes */
private String lastSelected = ""; // To keep track of the last selected value private VersionedReference<Set<Integer>> selectionRef;
/** The last selected value */
QuadBackgroundComponent translucentWhiteBackground = private String lastSelected = "";
new QuadBackgroundComponent(new ColorRGBA(1.0f, 1.0f, 1.0f, 0.5f)); /** The translucent white background */
private QuadBackgroundComponent translucentWhiteBackground = new QuadBackgroundComponent(new ColorRGBA(1.0f, 1.0f, 1.0f, 0.5f));
/** /**
* Constructs the ChoosePartner dialog. * Constructs the ChoosePartner dialog.
@ -169,9 +182,6 @@ public class ChoosePartner extends Dialog {
app.getGuiNode().attachChild(background); app.getGuiNode().attachChild(background);
} }
/**
* Handles the escape action for the dialog.
*/
@Override @Override
public void escape() { public void escape() {
new SettingsMenu(app).open(); new SettingsMenu(app).open();

View File

@ -38,18 +38,31 @@ import pp.dialog.DialogBuilder;
* Allows users to specify the host and port for connecting to a game server. * Allows users to specify the host and port for connecting to a game server.
*/ */
public class CreateGameMenu extends Dialog { public class CreateGameMenu extends Dialog {
/** The Logger for this class */
private static final Logger LOGGER = System.getLogger(CreateGameMenu.class.getName()); private static final Logger LOGGER = System.getLogger(CreateGameMenu.class.getName());
/** A string represing the localhost default */
private static final String LOCALHOST = "localhost"; //NON-NLS private static final String LOCALHOST = "localhost"; //NON-NLS
/** A string representing the default port number */
private static final String DEFAULT_PORT = "42069"; //NON-NLS private static final String DEFAULT_PORT = "42069"; //NON-NLS
/** The NetworkSupport instance to be used for network operations */
private final NetworkSupport network; private final NetworkSupport network;
/** The text field for the host name */
private final TextField host = new TextField(LOCALHOST); private final TextField host = new TextField(LOCALHOST);
/** The text field for the port number */
private final TextField port = new TextField(DEFAULT_PORT); private final TextField port = new TextField(DEFAULT_PORT);
/** The button for starting the server */
private final Button serverButton = new Button("Selber hosten"); private final Button serverButton = new Button("Selber hosten");
/** The button for canceling the connection */
private final Button cancelButton = new Button("Abbrechen"); private final Button cancelButton = new Button("Abbrechen");
/** The button for joining a game */
private final Button joinButton = new Button("Beitreten"); private final Button joinButton = new Button("Beitreten");
/** The hostname of the server */
private String hostname; private String hostname;
/** The port number of the server */
private int portNumber; private int portNumber;
/** The future representing the connection to the server */
private Future<Object> connectionFuture; private Future<Object> connectionFuture;
/** The dialog for indicating that the connection is in progress */
private Dialog progressDialog; private Dialog progressDialog;
/** /**

View File

@ -9,31 +9,49 @@ import com.jme3.scene.Node;
import com.jme3.scene.control.AbstractControl; import com.jme3.scene.control.AbstractControl;
import pp.monopoly.client.MonopolyApp; import pp.monopoly.client.MonopolyApp;
import pp.monopoly.game.client.ClientGameLogic;
import pp.monopoly.model.Figure; import pp.monopoly.model.Figure;
import pp.monopoly.notification.GameEventListener; import pp.monopoly.notification.GameEventListener;
import pp.monopoly.notification.UpdatePlayerView; import pp.monopoly.notification.UpdatePlayerView;
// import java.lang.System.Logger; import java.lang.System.Logger;
// import java.lang.System.Logger.Level; import java.lang.System.Logger.Level;
import java.util.LinkedList; import java.util.LinkedList;
import java.util.Queue; import java.util.Queue;
/**
* Control class for the figure objects.
*
* Handles the movement of the figure along a path.
*
*/
public class FigureControl extends AbstractControl implements GameEventListener { public class FigureControl extends AbstractControl implements GameEventListener {
/** The Logger for this class */
// // // private static final Logger LOGGER = System.getLogger(FigureControl.class.getName()); private static final Logger LOGGER = System.getLogger(FigureControl.class.getName());
/** The Figure object to control */
private final Figure figure; private final Figure figure;
/** The spatial object of the figure*/
private final Node spatial; private final Node spatial;
/** The MonopolyApp instance */
private final MonopolyApp app; private final MonopolyApp app;
private Queue<Vector3f> path; // Path to follow /** The path to follow */
private Queue<Vector3f> path;
/** The current target position */
private Vector3f currentTarget; private Vector3f currentTarget;
private float animationTime = 0f; // Time elapsed for the current movement /** The time elapsed for the current movement */
private final float durationPerField = 0.5f; // Time to move between fields private float animationTime = 0f;
private float delayTime = 3f; // Verzögerung in Sekunden /** The duration per field */
private float delayElapsed = 0f; // Zeit, die seit dem Start der Verzögerung vergangen ist private final float durationPerField = 0.5f;
/** The delay time */
private float delayTime = 3f;
/** The delay elapsed time */
private float delayElapsed = 0f;
/**
* Constructor for the FigureControl class
* @param spatial The spatial object of the figure
* @param figure The figure object
* @param app The MonopolyApp object
*/
public FigureControl(Node spatial, Figure figure, MonopolyApp app) { public FigureControl(Node spatial, Figure figure, MonopolyApp app) {
super(); super();
this.figure = figure; this.figure = figure;
@ -43,6 +61,14 @@ public class FigureControl extends AbstractControl implements GameEventListener
app.getGameLogic().addListener(this); app.getGameLogic().addListener(this);
} }
/**
* Updates the figure's movement along a path.
*
* Handles movement delays, rotates at specific fields (0, 10, 20, 30),
* and moves the figure with a hop effect toward the next target.
*
* @param tpf Time-per-frame since the last update.
*/
@Override @Override
protected void controlUpdate(float tpf) { protected void controlUpdate(float tpf) {
if (delayTime > 0) { if (delayTime > 0) {
@ -61,7 +87,6 @@ public class FigureControl extends AbstractControl implements GameEventListener
// Prüfe, ob eine Drehung erforderlich ist (Felder 0, 10, 20, 30) // Prüfe, ob eine Drehung erforderlich ist (Felder 0, 10, 20, 30)
int currentField = figure.getCurrentFieldID(); int currentField = figure.getCurrentFieldID();
int nextField = nextField(currentField);
if ((nextField(currentField) == 10) || if ((nextField(currentField) == 10) ||
(nextField(currentField) == 20) || (nextField(currentField) == 20) ||
@ -100,8 +125,11 @@ public class FigureControl extends AbstractControl implements GameEventListener
} }
} }
/**
* Calculate the next field on the board
* @param currentField The current field id
* @return The next field id
*/
private int nextField(int currentField) { private int nextField(int currentField) {
return (currentField + 1) % 40; return (currentField + 1) % 40;
} }
@ -113,35 +141,40 @@ public class FigureControl extends AbstractControl implements GameEventListener
// No rendering logic required // No rendering logic required
} }
/**
* Set the path for the figure to follow
* @param startField The field the figure is currently on
* @param endField The field the figure should move to
*/
public void setPath(int startField, int endField) { public void setPath(int startField, int endField) {
// LOGGER.log(Level.TRACE, "setPath called with startField: {0} to endField {1}", startField, endField); LOGGER.log(Level.TRACE, "setPath called with startField: {0} to endField {1}", startField, endField);
path.clear(); path.clear();
for (int fieldId = startField; fieldId != endField; fieldId = (fieldId + 1) % 40) { for (int fieldId = startField; fieldId != endField; fieldId = (fieldId + 1) % 40) {
Vector3f position = figure.calculateFieldPosition(fieldId); Vector3f position = figure.calculateFieldPosition(fieldId);
// LOGGER.log(Level.DEBUG, "Adding postition to path: {0}", position); LOGGER.log(Level.DEBUG, "Adding postition to path: {0}", position);
path.add(position); path.add(position);
} }
Vector3f finalPosition = figure.calculateFieldPosition(endField); Vector3f finalPosition = figure.calculateFieldPosition(endField);
path.add(finalPosition); path.add(finalPosition);
// LOGGER.log(Level.DEBUG, "Final position added to path: {0}", finalPosition); LOGGER.log(Level.DEBUG, "Final position added to path: {0}", finalPosition);
// LOGGER.log(Level.TRACE, "Path size: {0}", path.size()); LOGGER.log(Level.TRACE, "Path size: {0}", path.size());
} }
@Override @Override
public void receivedEvent(UpdatePlayerView event) { public void receivedEvent(UpdatePlayerView event) {
// LOGGER.log(Level.TRACE, "receivedEvent called with event: {0}", event); LOGGER.log(Level.TRACE, "receivedEvent called with event: {0}", event);
int newPos = app.getGameLogic().getPlayerHandler().getPlayerById(figure.getId()).getFieldID(); int newPos = app.getGameLogic().getPlayerHandler().getPlayerById(figure.getId()).getFieldID();
int currentField = figure.getCurrentFieldID(); int currentField = figure.getCurrentFieldID();
if (currentField == newPos) { if (currentField == newPos) {
// LOGGER.log(Level.DEBUG, "No movement required. Current field: {0}, New field: {1}", currentField, newPos); LOGGER.log(Level.DEBUG, "No movement required. Current field: {0}, New field: {1}", currentField, newPos);
return; return;
} }
// LOGGER.log(Level.DEBUG, "Movement required. Current field: {0}, New field: {1}", currentField, newPos); LOGGER.log(Level.DEBUG, "Movement required. Current field: {0}, New field: {1}", currentField, newPos);
setPath(currentField, newPos); setPath(currentField, newPos);
@ -150,9 +183,4 @@ public class FigureControl extends AbstractControl implements GameEventListener
} }
} }

View File

@ -4,26 +4,23 @@ import com.jme3.scene.Node;
import com.jme3.scene.Spatial; import com.jme3.scene.Spatial;
import pp.monopoly.model.Item; import pp.monopoly.model.Item;
import pp.monopoly.model.Visitor; import pp.monopoly.model.Visitor;
import pp.monopoly.notification.DiceRollEvent;
import pp.monopoly.notification.GameEventListener; import pp.monopoly.notification.GameEventListener;
import pp.monopoly.notification.ItemAddedEvent; import pp.monopoly.notification.ItemAddedEvent;
import pp.monopoly.notification.ItemRemovedEvent; import pp.monopoly.notification.ItemRemovedEvent;
import pp.monopoly.notification.UpdatePlayerView;
import pp.monopoly.model.Board; import pp.monopoly.model.Board;
import pp.monopoly.model.Figure;
import pp.view.ModelViewSynchronizer; import pp.view.ModelViewSynchronizer;
/** /**
* Abstract base class for synchronizing the visual representation of a {@link Board} with its model state. * Abstract base class for synchronizing the visual representation of a {@link Board} with its model state.
* This class handles the addition and removal of items from the board, ensuring that changes in the model * This class handles the addition and removal of items from the board, ensuring that changes in the model
* are accurately reflected in the view. * are accurately reflected in the view.
* <p> *
* Subclasses are responsible for providing the specific implementation of how each item in the map * Subclasses are responsible for providing the specific implementation of how each item in the map
* is represented visually by implementing the {@link Visitor} interface. * is represented visually by implementing the {@link Visitor} interface.
* </p> *
*/ */
abstract class GameBoardSynchronizer extends ModelViewSynchronizer<Item> implements Visitor<Spatial>, GameEventListener { abstract class GameBoardSynchronizer extends ModelViewSynchronizer<Item> implements Visitor<Spatial>, GameEventListener {
// The board that this synchronizer is responsible for /** The board that this synchronizer is responsible for*/
protected final Board board; protected final Board board;
/** /**

View File

@ -9,12 +9,24 @@ import pp.monopoly.game.server.Player;
import pp.monopoly.game.server.PlayerColor; import pp.monopoly.game.server.PlayerColor;
import pp.monopoly.notification.Sound; import pp.monopoly.notification.Sound;
/**
* A custom button class that uses images for its appearance. The button's appearance changes based on its state (enabled,
*/
public class ImageButton extends Button { public class ImageButton extends Button {
/** The MonopolyApp instance */
private final MonopolyApp app; private final MonopolyApp app;
/** The button's functionality (e.g., "end_turn", "roll_dice") */
private final String functionality; private final String functionality;
/** The player's color */
private final PlayerColor playerColor; private final PlayerColor playerColor;
/**
* Creates a new ImageButton with the given functionality and MonopolyApp instance.
*
* @param functionality the button's functionality (e.g., "end_turn", "roll_dice")
* @param app the MonopolyApp instance
*/
public ImageButton(String functionality, MonopolyApp app) { public ImageButton(String functionality, MonopolyApp app) {
super("", "button-clear"); super("", "button-clear");
this.app = app; this.app = app;
@ -82,10 +94,12 @@ public class ImageButton extends Button {
ENABLED, DISABLED, HOVER ENABLED, DISABLED, HOVER
} }
@Override
public void addClickCommands( Command<? super Button> command ) { public void addClickCommands( Command<? super Button> command ) {
super.addCommands(ButtonAction.Down, command); super.addCommands(ButtonAction.Down, command);
} }
@Override
@SuppressWarnings("unchecked") // because Java doesn't like var-arg generics @SuppressWarnings("unchecked") // because Java doesn't like var-arg generics
public void addClickCommands( Command<? super Button>... commands ) { public void addClickCommands( Command<? super Button>... commands ) {
super.addCommands(ButtonAction.Down, commands); super.addCommands(ButtonAction.Down, commands);

View File

@ -32,10 +32,10 @@ import java.util.Set;
/** /**
* Represents the lobby menu in the Monopoly application. * Represents the lobby menu in the Monopoly application.
* <p> *
* Provides functionality for player configuration, including input for starting capital, * Provides functionality for player configuration, including input for starting capital,
* player name, and figure selection, as well as options to ready up or exit the game. * player name, and figure selection, as well as options to ready up or exit the game.
* </p> *
*/ */
public class LobbyMenu extends Dialog { public class LobbyMenu extends Dialog {
@ -270,9 +270,6 @@ public class LobbyMenu extends Dialog {
app.getGameLogic().send(new PlayerReady(true, playerInputField.getText(), figure, Integer.parseInt(startingCapital.getText()))); app.getGameLogic().send(new PlayerReady(true, playerInputField.getText(), figure, Integer.parseInt(startingCapital.getText())));
} }
/**
* Opens the settings menu when the escape key is pressed.
*/
@Override @Override
public void escape() { public void escape() {
new SettingsMenu(app).open(); new SettingsMenu(app).open();
@ -291,11 +288,6 @@ public class LobbyMenu extends Dialog {
} }
} }
/**
* Closes the current menu and transitions music playback.
* Stops the secondary music (if playing) and resumes the main background music
* if music is enabled in the preferences. Ensures smooth transitions in audio.
*/
@Override @Override
public void close() { public void close() {
GameMusic music = app.getStateManager().getState(GameMusic.class); GameMusic music = app.getStateManager().getState(GameMusic.class);

View File

@ -28,10 +28,15 @@ import java.util.stream.Collectors;
* PropertyOverviewMenu is a dialog for displaying the player's properties in the game. * PropertyOverviewMenu is a dialog for displaying the player's properties in the game.
*/ */
public class PropertyOverviewMenu extends Dialog { public class PropertyOverviewMenu extends Dialog {
/** The MonopolyApp instance */
private final MonopolyApp app; private final MonopolyApp app;
/** The main container for the menu layout */
private final Container mainContainer; private final Container mainContainer;
/** The container for displaying the "Gebäude" cards */
private final Container displayContainer; private final Container displayContainer;
/** The horizontal slider for scrolling through cards */
private final Slider horizontalSlider; private final Slider horizontalSlider;
/** The list of cards to display */
private final List<Container> cards; private final List<Container> cards;
/** /**
@ -124,6 +129,9 @@ public class PropertyOverviewMenu extends Dialog {
/** /**
* Creates a card for BuildingProperty with detailed rent and cost information. * Creates a card for BuildingProperty with detailed rent and cost information.
*
* @param field The BuildingProperty to create a card for.
* @return The created card container.
*/ */
private Container createBuildingCard(BuildingProperty field) { private Container createBuildingCard(BuildingProperty field) {
Container card = new Container(); Container card = new Container();
@ -156,6 +164,9 @@ public class PropertyOverviewMenu extends Dialog {
/** /**
* Creates a card for FoodField with dynamic pricing and rent details. * Creates a card for FoodField with dynamic pricing and rent details.
*
* @param field The FoodField to create a card for.
* @return The created card container.
*/ */
private Container createFoodFieldCard(FoodField field) { private Container createFoodFieldCard(FoodField field) {
Container card = new Container(); Container card = new Container();
@ -188,6 +199,9 @@ public class PropertyOverviewMenu extends Dialog {
/** /**
* Creates a card for GateField with rent details for owning multiple gates. * Creates a card for GateField with rent details for owning multiple gates.
*
* @param field The GateField to create a card for.
* @return The created card container.
*/ */
private Container createGateFieldCard(GateField field) { private Container createGateFieldCard(GateField field) {
Container card = new Container(); Container card = new Container();
@ -260,9 +274,6 @@ public class PropertyOverviewMenu extends Dialog {
} }
/**
* Closes the dialog and detaches it from the GUI node.
*/
@Override @Override
public void close() { public void close() {
app.getGuiNode().detachChild(mainContainer); app.getGuiNode().detachChild(mainContainer);

View File

@ -136,9 +136,6 @@ public class SettingsMenu extends Dialog {
update(); update();
} }
/**
* As an escape action, this method closes the menu if it is the top dialog.
*/
@Override @Override
public void escape() { public void escape() {
close(); close();

View File

@ -3,12 +3,15 @@ package pp.monopoly.client.gui;
import com.simsilica.lemur.Slider; import com.simsilica.lemur.Slider;
import pp.monopoly.client.GameSound; import pp.monopoly.client.GameSound;
/**
* A slider for the sound effects volume.
*/
public class SoundSlider extends Slider { public class SoundSlider extends Slider {
/** /**
* Manages sound effects for the game. * Manages sound effects for the game.
*/ */
private final pp.monopoly.client.GameSound sound; private final GameSound sound;
/** /**
* Volume level for the game sounds. * Volume level for the game sounds.

View File

@ -20,6 +20,9 @@ import pp.monopoly.notification.Sound;
* Constructs the startup menu dialog for the Monopoly application. * Constructs the startup menu dialog for the Monopoly application.
*/ */
public class StartMenu extends Dialog { public class StartMenu extends Dialog {
/**
* The Monopoly application instance.
*/
private final MonopolyApp app; private final MonopolyApp app;
/** /**
@ -105,17 +108,11 @@ public class StartMenu extends Dialog {
app.getGuiNode().attachChild(unibwContainer); app.getGuiNode().attachChild(unibwContainer);
} }
/**
* Opens the settings menu when the escape key is pressed.
*/
@Override @Override
public void escape() { public void escape() {
new SettingsMenu(app).open(); new SettingsMenu(app).open();
} }
/**
* Closes the startup menu and detaches all GUI elements.
*/
@Override @Override
public void close() { public void close() {
app.getGuiNode().detachAllChildren(); app.getGuiNode().detachAllChildren();

View File

@ -273,17 +273,21 @@ public class Toolbar extends Dialog implements GameEventListener {
* Handles the dice roll event. * Handles the dice roll event.
*/ */
private void handleDiceRoll() { private void handleDiceRoll() {
ifTopDialog(() -> { ifTopDialog(() -> {
if (!canRollDice) return; if (!canRollDice) return;
canRollDice = false; canRollDice = false;
if (endTurnButton != null) endTurnButton.setEnabled(true); if (endTurnButton != null) endTurnButton.setEnabled(true);
startDiceAnimation(); startDiceAnimation();
app.getGameLogic().send(new RollDice()); app.getGameLogic().send(new RollDice());
app.getGameLogic().playSound(Sound.BUTTON); app.getGameLogic().playSound(Sound.BUTTON);
}); });
} }
/**
* Creates the trade button.
*
* @return The trade button.
*/
private Button createTradeButton() { private Button createTradeButton() {
String iconPath = "icons/icon-handeln.png"; String iconPath = "icons/icon-handeln.png";
// createActionButton(playerColor, "icons/icon-handeln.png", 100, () -> new ChoosePartner(app).open()); // createActionButton(playerColor, "icons/icon-handeln.png", 100, () -> new ChoosePartner(app).open());
@ -304,7 +308,11 @@ public class Toolbar extends Dialog implements GameEventListener {
return tradeButton; return tradeButton;
} }
/**
* Creates the property menu button.
*
* @return The property menu button.
*/
private Button createPropertyMenuButton() { private Button createPropertyMenuButton() {
String iconPath = "icons/icon-gebaude.png"; String iconPath = "icons/icon-gebaude.png";
@ -324,6 +332,11 @@ public class Toolbar extends Dialog implements GameEventListener {
return propertyMenuButton; return propertyMenuButton;
} }
/**
* Creates the end turn button.
*
* @return The end turn button.
*/
private Button createEndTurnButton() { private Button createEndTurnButton() {
// return createActionButton(playerColor, "icons/icon-zugbeenden.png", 75, () -> handleEndTurn()); // return createActionButton(playerColor, "icons/icon-zugbeenden.png", 75, () -> handleEndTurn());
@ -525,18 +538,11 @@ public class Toolbar extends Dialog implements GameEventListener {
endTurnButton.setEnabled(false); endTurnButton.setEnabled(false);
} }
/**
* Closes the toolbar, detaching it from the GUI.
*/
@Override @Override
public void close() { public void close() {
app.getGuiNode().detachChild(toolbarContainer); app.getGuiNode().detachChild(toolbarContainer);
super.close(); super.close();
} }
/**
* Opens the settings menu when the escape key is pressed.
*/
@Override @Override
public void escape() { public void escape() {
new SettingsMenu(app).open(); new SettingsMenu(app).open();

View File

@ -30,10 +30,10 @@ import java.util.stream.Collectors;
/** /**
* Represents the trade menu dialog in the Monopoly application. * Represents the trade menu dialog in the Monopoly application.
* <p> *
* Facilitates trade interactions between players, including selection of properties, * Facilitates trade interactions between players, including selection of properties,
* currency, and special cards for offers and requests. * currency, and special cards for offers and requests.
* </p> *
*/ */
public class TradeMenu extends Dialog { public class TradeMenu extends Dialog {
@ -48,17 +48,26 @@ public class TradeMenu extends Dialog {
/** Background geometry for the menu. */ /** Background geometry for the menu. */
private Geometry background; private Geometry background;
/** The building and card selector for the left column. */
private Selector<String> leftBuildingSelector, leftSpecialCardSelector; private Selector<String> leftBuildingSelector, leftSpecialCardSelector;
/** The building and card selector for the right column. */
private Selector<String> rightBuildingSelector, rightSpecialCardSelector; private Selector<String> rightBuildingSelector, rightSpecialCardSelector;
/** The labels for displaying selected properties. */
private Label leftSelectionsLabel, rightSelectionsLabel; private Label leftSelectionsLabel, rightSelectionsLabel;
/** The text fields for currency input. */
private TextField leftCurrencyInput, rightCurrencyInput; private TextField leftCurrencyInput, rightCurrencyInput;
/** References for tracking UI changes. */
private VersionedReference<Set<Integer>> leftBuildingRef, rightBuildingRef; private VersionedReference<Set<Integer>> leftBuildingRef, rightBuildingRef;
/** References for tracking UI changes. */
private VersionedReference<Set<Integer>> leftCardRef, rightCardRef; private VersionedReference<Set<Integer>> leftCardRef, rightCardRef;
/** The selected buildings for the trade. */
private Set<String> rightselBuildings = new HashSet<>(); private Set<String> rightselBuildings = new HashSet<>();
/** The selected buildings for the trade. */
private Set<String> leftselBuildings = new HashSet<>(); private Set<String> leftselBuildings = new HashSet<>();
/** The color for the trade menu background. */
private static final ColorRGBA TRANSLUCENT_WHITE = new ColorRGBA(1, 1, 1, 0.5f); private static final ColorRGBA TRANSLUCENT_WHITE = new ColorRGBA(1, 1, 1, 0.5f);
/** /**
@ -80,7 +89,11 @@ public class TradeMenu extends Dialog {
initializeReferences(); initializeReferences();
} }
/** Creates the main container for the trade menu UI. */
/**
* Creates the main container for the trade menu.
* @return the created main container
*/
private Container createMainContainer() { private Container createMainContainer() {
Container container = new Container(new SpringGridLayout(Axis.Y, Axis.X)); Container container = new Container(new SpringGridLayout(Axis.Y, Axis.X));
container.setPreferredSize(new Vector3f(1200, 800, 0)); container.setPreferredSize(new Vector3f(1200, 800, 0));
@ -90,7 +103,11 @@ public class TradeMenu extends Dialog {
container.addChild(createMainContent()); container.addChild(createMainContent());
return container; return container;
} }
/** Creates the header label for the trade menu. */
/**
* Creates the header label for the trade menu.
* @return the created header label
*/
private Label createHeader() { private Label createHeader() {
Label header = new Label("Handelsmenü", new ElementId("label-Bold")); Label header = new Label("Handelsmenü", new ElementId("label-Bold"));
header.setFontSize(50); header.setFontSize(50);
@ -98,7 +115,11 @@ public class TradeMenu extends Dialog {
header.setBackground(new QuadBackgroundComponent(TRANSLUCENT_WHITE)); header.setBackground(new QuadBackgroundComponent(TRANSLUCENT_WHITE));
return header; return header;
} }
/** Creates the main content section of the trade menu. */
/**
* Creates the main content for the trade menu.
* @return the created main content container
*/
private Container createMainContent() { private Container createMainContent() {
Container mainContent = new Container(new SpringGridLayout(Axis.X, Axis.Y)); Container mainContent = new Container(new SpringGridLayout(Axis.X, Axis.Y));
mainContent.setPreferredSize(new Vector3f(1200, 700, 0)); mainContent.setPreferredSize(new Vector3f(1200, 700, 0));
@ -110,7 +131,9 @@ public class TradeMenu extends Dialog {
return mainContent; return mainContent;
} }
/** Sets the trade data based on the current selections. */ /**
* Sets the trade values based on the user input.
*/
private void setTrades() { private void setTrades() {
String leftCurreny = leftCurrencyInput.getText().equals("")? "0" : leftCurrencyInput.getText(); String leftCurreny = leftCurrencyInput.getText().equals("")? "0" : leftCurrencyInput.getText();
String rightCurreny = rightCurrencyInput.getText().equals("")? "0" : rightCurrencyInput.getText(); String rightCurreny = rightCurrencyInput.getText().equals("")? "0" : rightCurrencyInput.getText();
@ -232,13 +255,21 @@ public class TradeMenu extends Dialog {
combinedProperties = combinedProperties.stream().sorted(Comparator.comparingInt(PropertyField::getId)).collect(Collectors.toList()); combinedProperties = combinedProperties.stream().sorted(Comparator.comparingInt(PropertyField::getId)).collect(Collectors.toList());
return combinedProperties; return combinedProperties;
} }
/** Creates a text field for currency input. */
/**
* Creates a currency input field for the trade menu.
* @return the created currency input field
*/
private TextField createCurrencyInput() { private TextField createCurrencyInput() {
TextField currencyInput = new TextField("0"); TextField currencyInput = new TextField("0");
styleTextField(currencyInput); styleTextField(currencyInput);
return currencyInput; return currencyInput;
} }
/** Creates the middle section containing buttons and summary fields. */
/**
* Creates the middle section of the trade menu.
* @return the created middle section container
*/
private Container createMiddleSection() { private Container createMiddleSection() {
Container middleSection = new Container(new SpringGridLayout(Axis.Y, Axis.X)); Container middleSection = new Container(new SpringGridLayout(Axis.Y, Axis.X));
middleSection.setBackground(new QuadBackgroundComponent(new ColorRGBA(0.8f, 0.8f, 0.8f, 1.0f))); middleSection.setBackground(new QuadBackgroundComponent(new ColorRGBA(0.8f, 0.8f, 0.8f, 1.0f)));
@ -281,13 +312,19 @@ public class TradeMenu extends Dialog {
return middleSection; return middleSection;
} }
/** Styles the given selector with insets and background color. */ /**
* Styles the given selector with insets and background color.
* @param selector the selector to style
*/
private void styleSelector(Selector<String> selector) { private void styleSelector(Selector<String> selector) {
selector.setInsets(new Insets3f(5, 10, 5, 10)); selector.setInsets(new Insets3f(5, 10, 5, 10));
selector.setBackground(new QuadBackgroundComponent(ColorRGBA.Black)); selector.setBackground(new QuadBackgroundComponent(ColorRGBA.Black));
} }
/** Styles the given text field with insets and background color. */ /**
* Styles the given text field with insets and background color.
* @param textField the text field to style
*/
private void styleTextField(TextField textField) { private void styleTextField(TextField textField) {
textField.setInsets(new Insets3f(5, 10, 5, 10)); textField.setInsets(new Insets3f(5, 10, 5, 10));
textField.setBackground(new QuadBackgroundComponent(ColorRGBA.Black)); textField.setBackground(new QuadBackgroundComponent(ColorRGBA.Black));
@ -314,7 +351,10 @@ public class TradeMenu extends Dialog {
rightCurrencyInput = currencyInput; rightCurrencyInput = currencyInput;
} }
} }
/** Positions the main container at the center of the screen. */
/**
* Positions the main container in the center of the screen.
*/
private void positionMainContainer() { private void positionMainContainer() {
mainContainer.setLocalTranslation( mainContainer.setLocalTranslation(
(app.getCamera().getWidth() - mainContainer.getPreferredSize().x) / 2, (app.getCamera().getWidth() - mainContainer.getPreferredSize().x) / 2,
@ -322,7 +362,10 @@ public class TradeMenu extends Dialog {
7 7
); );
} }
/** Adds a background image to the trade menu. */
/**
* Adds a background image to the trade menu.
*/
private void addBackgroundImage() { private void addBackgroundImage() {
Texture backgroundImage = app.getAssetManager().loadTexture("Pictures/unibw-Bib2.png"); Texture backgroundImage = app.getAssetManager().loadTexture("Pictures/unibw-Bib2.png");
Quad quad = new Quad(app.getCamera().getWidth(), app.getCamera().getHeight()); Quad quad = new Quad(app.getCamera().getWidth(), app.getCamera().getHeight());
@ -333,6 +376,7 @@ public class TradeMenu extends Dialog {
background.setLocalTranslation(0, 0, 6); background.setLocalTranslation(0, 0, 6);
app.getGuiNode().attachChild(background); app.getGuiNode().attachChild(background);
} }
/** Initializes references for tracking UI changes. */ /** Initializes references for tracking UI changes. */
private void initializeReferences() { private void initializeReferences() {
leftBuildingRef = leftBuildingSelector.getSelectionModel().createReference(); leftBuildingRef = leftBuildingSelector.getSelectionModel().createReference();

View File

@ -10,7 +10,9 @@ import pp.monopoly.client.GameMusic;
*/ */
public class VolumeSlider extends Slider { public class VolumeSlider extends Slider {
private final pp.monopoly.client.GameMusic music; /** The GameMusic instance to handel */
private final GameMusic music;
/** The volume of the music */
private double vol; private double vol;
/** /**

View File

@ -117,9 +117,6 @@ public class Bankrupt extends Dialog implements PopupDialog {
); );
} }
/**
* Displays the popup by attaching it to the GUI.
*/
@Override @Override
public void show() { public void show() {
app.getGuiNode().attachChild(overlayBackground); app.getGuiNode().attachChild(overlayBackground);
@ -128,9 +125,6 @@ public class Bankrupt extends Dialog implements PopupDialog {
centerContainers(); centerContainers();
} }
/**
* Closes the popup and removes the associated GUI elements.
*/
@Override @Override
public void close() { public void close() {
app.getGuiNode().detachChild(overlayBackground); app.getGuiNode().detachChild(overlayBackground);
@ -139,9 +133,6 @@ public class Bankrupt extends Dialog implements PopupDialog {
super.close(); super.close();
} }
/**
* Handles the escape key action by closing the popup.
*/
@Override @Override
public void escape() { public void escape() {
close(); close();

View File

@ -22,8 +22,11 @@ import pp.monopoly.notification.Sound;
*/ */
public class BuildingPropertyCard extends Dialog implements PopupDialog { public class BuildingPropertyCard extends Dialog implements PopupDialog {
/**The Monopoly application instance*/
private final MonopolyApp app; private final MonopolyApp app;
/**The main container for the popup*/
private final Container buildingPropertyContainer; private final Container buildingPropertyContainer;
/**The background container for the popup*/
private final Container backgroundContainer; private final Container backgroundContainer;
/** /**
@ -136,18 +139,12 @@ public class BuildingPropertyCard extends Dialog implements PopupDialog {
); );
} }
/**
* Attaches the popup to the GUI through the DialogManager.
*/
@Override @Override
public void show() { public void show() {
app.getGuiNode().attachChild(backgroundContainer); app.getGuiNode().attachChild(backgroundContainer);
app.getGuiNode().attachChild(buildingPropertyContainer); app.getGuiNode().attachChild(buildingPropertyContainer);
} }
/**
* Closes the popup and removes associated GUI elements.
*/
@Override @Override
public void close() { public void close() {
app.getGuiNode().detachChild(buildingPropertyContainer); app.getGuiNode().detachChild(buildingPropertyContainer);
@ -155,9 +152,6 @@ public class BuildingPropertyCard extends Dialog implements PopupDialog {
super.close(); super.close();
} }
/**
* Opens the settings menu when the escape key is pressed.
*/
@Override @Override
public void escape() { public void escape() {
new SettingsMenu(app).open(); new SettingsMenu(app).open();

View File

@ -227,9 +227,6 @@ public class BuyHouse extends Dialog {
this.cost.setText(cost+""); this.cost.setText(cost+"");
} }
/**
* Closes the popup and removes its GUI elements.
*/
@Override @Override
public void close() { public void close() {
app.getGuiNode().detachChild(buyHouseContainer); app.getGuiNode().detachChild(buyHouseContainer);
@ -237,9 +234,6 @@ public class BuyHouse extends Dialog {
super.close(); super.close();
} }
/**
* Opens the settings menu when the escape key is pressed.
*/
@Override @Override
public void escape() { public void escape() {
new SettingsMenu(app).open(); new SettingsMenu(app).open();

View File

@ -124,9 +124,6 @@ public class ConfirmTrade extends Dialog implements PopupDialog {
})); }));
} }
/**
* Displays the popup by attaching it to the GUI.
*/
@Override @Override
public void show() { public void show() {
float padding = 10; float padding = 10;
@ -149,9 +146,6 @@ public class ConfirmTrade extends Dialog implements PopupDialog {
app.getGuiNode().attachChild(confirmTradeContainer); app.getGuiNode().attachChild(confirmTradeContainer);
} }
/**
* Closes the popup and removes its GUI elements.
*/
@Override @Override
public void close() { public void close() {
app.getGuiNode().detachChild(confirmTradeContainer); app.getGuiNode().detachChild(confirmTradeContainer);
@ -159,9 +153,6 @@ public class ConfirmTrade extends Dialog implements PopupDialog {
super.close(); super.close();
} }
/**
* Opens the settings menu when the escape key is pressed.
*/
@Override @Override
public void escape() { public void escape() {
new SettingsMenu(app).open(); new SettingsMenu(app).open();

View File

@ -99,9 +99,6 @@ public class EventCardPopup extends Dialog implements PopupDialog {
})); }));
} }
/**
* Displays the popup by attaching it to the GUI.
*/
@Override @Override
public void show() { public void show() {
float padding = 10; float padding = 10;
@ -125,9 +122,6 @@ public class EventCardPopup extends Dialog implements PopupDialog {
app.getGuiNode().attachChild(eventCardContainer); app.getGuiNode().attachChild(eventCardContainer);
} }
/**
* Closes the popup and removes its associated GUI elements.
*/
@Override @Override
public void close() { public void close() {
app.getGuiNode().detachChild(overlayBackground); app.getGuiNode().detachChild(overlayBackground);
@ -136,9 +130,6 @@ public class EventCardPopup extends Dialog implements PopupDialog {
super.close(); super.close();
} }
/**
* Handles the escape key action by closing the popup.
*/
@Override @Override
public void escape() { public void escape() {
close(); close();

View File

@ -123,9 +123,6 @@ public class FoodFieldCard extends Dialog implements PopupDialog {
})); }));
} }
/**
* Displays the popup by attaching its elements to the GUI.
*/
@Override @Override
public void show() { public void show() {
float padding = 10; float padding = 10;
@ -149,9 +146,6 @@ public class FoodFieldCard extends Dialog implements PopupDialog {
app.getGuiNode().attachChild(foodFieldContainer); app.getGuiNode().attachChild(foodFieldContainer);
} }
/**
* Closes the popup and removes its associated GUI elements.
*/
@Override @Override
public void close() { public void close() {
app.getGuiNode().detachChild(overlayBackground); app.getGuiNode().detachChild(overlayBackground);
@ -160,9 +154,6 @@ public class FoodFieldCard extends Dialog implements PopupDialog {
super.close(); super.close();
} }
/**
* Handles the escape key action by closing the popup.
*/
@Override @Override
public void escape() { public void escape() {
close(); close();

View File

@ -104,9 +104,6 @@ public class GateFieldCard extends Dialog implements PopupDialog {
})); }));
} }
/**
* Displays the popup by attaching its elements to the GUI.
*/
@Override @Override
public void show() { public void show() {
float padding = 10; float padding = 10;
@ -129,9 +126,6 @@ public class GateFieldCard extends Dialog implements PopupDialog {
app.getGuiNode().attachChild(gateFieldContainer); app.getGuiNode().attachChild(gateFieldContainer);
} }
/**
* Closes the popup and removes its associated GUI elements.
*/
@Override @Override
public void close() { public void close() {
app.getGuiNode().detachChild(gateFieldContainer); // Remove main container app.getGuiNode().detachChild(gateFieldContainer); // Remove main container
@ -139,9 +133,6 @@ public class GateFieldCard extends Dialog implements PopupDialog {
super.close(); super.close();
} }
/**
* Opens the settings menu when the escape key is pressed.
*/
@Override @Override
public void escape() { public void escape() {
new SettingsMenu(app).open(); new SettingsMenu(app).open();

View File

@ -19,9 +19,9 @@ import pp.monopoly.notification.Sound;
/** /**
* Gulag is a warning popup triggered when a player lands on the "Wache" field in the Monopoly game. * Gulag is a warning popup triggered when a player lands on the "Wache" field in the Monopoly game.
* <p> *
* This popup informs the player that they are being sent to the Gulag and includes a confirmation button. * This popup informs the player that they are being sent to the Gulag and includes a confirmation button.
* </p> *
*/ */
public class Gulag extends Dialog implements PopupDialog { public class Gulag extends Dialog implements PopupDialog {
/** Reference to the Monopoly application instance. */ /** Reference to the Monopoly application instance. */
@ -94,9 +94,6 @@ public class Gulag extends Dialog implements PopupDialog {
})); }));
} }
/**
* Displays the popup by attaching its elements to the GUI.
*/
@Override @Override
public void show() { public void show() {
float padding = 10; float padding = 10;
@ -120,9 +117,6 @@ public class Gulag extends Dialog implements PopupDialog {
app.getGuiNode().attachChild(gulagContainer); app.getGuiNode().attachChild(gulagContainer);
} }
/**
* Closes the popup and removes its associated GUI elements.
*/
@Override @Override
public void close() { public void close() {
app.getGuiNode().detachChild(overlayBackground); app.getGuiNode().detachChild(overlayBackground);
@ -131,9 +125,6 @@ public class Gulag extends Dialog implements PopupDialog {
super.close(); super.close();
} }
/**
* Handles the escape action by closing the popup.
*/
@Override @Override
public void escape() { public void escape() {
close(); close();

View File

@ -115,9 +115,6 @@ public class GulagInfo extends Dialog implements PopupDialog {
} }
} }
/**
* Displays the popup by attaching its elements to the GUI.
*/
@Override @Override
public void show() { public void show() {
float padding = 10; float padding = 10;
@ -142,13 +139,15 @@ public class GulagInfo extends Dialog implements PopupDialog {
app.getGuiNode().attachChild(gulagInfoContainer); app.getGuiNode().attachChild(gulagInfoContainer);
} }
/**
* Closes the GulagInfo popup and removes its GUI elements.
*/
@Override @Override
public void close() { public void close() {
app.getGuiNode().detachChild(gulagInfoContainer); // Remove dialog app.getGuiNode().detachChild(gulagInfoContainer); // Remove dialog
app.getGuiNode().detachChild(backgroundContainer); // Remove background app.getGuiNode().detachChild(backgroundContainer); // Remove background
super.close(); super.close();
} }
@Override
public void escape() {
close();
}
} }

View File

@ -18,9 +18,9 @@ import pp.monopoly.notification.Sound;
/** /**
* LooserPopUp is a dialog that appears when a player loses the game. * LooserPopUp is a dialog that appears when a player loses the game.
* <p> *
* This popup provides a message of encouragement and an option to quit the game. * This popup provides a message of encouragement and an option to quit the game.
* </p> *
*/ */
public class LooserPopUp extends Dialog { public class LooserPopUp extends Dialog {
/** Reference to the Monopoly application instance. */ /** Reference to the Monopoly application instance. */
@ -123,9 +123,6 @@ public class LooserPopUp extends Dialog {
return overlay; return overlay;
} }
/**
* Closes the LooserPopUp dialog and removes its GUI elements.
*/
@Override @Override
public void close() { public void close() {
app.getGuiNode().detachChild(LooserContainer); // Entferne das Menü app.getGuiNode().detachChild(LooserContainer); // Entferne das Menü
@ -134,9 +131,6 @@ public class LooserPopUp extends Dialog {
super.close(); super.close();
} }
/**
* Handles the escape action to close the dialog.
*/
@Override @Override
public void escape() { public void escape() {
close(); close();

View File

@ -127,9 +127,6 @@ public class NoMoneyWarning extends Dialog implements PopupDialog {
); );
} }
/**
* Displays the dialog by attaching its components to the GUI node.
*/
@Override @Override
public void show() { public void show() {
app.getGuiNode().attachChild(overlayBackground); app.getGuiNode().attachChild(overlayBackground);
@ -137,9 +134,6 @@ public class NoMoneyWarning extends Dialog implements PopupDialog {
app.getGuiNode().attachChild(noMoneyWarningContainer); app.getGuiNode().attachChild(noMoneyWarningContainer);
} }
/**
* Closes the dialog and removes its components from the GUI node.
*/
@Override @Override
public void close() { public void close() {
app.getGuiNode().detachChild(overlayBackground); app.getGuiNode().detachChild(overlayBackground);
@ -148,9 +142,6 @@ public class NoMoneyWarning extends Dialog implements PopupDialog {
super.close(); super.close();
} }
/**
* Handles the escape action to close the dialog.
*/
@Override @Override
public void escape() { public void escape() {
close(); close();

View File

@ -125,9 +125,6 @@ public class ReceivedRent extends Dialog implements PopupDialog {
); );
} }
/**
* Displays the popup by attaching it to the GUI through the DialogManager.
*/
@Override @Override
public void show() { public void show() {
app.getGuiNode().attachChild(overlayBackground); app.getGuiNode().attachChild(overlayBackground);
@ -136,9 +133,6 @@ public class ReceivedRent extends Dialog implements PopupDialog {
centerContainers(); centerContainers();
} }
/**
* Closes the popup and removes GUI elements.
*/
@Override @Override
public void close() { public void close() {
app.getGuiNode().detachChild(overlayBackground); app.getGuiNode().detachChild(overlayBackground);
@ -147,9 +141,6 @@ public class ReceivedRent extends Dialog implements PopupDialog {
super.close(); super.close();
} }
/**
* Handles the escape action to close the dialog.
*/
@Override @Override
public void escape() { public void escape() {
close(); close();

View File

@ -134,9 +134,6 @@ public class RejectTrade extends Dialog implements PopupDialog {
); );
} }
/**
* Displays the popup by attaching its elements to the GUI node.
*/
@Override @Override
public void show() { public void show() {
app.getGuiNode().attachChild(overlayBackground); app.getGuiNode().attachChild(overlayBackground);
@ -144,9 +141,6 @@ public class RejectTrade extends Dialog implements PopupDialog {
app.getGuiNode().attachChild(rejectTradeContainer); app.getGuiNode().attachChild(rejectTradeContainer);
} }
/**
* Closes the menu and removes the GUI elements.
*/
@Override @Override
public void close() { public void close() {
app.getGuiNode().detachChild(overlayBackground); app.getGuiNode().detachChild(overlayBackground);
@ -155,9 +149,6 @@ public class RejectTrade extends Dialog implements PopupDialog {
super.close(); super.close();
} }
/**
* Handles the escape key action by closing the popup.
*/
@Override @Override
public void escape() { public void escape() {
close(); close();

View File

@ -19,17 +19,28 @@ import pp.monopoly.notification.Sound;
/** /**
* Rent is a popup that is triggered when a player lands on a property owned by another player * Rent is a popup that is triggered when a player lands on a property owned by another player
* and needs to pay rent in the Monopoly application. * and needs to pay rent in the Monopoly application.
* <p> *
* Displays the rent amount and the recipient player's name, with an option to confirm the payment. * Displays the rent amount and the recipient player's name, with an option to confirm the payment.
* </p> *
*/ */
public class Rent extends Dialog implements PopupDialog { public class Rent extends Dialog implements PopupDialog {
private final MonopolyApp app;
/** Reference to the Monopoly application instance. */
private final MonopolyApp app;
/** Semi-transparent overlay background for the popup. */
private final Geometry overlayBackground; private final Geometry overlayBackground;
/** Main container for the rent information and action. */
private final Container rentContainer; private final Container rentContainer;
/** Background container providing a border for the rent popup. */
private final Container backgroundContainer; private final Container backgroundContainer;
/**
* Constructs the Rent popup displaying the rent amount and recipient player's name.
*
* @param app the Monopoly application instance
* @param playerName the name of the player to pay rent to
* @param amount the amount of rent to pay
*/
public Rent(MonopolyApp app, String playerName, int amount) { public Rent(MonopolyApp app, String playerName, int amount) {
super(app.getDialogManager()); super(app.getDialogManager());
this.app = app; this.app = app;
@ -43,6 +54,11 @@ public class Rent extends Dialog implements PopupDialog {
centerContainers(); centerContainers();
} }
/**
* Creates the semi-transparent overlay background for the popup.
*
* @return the geometry of the overlay
*/
private Geometry createOverlayBackground() { private Geometry createOverlayBackground() {
Quad quad = new Quad(app.getCamera().getWidth(), app.getCamera().getHeight()); Quad quad = new Quad(app.getCamera().getWidth(), app.getCamera().getHeight());
Geometry overlay = new Geometry("Overlay", quad); Geometry overlay = new Geometry("Overlay", quad);
@ -54,12 +70,24 @@ public class Rent extends Dialog implements PopupDialog {
return overlay; return overlay;
} }
/**
* Creates the background container for the rent popup.
*
* @return the background container
*/
private Container createBackgroundContainer() { private Container createBackgroundContainer() {
Container container = new Container(); Container container = new Container();
container.setBackground(new QuadBackgroundComponent(new ColorRGBA(0.8657f, 0.8735f, 0.8892f, 1.0f))); container.setBackground(new QuadBackgroundComponent(new ColorRGBA(0.8657f, 0.8735f, 0.8892f, 1.0f)));
return container; return container;
} }
/**
* Creates the main container for the rent popup.
*
* @param playerName the name of the player to pay rent to
* @param amount the amount of rent to pay
* @return the rent container
*/
private Container createRentContainer(String playerName, int amount) { private Container createRentContainer(String playerName, int amount) {
Container container = new Container(); Container container = new Container();
container.setBackground(new QuadBackgroundComponent(ColorRGBA.Gray)); container.setBackground(new QuadBackgroundComponent(ColorRGBA.Gray));
@ -85,6 +113,9 @@ public class Rent extends Dialog implements PopupDialog {
return container; return container;
} }
/**
* Centers the rent and background containers on the screen.
*/
private void centerContainers() { private void centerContainers() {
float padding = 10; float padding = 10;

View File

@ -29,10 +29,10 @@ import java.util.stream.Collectors;
/** /**
* RepayMortage is a popup that appears when a player selects the "Repay Mortgage" option * RepayMortage is a popup that appears when a player selects the "Repay Mortgage" option
* in the Building Administration Menu. * in the Building Administration Menu.
* <p> *
* This popup allows the player to select mortgaged properties and repay their mortgages, * This popup allows the player to select mortgaged properties and repay their mortgages,
* showing the total cost of the repayment. Includes options to confirm or cancel the repayment. * showing the total cost of the repayment. Includes options to confirm or cancel the repayment.
* </p> *
*/ */
public class RepayMortage extends Dialog { public class RepayMortage extends Dialog {
/** Reference to the Monopoly application instance. */ /** Reference to the Monopoly application instance. */
@ -231,9 +231,6 @@ public class RepayMortage extends Dialog {
this.cost.setText(cost+""); this.cost.setText(cost+"");
} }
/**
* Closes the popup and removes its associated GUI elements.
*/
@Override @Override
public void close() { public void close() {
app.getGuiNode().detachChild(repayMortageContainer); // Entferne das Menü app.getGuiNode().detachChild(repayMortageContainer); // Entferne das Menü
@ -241,9 +238,6 @@ public class RepayMortage extends Dialog {
super.close(); super.close();
} }
/**
* Opens the settings menu when the escape key is pressed.
*/
@Override @Override
public void escape() { public void escape() {
new SettingsMenu(app).open(); new SettingsMenu(app).open();

View File

@ -29,10 +29,10 @@ import java.util.stream.Collectors;
/** /**
* SellHouse is a popup that appears when a player clicks on the "Demolish" button * SellHouse is a popup that appears when a player clicks on the "Demolish" button
* in the BuildingAdminMenu. * in the BuildingAdminMenu.
* <p> *
* This dialog allows players to select their properties and demolish houses or hotels * This dialog allows players to select their properties and demolish houses or hotels
* for a partial refund of their purchase cost. * for a partial refund of their purchase cost.
* </p> *
*/ */
public class SellHouse extends Dialog { public class SellHouse extends Dialog {
/** Reference to the Monopoly application instance. */ /** Reference to the Monopoly application instance. */
@ -230,9 +230,6 @@ public class SellHouse extends Dialog {
this.cost.setText(cost+""); this.cost.setText(cost+"");
} }
/**
* Closes the dialog and removes GUI elements from the screen.
*/
@Override @Override
public void close() { public void close() {
app.getGuiNode().detachChild(sellhouseContainer); // Entferne das Menü app.getGuiNode().detachChild(sellhouseContainer); // Entferne das Menü
@ -240,9 +237,6 @@ public class SellHouse extends Dialog {
super.close(); super.close();
} }
/**
* Handles the escape action to close the dialog.
*/
@Override @Override
public void escape() { public void escape() {
new SettingsMenu(app).open(); new SettingsMenu(app).open();

View File

@ -240,9 +240,6 @@ public class TakeMortage extends Dialog {
this.cost.setText(cost+""); this.cost.setText(cost+"");
} }
/**
* Closes the dialog and removes GUI elements from the screen.
*/
@Override @Override
public void close() { public void close() {
app.getGuiNode().detachChild(takeMortageContainer); // Entferne das Menü app.getGuiNode().detachChild(takeMortageContainer); // Entferne das Menü
@ -250,9 +247,6 @@ public class TakeMortage extends Dialog {
super.close(); super.close();
} }
/**
* Handles the escape action to close the dialog.
*/
@Override @Override
public void escape() { public void escape() {
new SettingsMenu(app).open(); new SettingsMenu(app).open();

View File

@ -18,9 +18,9 @@ import pp.monopoly.notification.Sound;
/** /**
* WinnerPopUp is a dialog displayed when a player wins the Monopoly game. * WinnerPopUp is a dialog displayed when a player wins the Monopoly game.
* <p> *
* This popup congratulates the player for their victory and provides an option to quit the game. * This popup congratulates the player for their victory and provides an option to quit the game.
* </p> *
*/ */
public class WinnerPopUp extends Dialog { public class WinnerPopUp extends Dialog {
/** Reference to the Monopoly application instance. */ /** Reference to the Monopoly application instance. */
@ -121,9 +121,6 @@ public class WinnerPopUp extends Dialog {
return overlay; return overlay;
} }
/**
* Closes the WinnerPopUp dialog and removes its GUI elements.
*/
@Override @Override
public void close() { public void close() {
app.getGuiNode().detachChild(WinnerContainer); // Entferne das Menü app.getGuiNode().detachChild(WinnerContainer); // Entferne das Menü
@ -132,9 +129,6 @@ public class WinnerPopUp extends Dialog {
super.close(); super.close();
} }
/**
* Handles the escape action to close the dialog.
*/
@Override @Override
public void escape() { public void escape() {
close(); close();

View File

@ -69,10 +69,13 @@ public class ClientGameLogic implements ServerInterpreter, GameEventBroker {
/** The current state of the client game logic. */ /** The current state of the client game logic. */
private ClientState state = new LobbyState(this); private ClientState state = new LobbyState(this);
/** The player handler containing information about all players in the game. */
private PlayerHandler playerHandler; private PlayerHandler playerHandler;
/** The board manager containing information about all fields on the board. */
private BoardManager boardManager = new BoardManager(); private BoardManager boardManager = new BoardManager();
/** The trade handler containing information about trades in the game. */
private TradeHandler tradeHandler; private TradeHandler tradeHandler;

View File

@ -7,6 +7,7 @@
package pp.monopoly.game.server; package pp.monopoly.game.server;
import java.lang.System.Logger;
import java.util.ArrayList; import java.util.ArrayList;
import java.util.HashSet; import java.util.HashSet;
import java.util.List; import java.util.List;
@ -39,24 +40,35 @@ import pp.monopoly.model.fields.WacheField;
* Class representing a player * Class representing a player
*/ */
@Serializable @Serializable
public class Player implements FieldVisitor<Void>{ public class Player implements FieldVisitor<Void> {
/** The logger for this class */
private final static Logger LOGGER = System.getLogger(Player.class.getName());
/** The player id */
private final int id; private final int id;
/** The player name */
private String name; private String name;
/** The player account balance */
private int accountBalance = 15000; private int accountBalance = 15000;
/** The player figure */
private String figure; private String figure;
/** The player properties */
private Set<Integer> properties = new HashSet<>(); private Set<Integer> properties = new HashSet<>();
/** The number of GetOutOfJailCards owned by the player */
private int getOutOfJailCard; private int getOutOfJailCard;
/** The current field id of the player */
private int fieldID; private int fieldID;
/** The result of the last dice roll */
private DiceResult rollResult; private DiceResult rollResult;
/** The player handler */
private transient final PlayerHandler handler; private transient final PlayerHandler handler;
/** The current state of the player */
private transient PlayerState state = new WaitForTurnState(); private transient PlayerState state = new WaitForTurnState();
/** /**
* Default constructor for serialization purposes. * Default constructor for serialization purposes.
*/ */
private Player(){ private Player(){
id = 0; this(0, null);
handler = null;
} }
/** /**
@ -69,6 +81,7 @@ public class Player implements FieldVisitor<Void>{
this.name = name; this.name = name;
this.id = id; this.id = id;
this.handler = handler; this.handler = handler;
LOGGER.log(Logger.Level.INFO, "Player created: " + name);
} }
/** /**
@ -77,8 +90,7 @@ public class Player implements FieldVisitor<Void>{
* @param handler the PlayerHandler this player is a part of * @param handler the PlayerHandler this player is a part of
*/ */
public Player(int id, PlayerHandler handler) { public Player(int id, PlayerHandler handler) {
this.id = id; this(id, null, handler);
this.handler = handler;
} }
/** /**
@ -97,6 +109,10 @@ public class Player implements FieldVisitor<Void>{
return figure; return figure;
} }
/**
* Returns the color of the player
* @return the color of the player
*/
public static PlayerColor getColor(int id) { public static PlayerColor getColor(int id) {
switch ((id%6)+1) { switch ((id%6)+1) {
case 1: return PlayerColor.CYAN; case 1: return PlayerColor.CYAN;
@ -143,6 +159,10 @@ public class Player implements FieldVisitor<Void>{
return fieldID; return fieldID;
} }
/**
* Sets the state of the player to active
* If the player is in jail, the player will be asked to pay the bail
*/
void setActive() { void setActive() {
System.out.println("State: "+state.getClass().getName()); System.out.println("State: "+state.getClass().getName());
if(!(state instanceof JailState)) { if(!(state instanceof JailState)) {
@ -153,6 +173,11 @@ public class Player implements FieldVisitor<Void>{
} }
} }
/**
* Finish the turn of the player
* If the player has a negative account balance, the player will be bankrupted
* @return true if the turn was finished successfully, false if the player is bankrupt
*/
boolean finishTurn() { boolean finishTurn() {
if(canFinishTurn()) { if(canFinishTurn()) {
if (state instanceof ActiveState) state = new WaitForTurnState(); if (state instanceof ActiveState) state = new WaitForTurnState();
@ -164,14 +189,26 @@ public class Player implements FieldVisitor<Void>{
} }
} }
/**
* Checks if the player can finish the turn
* @return true if the player can finish the turn, false if the player is bankrupt
*/
boolean canFinishTurn() { boolean canFinishTurn() {
return accountBalance >= 0; return accountBalance >= 0;
} }
/**
* Returns the current state of the player
* @return the current state of the player
*/
public PlayerState getState() { public PlayerState getState() {
return state; return state;
} }
/**
* Sets the state of the player
* @param state the new state of the player
*/
public void setState(PlayerState state) { public void setState(PlayerState state) {
this.state = state; this.state = state;
} }
@ -206,7 +243,7 @@ public class Player implements FieldVisitor<Void>{
return fieldID; return fieldID;
} }
/** /**
* Sets the player to the specified Position on the board * Sets the player to the specified Position on the board
* @param position the position to move to * @param position the position to move to
* @return the new position * @return the new position
@ -297,7 +334,7 @@ public class Player implements FieldVisitor<Void>{
/** /**
* Return the number of GEtOutOfJailCards owned by this player * Return the number of GEtOutOfJailCards owned by this player
* @return * @return the number of GetOutOfJailCards owned by this player
*/ */
public int getNumJailCard() { public int getNumJailCard() {
return getOutOfJailCard; return getOutOfJailCard;
@ -335,7 +372,11 @@ public class Player implements FieldVisitor<Void>{
state.useJailCard(); state.useJailCard();
} }
private void sendRentNotification(String keyword, Player player, int amount) { /**
* Sends a notification to the player
* @param keyword the keyword of the notification
*/
private void sendNotification(String keyword, Player player, int amount) {
NotificationMessage msg = new NotificationMessage(keyword); NotificationMessage msg = new NotificationMessage(keyword);
msg.setRentAmount(amount); msg.setRentAmount(amount);
msg.setRentOwnerId(player.getName()); msg.setRentOwnerId(player.getName());
@ -351,8 +392,8 @@ public class Player implements FieldVisitor<Void>{
int rent = field.calcRent(); int rent = field.calcRent();
field.getOwner().earnMoney(rent); field.getOwner().earnMoney(rent);
pay(rent); pay(rent);
sendRentNotification("ReceivedRent", this, rent); sendNotification("ReceivedRent", this, rent);
sendRentNotification("rent", field.getOwner(), rent); sendNotification("rent", field.getOwner(), rent);
} }
return null; return null;
} }
@ -369,8 +410,8 @@ public class Player implements FieldVisitor<Void>{
int rent = rollResult.calcTotal()*factor; int rent = rollResult.calcTotal()*factor;
field.getOwner().earnMoney(rent); field.getOwner().earnMoney(rent);
pay(rent); pay(rent);
sendRentNotification("ReceivedRent", this, rent); sendNotification("ReceivedRent", this, rent);
sendRentNotification("rent", field.getOwner(), rent); sendNotification("rent", field.getOwner(), rent);
} }
return null; return null;
} }
@ -384,8 +425,8 @@ public class Player implements FieldVisitor<Void>{
field.getOwner().earnMoney(rent); field.getOwner().earnMoney(rent);
pay(rent); pay(rent);
sendRentNotification("ReceivedRent", this, rent); sendNotification("ReceivedRent", this, rent);
sendRentNotification("rent", field.getOwner(), rent); sendNotification("rent", field.getOwner(), rent);
} }
return null; return null;
} }
@ -450,6 +491,9 @@ public class Player implements FieldVisitor<Void>{
handler.getLogic().send(this, new JailEvent(true)); handler.getLogic().send(this, new JailEvent(true));
} }
/**
* Sends the player to jail by setting position and state.
*/
void jail() { void jail() {
state = new JailState(); state = new JailState();
fieldID = 10; fieldID = 10;
@ -473,6 +517,10 @@ public class Player implements FieldVisitor<Void>{
return count; return count;
} }
/**
* Return the number of Houses owned by the player
* @return the number of houses owned by the player
*/
public int getNumHouses() { public int getNumHouses() {
int total = 0; int total = 0;
for (PropertyField field : getPropertyFields()) { for (PropertyField field : getPropertyFields()) {
@ -483,6 +531,10 @@ public class Player implements FieldVisitor<Void>{
return total; return total;
} }
/**
* Return the number of Hotels owned by the player
* @return the number of hotels owned by the player
*/
public int getNumHotels() { public int getNumHotels() {
int total = 0; int total = 0;
for (PropertyField field : getPropertyFields()) { for (PropertyField field : getPropertyFields()) {
@ -527,6 +579,9 @@ public class Player implements FieldVisitor<Void>{
return state.rollDice(); return state.rollDice();
} }
/**
* Bankrupts the player by removing all properties and setting the account balance to 0.
*/
private void bankrupt() { private void bankrupt() {
for (PropertyField field : getPropertyFields()) { for (PropertyField field : getPropertyFields()) {
field.setOwner(null); field.setOwner(null);
@ -654,6 +709,10 @@ public class Player implements FieldVisitor<Void>{
} }
} }
/**
* A class to represent the WaitForTurn PlayerState
* Set when it is not the players turn
*/
private class WaitForTurnState implements PlayerState { private class WaitForTurnState implements PlayerState {
@Override @Override
@ -676,10 +735,18 @@ public class Player implements FieldVisitor<Void>{
return "Player{name=" + name + ", figure=" + figure + "}"; return "Player{name=" + name + ", figure=" + figure + "}";
} }
/**
* Adds a property to the player
* @param id the id of the property to be added
*/
public void addProperty(Integer id) { public void addProperty(Integer id) {
properties.add(id); properties.add(id);
} }
/**
* Removes a property from the player
* @param id the id of the property to be removed
*/
public void removeProperty(Integer id) { public void removeProperty(Integer id) {
properties.remove(id); properties.remove(id);
} }

View File

@ -172,12 +172,20 @@ public class PlayerHandler {
players.get(0).setActive(); players.get(0).setActive();
} }
/**
* Sets the starting balance for all players
* @param amount the amount to be set
*/
public void setStartBalance(int amount) { public void setStartBalance(int amount) {
for (Player player : players) { for (Player player : players) {
player.setAccountBalance(amount); player.setAccountBalance(amount);
} }
} }
/**
* Sets a player to have an extra turn
* @param player the player to have an extra turn
*/
public void extraTurn(Player player) { public void extraTurn(Player player) {
if (players.contains(player)) extra = player; if (players.contains(player)) extra = player;
} }

View File

@ -38,15 +38,26 @@ import pp.monopoly.model.fields.PropertyField;
* Manages game states, player interactions, and message handling. * Manages game states, player interactions, and message handling.
*/ */
public class ServerGameLogic implements ClientInterpreter { public class ServerGameLogic implements ClientInterpreter {
/**
* The logger for the ServerGameLogic class.
*/
private static final Logger LOGGER = System.getLogger(ServerGameLogic.class.getName()); private static final Logger LOGGER = System.getLogger(ServerGameLogic.class.getName());
/** The game configuration. */
private final MonopolyConfig config; private final MonopolyConfig config;
/** The player handler for managing players. */
private final PlayerHandler playerHandler = new PlayerHandler(this); private final PlayerHandler playerHandler = new PlayerHandler(this);
/** The sender used to send messages to clients. */
private final ServerSender serverSender; private final ServerSender serverSender;
/** The current state of the game. */
private ServerState state = ServerState.LOBBY; private ServerState state = ServerState.LOBBY;
/** The maximum number of players allowed in the game. */
private static final int MAX_PLAYERS = 6; private static final int MAX_PLAYERS = 6;
/** The board manager for managing the game board. */
private BoardManager boardManager = new BoardManager(); private BoardManager boardManager = new BoardManager();
/** The deck helper for managing card decks. */
private final DeckHelper deckHelper = new DeckHelper(); private final DeckHelper deckHelper = new DeckHelper();
/** The amount of money each player starts with. */
private int startMoney; private int startMoney;
/** /**
@ -383,10 +394,21 @@ public class ServerGameLogic implements ClientInterpreter {
return boardManager; return boardManager;
} }
/**
* Retrieves the player handler, which manages player actions and turns.
*
* @param id the id of the player to retrieve
* @return the PlayerHandler instance managing players
*/
public Player getPlayerById(int id) { public Player getPlayerById(int id) {
return playerHandler.getPlayerById(id); return playerHandler.getPlayerById(id);
} }
/**
* Retrieves the deck helper, which manages decks of cards.
*
* @return the deck helper
*/
public DeckHelper getDeckHelper() { public DeckHelper getDeckHelper() {
return deckHelper; return deckHelper;
} }
@ -452,6 +474,9 @@ public class ServerGameLogic implements ClientInterpreter {
updateAllPlayers(); updateAllPlayers();
} }
/**
* Generates a predefined game state for testing and demo purposes.
*/
private void generatePredefinedGameState() { private void generatePredefinedGameState() {
if(playerHandler.getPlayerCount() < 2) { if(playerHandler.getPlayerCount() < 2) {

View File

@ -4,14 +4,24 @@ import java.util.Set;
import com.jme3.network.serializing.Serializable; import com.jme3.network.serializing.Serializable;
/**
* Sent by the client to the server to alter the properties of a field.
*/
@Serializable @Serializable
public class AlterProperty extends ClientMessage{ public class AlterProperty extends ClientMessage{
/** The keyword to indicate what action should be performed */
private String keyword; private String keyword;
/** The properties that should be altered */
private Set<Integer> properties; private Set<Integer> properties;
/** No-Args Construcotr for serilization */
private AlterProperty() {} private AlterProperty() {}
/**
* Create a new AlterProperty message.
* @param keyword The keyword to indicate what action should be performed
*/
public AlterProperty(String keyword) { public AlterProperty(String keyword) {
this.keyword = keyword; this.keyword = keyword;
} }
@ -21,14 +31,26 @@ public class AlterProperty extends ClientMessage{
interpreter.received(this, from); interpreter.received(this, from);
} }
/**
* Returns the keyword to indicate what action should be performed.
* @return keyword The keyword to indicate what action should be performed
*/
public String getKeyword() { public String getKeyword() {
return keyword; return keyword;
} }
/**
* Sets the properties that should be altered.
* @param properties The properties that should be altered
*/
public void setProperties(Set<Integer> properties) { public void setProperties(Set<Integer> properties) {
this.properties = properties; this.properties = properties;
} }
/**
* Returns the properties that should be altered.
* @return properties The properties that should be altered
*/
public Set<Integer> getProperties() { public Set<Integer> getProperties() {
return properties; return properties;
} }

View File

@ -2,17 +2,30 @@ package pp.monopoly.message.client;
import com.jme3.network.serializing.Serializable; import com.jme3.network.serializing.Serializable;
/**
* Sent by the client to answer a notification.
*/
@Serializable @Serializable
public class NotificationAnswer extends ClientMessage{ public class NotificationAnswer extends ClientMessage{
/** The keyword to indicate the awnser */
private String keyword; private String keyword;
/** No-Args constructor for serilization */
private NotificationAnswer() {} private NotificationAnswer() {}
/**
* Create a new NotificationAnswer
* @param keyword the keyword to indicate the awnser
*/
public NotificationAnswer(String keyword) { public NotificationAnswer(String keyword) {
this.keyword = keyword; this.keyword = keyword;
} }
/**
* Get the keyword to indicate the awnser
* @return the keyword to indicate the awnser
*/
public String getKeyword() { public String getKeyword() {
return keyword; return keyword;
} }

View File

@ -31,18 +31,34 @@ public class PlayerReady extends ClientMessage {
this.startMoney = startMoney; this.startMoney = startMoney;
} }
/**
* Returns the name of the player.
* @return the name of the player
*/
public String getName() { public String getName() {
return name; return name;
} }
/**
* Returns the figure of the player.
* @return the figure of the player
*/
public String getFigure() { public String getFigure() {
return figure; return figure;
} }
/**
* Returns whether the player is ready.
* @return whether the player is ready
*/
public boolean isReady() { public boolean isReady() {
return isReady; return isReady;
} }
/**
* Returns the initial capital of the game.
* @return the initial capital of the game
*/
public int getStartMoney() { public int getStartMoney() {
return startMoney; return startMoney;
} }

View File

@ -25,6 +25,11 @@ public class TradeOffer extends ClientMessage{
this.tradehandler = tradehandler; this.tradehandler = tradehandler;
} }
/**
* Returns the tradehandler.
*
* @return the tradehandler
*/
public TradeHandler getTradeHandler() { return tradehandler; } public TradeHandler getTradeHandler() { return tradehandler; }
@Override @Override

View File

@ -8,8 +8,10 @@ import com.jme3.network.serializing.Serializable;
@Serializable @Serializable
public class ViewAssetsRequest extends ClientMessage{ public class ViewAssetsRequest extends ClientMessage{
public ViewAssetsRequest() { /**
} * Constructor needed for the serialization.
*/
public ViewAssetsRequest() {}
@Override @Override
public void accept(ClientInterpreter interpreter, int from) { public void accept(ClientInterpreter interpreter, int from) {

View File

@ -2,26 +2,44 @@ package pp.monopoly.message.server;
import com.jme3.network.serializing.Serializable; import com.jme3.network.serializing.Serializable;
/**
* Sent from server to client to inform about a build action.
*/
@Serializable @Serializable
public class BuildInfo extends ServerMessage { public class BuildInfo extends ServerMessage {
/** Id of the field that was altered */
private final int id; private final int id;
/** True if a house/hotel was added, false if it was removed */
private final boolean added; private final boolean added;
/** No-args constructor required for serialization */
private BuildInfo() { private BuildInfo() {
this(0, false); this(0, false);
} }
/**
* Create a new BuildInfo message.
* @param id Id of the field that was altered
* @param added True if a house/hotel was added, false if it was removed
*/
public BuildInfo(int id, boolean added) { public BuildInfo(int id, boolean added) {
this.id = id; this.id = id;
this.added = added; this.added = added;
} }
/**
* Get the id of the field that was altered.
* @return Id of the field that was altered
*/
public int getId() { public int getId() {
return id; return id;
} }
/**
* Check if a house/hotel was added.
* @return True if a house/hotel was added, false if it was removed
*/
public boolean isAdded() { public boolean isAdded() {
return added; return added;
} }

View File

@ -2,6 +2,9 @@ package pp.monopoly.message.server;
import com.jme3.network.serializing.Serializable; import com.jme3.network.serializing.Serializable;
/**
* Sent by the server to the client to request the client to show a buy property popup.
*/
@Serializable @Serializable
public class BuyPropertyRequest extends ServerMessage{ public class BuyPropertyRequest extends ServerMessage{

View File

@ -4,10 +4,15 @@ import java.util.List;
import com.jme3.network.serializing.Serializable; import com.jme3.network.serializing.Serializable;
/**
* Sent by the server to the client to inform the client about the result of a dice roll.
*/
@Serializable @Serializable
public class DiceResult extends ServerMessage{ public class DiceResult extends ServerMessage{
/** The first value of the DiceRoll */
private final int a; private final int a;
/** The second value of the DiceRoll */
private final int b; private final int b;
/** /**
@ -18,11 +23,20 @@ public class DiceResult extends ServerMessage{
b = 1; b = 1;
} }
/**
* Creates a new DiceResult with the given values.
* @param a The first value of the DiceRoll
* @param b The second value of the DiceRoll
*/
public DiceResult(int a, int b) { public DiceResult(int a, int b) {
this.a = a; this.a = a;
this.b = b; this.b = b;
} }
/**
* Returns the values of the DiceRoll.
* @return The values of the DiceRoll
*/
public List<Integer> getRollResult() { public List<Integer> getRollResult() {
return List.of(a,b); return List.of(a,b);
} }
@ -32,10 +46,18 @@ public class DiceResult extends ServerMessage{
interpreter.received(this); interpreter.received(this);
} }
/**
* Returns whether the DiceRoll is a doublets.
* @return Whether the DiceRoll is a doublets
*/
public boolean isDoublets() { public boolean isDoublets() {
return a == b; return a == b;
} }
/**
* Returns the total value of the DiceRoll.
* @return The total value of the DiceRoll
*/
public int calcTotal() { public int calcTotal() {
return a+b; return a+b;
} }

View File

@ -2,8 +2,14 @@ package pp.monopoly.message.server;
import com.jme3.network.serializing.Serializable; import com.jme3.network.serializing.Serializable;
/**
* Message to inform the player that the game is over and if he won or not.
*/
@Serializable @Serializable
public class GameOver extends ServerMessage{ public class GameOver extends ServerMessage {
/**
* Whether the player is the winner.
*/
private boolean isWinner; private boolean isWinner;
/** /**
@ -11,10 +17,20 @@ public class GameOver extends ServerMessage{
*/ */
private GameOver() { /* empty */ } private GameOver() { /* empty */ }
/**
* Creates a new GameOver message.
*
* @param isWinner true if the player is the winner, false otherwise
*/
public GameOver(boolean isWinner) { public GameOver(boolean isWinner) {
this.isWinner = isWinner; this.isWinner = isWinner;
} }
/**
* Returns whether the player is the winner.
*
* @return true if the player is the winner, false otherwise
*/
public boolean isWinner() { public boolean isWinner() {
return isWinner; return isWinner;
} }

View File

@ -7,6 +7,9 @@ import pp.monopoly.game.server.PlayerHandler;
@Serializable @Serializable
public class GameStart extends ServerMessage{ public class GameStart extends ServerMessage{
/**
* The PlayerHandler. This is the object that contains all the players and their information.
*/
private PlayerHandler playerHandler; private PlayerHandler playerHandler;
/** /**
@ -14,10 +17,20 @@ public class GameStart extends ServerMessage{
*/ */
private GameStart() { /* empty */ } private GameStart() { /* empty */ }
/**
* Creates a new GameStart message.
*
* @param playerHandler the playerHandler
*/
public GameStart(PlayerHandler playerHandler) { public GameStart(PlayerHandler playerHandler) {
this.playerHandler = playerHandler; this.playerHandler = playerHandler;
} }
/**
* Returns the PlayerHandler. This is the object that contains all the players and their information.
*
* @return the playerHandler
*/
public PlayerHandler getPlayerHandler() { public PlayerHandler getPlayerHandler() {
return playerHandler; return playerHandler;
} }

View File

@ -2,9 +2,13 @@ package pp.monopoly.message.server;
import com.jme3.network.serializing.Serializable; import com.jme3.network.serializing.Serializable;
/**
* Message for the client to inform him that a player is going to jail or leaving jail.
*/
@Serializable @Serializable
public class JailEvent extends ServerMessage{ public class JailEvent extends ServerMessage{
/** true if the player is going to jail, false if he is leaving jail */
private boolean goingToJail; private boolean goingToJail;
/** /**
@ -12,10 +16,20 @@ public class JailEvent extends ServerMessage{
*/ */
private JailEvent() { /* empty */ } private JailEvent() { /* empty */ }
/**
* Creates a new JailEvent.
*
* @param goingToJail true if the player is going to jail, false if he is leaving jail
*/
public JailEvent(boolean goingToJail) { public JailEvent(boolean goingToJail) {
this.goingToJail = goingToJail; this.goingToJail = goingToJail;
} }
/**
* Returns true if the player is going to jail, false if he is leaving jail.
*
* @return true if the player is going to jail, false if he is leaving jail
*/
public boolean isGoingToJail() { public boolean isGoingToJail() {
return goingToJail; return goingToJail;
} }

View File

@ -2,14 +2,17 @@ package pp.monopoly.message.server;
import com.jme3.network.serializing.Serializable; import com.jme3.network.serializing.Serializable;
/**
* Message to inform the clients that the next player's turn has started.
* The client should now enable the buttons for the current player.
*/
@Serializable @Serializable
public class NextPlayerTurn extends ServerMessage{ public class NextPlayerTurn extends ServerMessage{
/** /**
* Default constructor for serialization purposes. * Default constructor for serialization purposes.
*/ */
public NextPlayerTurn() { public NextPlayerTurn() {}
}
@Override @Override
public void accept(ServerInterpreter interpreter) { public void accept(ServerInterpreter interpreter) {

View File

@ -2,36 +2,68 @@ package pp.monopoly.message.server;
import com.jme3.network.serializing.Serializable; import com.jme3.network.serializing.Serializable;
/**
* This class is used to send notifications to the client. The keyWord is used to identify the type of notification.
* The rentAmount is used to store the amount of rent that has to be paid and the rentOwner is used to store the id of the player that has to be paid.
*/
@Serializable @Serializable
public class NotificationMessage extends ServerMessage{ public class NotificationMessage extends ServerMessage{
/** keyWord is used to identify the type of notification */
private final String keyWord; private final String keyWord;
/** rentAmount is used to store the amount of rent that has to be paid */
private int rentAmount; private int rentAmount;
/** rentOwner is used to store the id of the player that has to be paid */
private String rentOwner; private String rentOwner;
/** Default constructor needed for serializiaton */
private NotificationMessage(){ keyWord = null;} private NotificationMessage(){ keyWord = null;}
/**
* Constructor for the NotificationMessage
* @param keyWord the keyWord that is used to identify the type of notification
*/
public NotificationMessage(String keyWord) { public NotificationMessage(String keyWord) {
this.keyWord = keyWord; this.keyWord = keyWord;
} }
/**
* Getter for the rentAmount
* @return the amount of rent that has to be paid
*/
public int getRentAmount() { public int getRentAmount() {
return rentAmount; return rentAmount;
} }
/**
* Setter for the rentAmount
* @param rentAmount the amount of rent that has to be paid
*/
public void setRentAmount(int rentAmount) { public void setRentAmount(int rentAmount) {
this.rentAmount = rentAmount; this.rentAmount = rentAmount;
} }
/**
* Setter for the rentOwnerId
* @param rentOwnerId the id of the player that has to be paid
*/
public void setRentOwnerId(String rentOwnerId) { public void setRentOwnerId(String rentOwnerId) {
this.rentOwner = rentOwnerId; this.rentOwner = rentOwnerId;
} }
/**
* Getter for the rentOwnerId
* @return the id of the player that has to be paid
*/
public String getRentOwner() { public String getRentOwner() {
return rentOwner; return rentOwner;
} }
/**
* Getter for the keyWord
* @return the keyWord that is used to identify the type of notification
*/
public String getKeyWord() { public String getKeyWord() {
return keyWord; return keyWord;
} }

View File

@ -4,6 +4,9 @@ import com.jme3.network.serializing.Serializable;
import pp.monopoly.game.server.PlayerHandler; import pp.monopoly.game.server.PlayerHandler;
/**
* Message for updating the status of a player.
*/
@Serializable @Serializable
public class PlayerStatusUpdate extends ServerMessage{ public class PlayerStatusUpdate extends ServerMessage{
@ -14,10 +17,20 @@ public class PlayerStatusUpdate extends ServerMessage{
*/ */
private PlayerStatusUpdate() { /* empty */ } private PlayerStatusUpdate() { /* empty */ }
/**
* Creates a new PlayerStatusUpdate.
*
* @param playerHandler the playerHandler
*/
public PlayerStatusUpdate(PlayerHandler playerHandler) { public PlayerStatusUpdate(PlayerHandler playerHandler) {
this.playerHandler = playerHandler; this.playerHandler = playerHandler;
} }
/**
* Returns the playerHandler.
*
* @return the playerHandler
*/
public PlayerHandler getPlayerHandler() { public PlayerHandler getPlayerHandler() {
return playerHandler; return playerHandler;
} }

View File

@ -2,9 +2,15 @@ package pp.monopoly.message.server;
import com.jme3.network.serializing.Serializable; import com.jme3.network.serializing.Serializable;
/**
* Send to the client to inform the player that he has only a certain amount of time left to make his move.
*/
@Serializable @Serializable
public class TimeOutWarning extends ServerMessage{ public class TimeOutWarning extends ServerMessage{
/**
* Remaining time in seconds.
*/
private int remainingTime; private int remainingTime;
/** /**
@ -12,10 +18,18 @@ public class TimeOutWarning extends ServerMessage{
*/ */
private TimeOutWarning() { /* empty */ } private TimeOutWarning() { /* empty */ }
/**
* Create a new TimeOutWarning message.
* @param remainingTime Remaining time in seconds.
*/
public TimeOutWarning(int remainingTime) { public TimeOutWarning(int remainingTime) {
this.remainingTime = remainingTime; this.remainingTime = remainingTime;
} }
/**
* Get the remaining time in seconds.
* @return Remaining time in seconds.
*/
public int getRemainingTime() { public int getRemainingTime() {
return remainingTime; return remainingTime;
} }

View File

@ -28,7 +28,18 @@ public class TradeReply extends ServerMessage{
this.tradeHandler = tradeHandler; this.tradeHandler = tradeHandler;
} }
/**
* Returns whether the trade was accepted.
*
* @return true if the trade was accepted, false otherwise
*/
public boolean isAccepted() { return status; } public boolean isAccepted() { return status; }
/**
* Returns the TradeHandler corresponding to the trade.
*
* @return the TradeHandler corresponding to the trade
*/
public TradeHandler getTradeHandler() { public TradeHandler getTradeHandler() {
return tradeHandler; return tradeHandler;
} }

View File

@ -26,6 +26,11 @@ public class TradeRequest extends ServerMessage{
this.tradehandler = tradehandler; this.tradehandler = tradehandler;
} }
/**
* Returns the tradehandler.
*
* @return the tradehandler
*/
public TradeHandler getTradeHandler() { return tradehandler; } public TradeHandler getTradeHandler() { return tradehandler; }

View File

@ -32,6 +32,11 @@ public class ViewAssetsResponse extends ServerMessage{
interpreter.received(this); interpreter.received(this);
} }
/**
* Returns the BoardManager representing the current Status
*
* @return the BoardManager representing the current Status
*/
public BoardManager getboard() { public BoardManager getboard() {
return board; return board;
} }

View File

@ -11,51 +11,52 @@ import pp.monopoly.notification.ItemAddedEvent;
import pp.monopoly.notification.ItemRemovedEvent; import pp.monopoly.notification.ItemRemovedEvent;
/** /**
* Represents a rectangular map that holds figures and registers houses, hotels * Represents a rectangular board that holds figures and registers houses, hotels
* It also supports event notification for game state changes such as item addition or removal. * It also supports event notification for game state changes such as item addition or removal.
* Valid positions on this map have x-coordinates in the range of 0 to width-1 and y-coordinates
* in the range of 0 to height-1.
*
* @see #getWidth()
* @see #getHeight()
*/ */
public class Board { public class Board {
/** /**
* A list of items (figure, house, etc.) placed on the map. * A list of items (figure, house, etc.) placed on the board.
*/ */
private final List<Item> items = new ArrayList<>(); private final List<Item> items = new ArrayList<>();
/** /**
* The broker responsible for notifying registered listeners of events * The broker responsible for notifying registered listeners of events
* (such as when an item is added or removed from the map). * (such as when an item is added or removed from the board).
* Can be null, in which case no notifications will be sent. * Can be null, in which case no notifications will be sent.
*/ */
private final GameEventBroker eventBroker; private final GameEventBroker eventBroker;
/**
* The width (number of columns) of the board.
*/
private final int width; private final int width;
/**
* The height (number of rows) of the board.
*/
private final int height; private final int height;
/** /**
* Constructs an empty map with the given dimensions. The specified event broker * Constructs an empty board with the given dimensions. The specified event broker
* will handle the notification of changes in the map state, such as adding or removing items. * will handle the notification of changes in the board state, such as adding or removing items.
* Passing null as the event broker is allowed, but in that case, no notifications will occur. * Passing null as the event broker is allowed, but in that case, no notifications will occur.
* *
* @param width the number of columns (width) of the map * @param width the number of columns (width) of the board
* @param height the number of rows (height) of the map * @param height the number of rows (height) of the board
* @param eventBroker the event broker used for notifying listeners, or null if event distribution is not needed * @param eventBroker the event broker used for notifying listeners, or null if event distribution is not needed
*/ */
public Board(int width, int height, GameEventBroker eventBroker) { public Board(int width, int height, GameEventBroker eventBroker) {
if (width < 1 || height < 1) if (width < 1 || height < 1)
throw new IllegalArgumentException("Invalid map size"); throw new IllegalArgumentException("Invalid board size");
this.width = width; this.width = width;
this.height = height; this.height = height;
this.eventBroker = eventBroker; this.eventBroker = eventBroker;
} }
/** /**
* Adds an item (e.g., a figure or a house) to the map and triggers the appropriate event. * Adds an item (e.g., a figure or a house) to the board and triggers the appropriate event.
* *
* @param item the item to be added to the map * @param item the item to be added to the board
*/ */
private void addItem(Item item) { private void addItem(Item item) {
items.add(item); items.add(item);
@ -63,36 +64,36 @@ public class Board {
} }
/** /**
* Adds a figure to the map and triggers an item addition event. * Adds a figure to the board and triggers an item addition event.
* *
* @param figure the figure to be added to the map * @param figure the figure to be added to the board
*/ */
public void add(Figure figure) { public void add(Figure figure) {
addItem(figure); addItem(figure);
} }
/** /**
* Adds a house to the map and triggers an item addition event. * Adds a house to the board and triggers an item addition event.
* *
* @param house the house to be added to the map * @param house the house to be added to the board
*/ */
public void add(House house) { public void add(House house) {
addItem(house); addItem(house);
} }
/** /**
* Adds a hotel to the map and triggers an item addition event. * Adds a hotel to the board and triggers an item addition event.
* *
* @param hotel the hotel to be added to the map * @param hotel the hotel to be added to the board
*/ */
public void add(Hotel hotel) { public void add(Hotel hotel) {
addItem(hotel); addItem(hotel);
} }
/** /**
* Removes an item from the map and triggers an item removal event. * Removes an item from the board and triggers an item removal event.
* *
* @param item the item to be removed from the map * @param item the item to be removed from the board
*/ */
public void remove(Item item) { public void remove(Item item) {
items.remove(item); items.remove(item);
@ -104,7 +105,7 @@ public class Board {
} }
/** /**
* Removes all items from the map and triggers corresponding removal events for each. * Removes all items from the board and triggers corresponding removal events for each.
*/ */
public void clear() { public void clear() {
new ArrayList<>(items).forEach(this::remove); new ArrayList<>(items).forEach(this::remove);
@ -122,46 +123,62 @@ public class Board {
} }
/** /**
* Returns a stream of all figures currently on the map. * Returns a stream of all figures currently on the board.
* *
* @return a stream of all figures on the map * @return a stream of all figures on the board
*/ */
public Stream<Figure> getFigures() { public Stream<Figure> getFigures() {
return getItems(Figure.class); return getItems(Figure.class);
} }
/** /**
* Returns a stream of all houses currently on the map. * Returns a stream of all houses currently on the board.
* *
* @return a stream of all houses on the map * @return a stream of all houses on the board
*/ */
public Stream<House> getHouses() { public Stream<House> getHouses() {
return getItems(House.class); return getItems(House.class);
} }
/**
* Returns the house on the specified field and stage.
* @param fieldId the id at which the house is located
* @param stage the stage of the house
* @return the house on the specified field and stage, or null if no such house exists
*/
public House getHouse(int fieldId, int stage) { public House getHouse(int fieldId, int stage) {
return getHouses().filter(house -> house.getFieldID() == fieldId && house.getStage() == stage).findFirst().orElse(null); return getHouses().filter(house -> house.getFieldID() == fieldId && house.getStage() == stage).findFirst().orElse(null);
} }
/**
* Returns the hotel on the specified field.
* @param fieldId the id at which the hotel is located
* @return the hotel on the specified field, or null if no such hotel exists
*/
public Hotel getHotel(int fieldId) { public Hotel getHotel(int fieldId) {
return getHotels().filter(hotel -> hotel.getFieldID() == fieldId).findFirst().orElse(null); return getHotels().filter(hotel -> hotel.getFieldID() == fieldId).findFirst().orElse(null);
} }
/**
* Returns the figure with the specified id.
* @param playerId the id of the figure
* @return the figure with the specified id, or null if no such figure exists
*/
public Figure getFigure(int playerId) { public Figure getFigure(int playerId) {
return getFigures().filter(figure -> figure.getId() == playerId).findFirst().orElse(null); return getFigures().filter(figure -> figure.getId() == playerId).findFirst().orElse(null);
} }
/** /**
* Returns a stream of all hotels currently on the map. * Returns a stream of all hotels currently on the board.
* *
* @return a stream of all hotels on the map * @return a stream of all hotels on the board
*/ */
public Stream<Hotel> getHotels() { public Stream<Hotel> getHotels() {
return getItems(Hotel.class); return getItems(Hotel.class);
} }
/** /**
* Returns an unmodifiable list of all items currently on the map. * Returns an unmodifiable list of all items currently on the board.
* *
* @return an unmodifiable list of all items * @return an unmodifiable list of all items
*/ */
@ -170,27 +187,27 @@ public class Board {
} }
/** /**
* Returns the width (number of columns) of the map. * Returns the width (number of columns) of the board.
* *
* @return the width of the map * @return the width of the board
*/ */
public int getWidth() { public int getWidth() {
return width; return width;
} }
/** /**
* Returns the height (number of rows) of the map. * Returns the height (number of rows) of the board.
* *
* @return the height of the map * @return the height of the board
*/ */
public int getHeight() { public int getHeight() {
return height; return height;
} }
/** /**
* Returns a string representation of the map. * Returns a string representation of the board.
* *
* @return a string representation of the map * @return a string representation of the board
*/ */
@Override @Override
public String toString() { public String toString() {

View File

@ -10,14 +10,71 @@ import pp.monopoly.model.fields.GulagField;
import pp.monopoly.model.fields.TestStreckeField; import pp.monopoly.model.fields.TestStreckeField;
import pp.monopoly.model.fields.WacheField; import pp.monopoly.model.fields.WacheField;
/**
* Interface for the visitor pattern for the fields.
* @param <T> The return type of the visit methods.
*/
public interface FieldVisitor<T> { public interface FieldVisitor<T> {
/**
* Visit method for the field.
* @param field The BuildingProperty to visit.
* @return The return value of the visit method.
*/
T visit(BuildingProperty field); T visit(BuildingProperty field);
/**
* Visit method for the field.
* @param field The FoodField to visit.
* @return The return value of the visit method.
*/
T visit(FoodField field); T visit(FoodField field);
/**
* Visit method for the field.
* @param field The GateField to visit.
* @return The return value of the visit method.
*/
T visit(GateField field); T visit(GateField field);
/**
* Visit method for the field.
* @param field The GulagField to visit.
* @return The return value of the visit method.
*/
T visit(GulagField field); T visit(GulagField field);
/**
* Visit method for the field.
* @param field The TestStreckeField to visit.
* @return The return value of the visit method.
*/
T visit(TestStreckeField field); T visit(TestStreckeField field);
/**
* Visit method for the field.
* @param field The EventField to visit.
* @return The return value of the visit method.
*/
T visit(EventField field); T visit(EventField field);
/**
* Visit method for the field.
* @param field The WacheField to visit.
* @return The return value of the visit method.
*/
T visit(WacheField field); T visit(WacheField field);
/**
* Visit method for the field.
* @param field The GoField to visit.
* @return The return value of the visit method.
*/
T visit(GoField field); T visit(GoField field);
/**
* Visit method for the field.
* @param field The FineField to visit.
* @return The return value of the visit method.
*/
T visit(FineField field); T visit(FineField field);
} }

View File

@ -5,13 +5,20 @@ import java.util.Random;
import com.jme3.math.Vector3f; import com.jme3.math.Vector3f;
import com.jme3.network.serializing.Serializable; import com.jme3.network.serializing.Serializable;
/**
* Represents a figure that can be moved on the game board. A figure has a position and a rotation.
*/
@Serializable @Serializable
public class Figure implements Item{ public class Figure implements Item{
/** The id of the figure, corresponging to the id of the player it represents */
private final int id; private final int id;
/** The type of the figure */
private final String type; private final String type;
/** The position of the Figure */
private Vector3f position; private Vector3f position;
private Rotation rot; // The rotation of the Figure /** The rotation of the Figure */
private Rotation rot;
/** /**
* Default constructor for serialization. Initializes a Figure with length 0, * Default constructor for serialization. Initializes a Figure with length 0,
@ -98,6 +105,12 @@ public class Figure implements Item{
moveTo(calculateFieldPosition(fieldId)); moveTo(calculateFieldPosition(fieldId));
} }
/**
* Calculates the position of a field on the board.
*
* @param fieldID the ID of the field
* @return the position of the field
*/
public Vector3f calculateFieldPosition(int fieldID) { public Vector3f calculateFieldPosition(int fieldID) {
float baseX = 0.0f; float baseX = 0.0f;
float baseZ = 0.0f; float baseZ = 0.0f;
@ -153,6 +166,11 @@ public class Figure implements Item{
return new Vector3f(baseX , 0, baseZ ); return new Vector3f(baseX , 0, baseZ );
} }
/**
* Returns the ID of the field the Figure is currently on.
*
* @return the ID of the current field
*/
public int getCurrentFieldID() { public int getCurrentFieldID() {
Vector3f pos = getPos(); Vector3f pos = getPos();
for (int fieldID = 0; fieldID < 40; fieldID++) { for (int fieldID = 0; fieldID < 40; fieldID++) {
@ -206,17 +224,15 @@ public class Figure implements Item{
return visitor.visit(this); return visitor.visit(this);
} }
/**
* Accepts a visitor that does not return a value. This method is part of the
* Visitor design pattern.
*
* @param visitor the visitor to accept
*/
@Override @Override
public void accept(VoidVisitor visitor) { public void accept(VoidVisitor visitor) {
visitor.visit(this); visitor.visit(this);
} }
/**
* Returns the type of the figure
* @return the type of the figure
*/
public String getType() { public String getType() {
return type; return type;
} }

View File

@ -15,15 +15,27 @@ import com.jme3.network.serializing.Serializable;
@Serializable @Serializable
public class TradeHandler { public class TradeHandler {
/** The player initialing the trade */
private final Player sender; private final Player sender;
/** The player receiving the trade offer */
private Player receiver; private Player receiver;
/** The amount of money offered by the sender */
private int offeredAmount; private int offeredAmount;
/** The properties offered by the sender */
private Set<PropertyField> offeredProperties = new HashSet<>(); private Set<PropertyField> offeredProperties = new HashSet<>();
/** The jail cards offered by the sender */
private int offeredJailCards; private int offeredJailCards;
/** The amount of money requested from the receiver */
private int requestedAmount; private int requestedAmount;
/** The properties requested from the receiver */
private Set<PropertyField> requestedProperties = new HashSet<>(); private Set<PropertyField> requestedProperties = new HashSet<>();
/** The jail cards requested from the receiver */
private int requestedJailCards; private int requestedJailCards;
/**
* Constructs a TradeHandler with no trade details.
* Used for serialization.
*/
private TradeHandler() { private TradeHandler() {
sender = null; sender = null;
} }
@ -52,7 +64,7 @@ public class TradeHandler {
this.requestedJailCards = requestedJailCards; this.requestedJailCards = requestedJailCards;
} }
/** /**
* Constructs a TradeHandler for a single trade instance. * Constructs a TradeHandler for a single trade instance.
* *
* @param sender the Player initiating the trade * @param sender the Player initiating the trade
@ -61,62 +73,122 @@ public class TradeHandler {
this.sender = sender; this.sender = sender;
} }
/**
* Returns the offered amount of money.
* @return the offered amount of money
*/
public int getOfferedAmount() { public int getOfferedAmount() {
return offeredAmount; return offeredAmount;
} }
/**
* Returns the offered amount of jail cards.
* @return the offered amount of jail cards
*/
public int getOfferedJailCards() { public int getOfferedJailCards() {
return offeredJailCards; return offeredJailCards;
} }
/**
* Returns the offered properties.
* @return the offered properties
*/
public Set<PropertyField> getOfferedProperties() { public Set<PropertyField> getOfferedProperties() {
return offeredProperties; return offeredProperties;
} }
/**
* Returns the receiving player.
* @return the receiving player
*/
public Player getReceiver() { public Player getReceiver() {
return receiver; return receiver;
} }
/**
* Returns the requested amount of money.
* @return the requested amount of money
*/
public int getRequestedAmount() { public int getRequestedAmount() {
return requestedAmount; return requestedAmount;
} }
/**
* Returns the requested amount of jail cards.
* @return the requested amount of jail cards
*/
public int getRequestedJailCards() { public int getRequestedJailCards() {
return requestedJailCards; return requestedJailCards;
} }
/**
* Returns the requested properties.
* @return the requested properties
*/
public Set<PropertyField> getRequestedProperties() { public Set<PropertyField> getRequestedProperties() {
return requestedProperties; return requestedProperties;
} }
/**
* Returns the sending player.
* @return the sending player
*/
public Player getSender() { public Player getSender() {
return sender; return sender;
} }
/**
* Sets the offered amount of money.
* @param offeredAmount the offered amount of money
*/
public void setOfferedAmount(int offeredAmount) { public void setOfferedAmount(int offeredAmount) {
this.offeredAmount = offeredAmount; this.offeredAmount = offeredAmount;
} }
/**
* Sets the offered amount of jail cards.
* @param offeredJailCards the offered amount of jail cards
*/
public void setOfferedJailCards(int offeredJailCards) { public void setOfferedJailCards(int offeredJailCards) {
this.offeredJailCards = offeredJailCards; this.offeredJailCards = offeredJailCards;
} }
/**
* Sets the offered properties.
* @param offeredProperties the offered properties
*/
public void setOfferedProperties(Set<PropertyField> offeredProperties) { public void setOfferedProperties(Set<PropertyField> offeredProperties) {
this.offeredProperties = offeredProperties; this.offeredProperties = offeredProperties;
} }
/**
* Sets the receiving player.
* @param receiver the receiving player
*/
public void setReceiver(Player receiver) { public void setReceiver(Player receiver) {
this.receiver = receiver; this.receiver = receiver;
} }
/**
* Sets the requested amount of money.
* @param requestedAmount the requested amount of money
*/
public void setRequestedAmount(int requestedAmount) { public void setRequestedAmount(int requestedAmount) {
this.requestedAmount = requestedAmount; this.requestedAmount = requestedAmount;
} }
/**
* Sets the requested amount of jail cards.
* @param requestedJailCards the requested amount of jail cards
*/
public void setRequestedJailCards(int requestedJailCards) { public void setRequestedJailCards(int requestedJailCards) {
this.requestedJailCards = requestedJailCards; this.requestedJailCards = requestedJailCards;
} }
/**
* Sets the requested properties.
* @param requestedProperties the requested properties
*/
public void setRequestedProperties(Set<PropertyField> requestedProperties) { public void setRequestedProperties(Set<PropertyField> requestedProperties) {
this.requestedProperties = requestedProperties; this.requestedProperties = requestedProperties;
} }

View File

@ -2,23 +2,50 @@ package pp.monopoly.model.card;
import pp.monopoly.game.server.Player; import pp.monopoly.game.server.Player;
/**
* Represents a event card in the game.
*/
public class Card { public class Card {
/** Description of the card */
private final String description; private final String description;
/** Keyword of the card */
private final String keyword; private final String keyword;
/**
* Constructs a card with a description and a keyword.
*
* @param description the description of the card
* @param keyword the keyword of the card
*/
Card(String description, String keyword) { Card(String description, String keyword) {
this.description = description; this.description = description;
this.keyword = keyword; this.keyword = keyword;
} }
/**
* Accepts a visitor and calls the visit method of the visitor.
*
* @param visitor the visitor
* @param player the player
*/
public void accept(DeckHelper visitor, Player player) { public void accept(DeckHelper visitor, Player player) {
visitor.visit(this, player); visitor.visit(this, player);
} }
/**
* Returns the description of the card.
*
* @return the description of the card
*/
public String getDescription() { public String getDescription() {
return description; return description;
} // TODO wird gerade in der EventCard zur erstellung des Popup genutzt }
/**
* Returns the keyword of the card.
*
* @return the keyword of the card
*/
public String getKeyword() { public String getKeyword() {
return keyword; return keyword;
} }

View File

@ -10,11 +10,19 @@ import pp.monopoly.game.server.Player;
import pp.monopoly.message.client.EndTurn; import pp.monopoly.message.client.EndTurn;
import pp.monopoly.message.server.NotificationMessage; import pp.monopoly.message.server.NotificationMessage;
/**
* Helper class for the deck of cards.
*/
public class DeckHelper{ public class DeckHelper{
/** The deck of cards */
private Queue<Card> cards; private Queue<Card> cards;
/** The drawn cards */
private List<Card> drawn = new ArrayList<>(); private List<Card> drawn = new ArrayList<>();
/**
* Constructor for the deck helper.
*/
public DeckHelper() { public DeckHelper() {
cards = new LinkedList<Card>(); cards = new LinkedList<Card>();
cards.add(new Card("Du wurdest mit einem Dienst KFZ geblitzt. Zahle 800 EUR", "dienst-kfz-blitzer")); cards.add(new Card("Du wurdest mit einem Dienst KFZ geblitzt. Zahle 800 EUR", "dienst-kfz-blitzer"));
@ -53,6 +61,11 @@ public class DeckHelper{
shuffle(); shuffle();
} }
/**
* Triggers the specified method for each card action
* @param card the card to be triggered
* @param player the player triggering it
*/
public void visit(Card card, Player player) { public void visit(Card card, Player player) {
switch (card.getKeyword()) { switch (card.getKeyword()) {
case "dienst-kfz-blitzer": case "dienst-kfz-blitzer":
@ -320,6 +333,9 @@ public class DeckHelper{
} }
/**
* Shuffles the deck of cards.
*/
private void shuffle() { private void shuffle() {
List<Card> cardList = new ArrayList<>(cards); List<Card> cardList = new ArrayList<>(cards);
Collections.shuffle(cardList); Collections.shuffle(cardList);
@ -327,6 +343,10 @@ public class DeckHelper{
cards.addAll(cardList); cards.addAll(cardList);
} }
/**
* Draws a card from the deck.
* @return the drawn card
*/
public Card drawCard() { public Card drawCard() {
if (cards.isEmpty()) { if (cards.isEmpty()) {
drawn.forEach(cards::add); drawn.forEach(cards::add);

View File

@ -1,11 +1,12 @@
package pp.monopoly.notification; package pp.monopoly.notification;
/**
* Event that is sent when the buttons should be enabled or disabled.
*
* @param buttonsEnabled true if the buttons should be enabled, false if they should be disabled
*/
public record ButtonStatusEvent(boolean buttonsEnabled) implements GameEvent{ public record ButtonStatusEvent(boolean buttonsEnabled) implements GameEvent{
/**
* Notifies the game event listener of this event.
*
* @param listener the game event listener
*/
@Override @Override
public void notifyListener(GameEventListener listener) { public void notifyListener(GameEventListener listener) {
listener.receivedEvent(this); listener.receivedEvent(this);

View File

@ -1,5 +1,11 @@
package pp.monopoly.notification; package pp.monopoly.notification;
/**
* Event that is sent when the dice are rolled.
*
* @param a the first number of the dice roll
* @param b the second number of the dice roll
*/
public record DiceRollEvent(int a, int b) implements GameEvent{ public record DiceRollEvent(int a, int b) implements GameEvent{
@Override @Override

View File

@ -1,5 +1,10 @@
package pp.monopoly.notification; package pp.monopoly.notification;
/**
* EventCardEvent is a class that represents an event that is sent to the GameEventListener when a player draws an event card.
*
* @param description the description of the card that was drawn
*/
public record EventCardEvent(String description) implements GameEvent{ public record EventCardEvent(String description) implements GameEvent{
@Override @Override

View File

@ -13,11 +13,7 @@ package pp.monopoly.notification;
* @param key the bundle key for the message * @param key the bundle key for the message
*/ */
public record InfoTextEvent(String key) implements GameEvent { public record InfoTextEvent(String key) implements GameEvent {
/**
* Notifies the game event listener of this event.
*
* @param listener the game event listener
*/
@Override @Override
public void notifyListener(GameEventListener listener) { public void notifyListener(GameEventListener listener) {
listener.receivedEvent(this); listener.receivedEvent(this);

View File

@ -5,6 +5,9 @@ import pp.monopoly.model.Item;
/** /**
* Event that is triggered when an item is added to a board. * Event that is triggered when an item is added to a board.
*
* @param board the board to which the item was added
* @param item the item that was added
*/ */
public record ItemAddedEvent(Board board, Item item) implements GameEvent { public record ItemAddedEvent(Board board, Item item) implements GameEvent {

View File

@ -5,6 +5,9 @@ import pp.monopoly.model.Item;
/** /**
* Event that is triggered when an item is removed from a board. * Event that is triggered when an item is removed from a board.
*
* @param board the board from which the item was removed
* @param item the item that was removed
*/ */
public record ItemRemovedEvent(Board board, Item item) implements GameEvent { public record ItemRemovedEvent(Board board, Item item) implements GameEvent {

View File

@ -2,6 +2,12 @@ package pp.monopoly.notification;
import pp.monopoly.message.server.ServerMessage; import pp.monopoly.message.server.ServerMessage;
/**
* Event that is used to show a popup message to the user.
*
* @param msg a keyword to indicate the type of message
* @param message the message that should be shown
*/
public record PopUpEvent(String msg, ServerMessage message) implements GameEvent{ public record PopUpEvent(String msg, ServerMessage message) implements GameEvent{
@Override @Override

View File

@ -14,11 +14,6 @@ package pp.monopoly.notification;
*/ */
public record SoundEvent(Sound sound) implements GameEvent { public record SoundEvent(Sound sound) implements GameEvent {
/**
* Notifies the game event listener of this event.
*
* @param listener the game event listener
*/
@Override @Override
public void notifyListener(GameEventListener listener) { public void notifyListener(GameEventListener listener) {
listener.receivedEvent(this); listener.receivedEvent(this);

View File

@ -1,11 +1,10 @@
package pp.monopoly.notification; package pp.monopoly.notification;
/**
* This class is used to notify the view that the player's information has been updated.
*/
public record UpdatePlayerView() implements GameEvent{ public record UpdatePlayerView() implements GameEvent{
/**
* Notifies the game event listener of this event.
*
* @param listener the game event listener
*/
@Override @Override
public void notifyListener(GameEventListener listener) { public void notifyListener(GameEventListener listener) {
listener.receivedEvent(this); listener.receivedEvent(this);