mirror of
https://athene2.informatik.unibw-muenchen.de/progproj/gruppen-ht24/Gruppe-02.git
synced 2025-08-03 12:37:42 +02:00
trade logic complete
This commit is contained in:
@@ -22,6 +22,7 @@ import pp.monopoly.message.server.TradeRequest;
|
||||
import pp.monopoly.message.server.ViewAssetsResponse;
|
||||
import pp.monopoly.model.Board;
|
||||
import pp.monopoly.model.IntPoint;
|
||||
import pp.monopoly.model.TradeHandler;
|
||||
import pp.monopoly.model.fields.BoardManager;
|
||||
import pp.monopoly.notification.ClientStateEvent;
|
||||
import pp.monopoly.notification.DiceRollEvent;
|
||||
@@ -61,6 +62,8 @@ public class ClientGameLogic implements ServerInterpreter, GameEventBroker {
|
||||
|
||||
private BoardManager boardManager = new BoardManager();
|
||||
|
||||
private TradeHandler tradeHandler;
|
||||
|
||||
|
||||
/**
|
||||
* Constructs a ClientGameLogic with the specified sender object.
|
||||
@@ -113,6 +116,10 @@ public class ClientGameLogic implements ServerInterpreter, GameEventBroker {
|
||||
return board;
|
||||
}
|
||||
|
||||
public TradeHandler getTradeHandler() {
|
||||
return tradeHandler;
|
||||
}
|
||||
|
||||
/**
|
||||
* Moves the preview figure to the specified position.
|
||||
*
|
||||
@@ -300,13 +307,11 @@ public class ClientGameLogic implements ServerInterpreter, GameEventBroker {
|
||||
*/
|
||||
@Override
|
||||
public void received(TradeReply msg) {
|
||||
// if (msg.getTradeHandler().getStatus()) {
|
||||
|
||||
// playSound(Sound.TRADE_ACCEPTED);
|
||||
// } else {
|
||||
|
||||
// playSound(Sound.TRADE_REJECTED);
|
||||
// }
|
||||
if (msg.isAccepted()) {
|
||||
playSound(Sound.TRADE_ACCEPTED);
|
||||
} else {
|
||||
playSound(Sound.TRADE_REJECTED);
|
||||
}
|
||||
}
|
||||
|
||||
/**
|
||||
@@ -316,7 +321,7 @@ public class ClientGameLogic implements ServerInterpreter, GameEventBroker {
|
||||
*/
|
||||
@Override
|
||||
public void received(TradeRequest msg) {
|
||||
System.out.println("Angebot angekommen");
|
||||
tradeHandler = msg.getTradeHandler();
|
||||
notifyListeners(new PopUpEvent("tradeRequest"));
|
||||
}
|
||||
|
||||
|
@@ -8,10 +8,10 @@
|
||||
package pp.monopoly.game.server;
|
||||
|
||||
import java.util.ArrayList;
|
||||
import java.util.HashSet;
|
||||
import java.util.List;
|
||||
import java.util.Random;
|
||||
|
||||
import javax.swing.JInternalFrame;
|
||||
import java.util.Set;
|
||||
|
||||
import com.jme3.network.serializing.Serializable;
|
||||
|
||||
@@ -43,7 +43,7 @@ public class Player implements FieldVisitor<Void>{
|
||||
private String name;
|
||||
private int accountBalance = 15000;
|
||||
private Figure figure;
|
||||
private List<Integer> properties = new ArrayList<>();
|
||||
private Set<Integer> properties = new HashSet<>();
|
||||
private int getOutOfJailCard;
|
||||
private int fieldID;
|
||||
private DiceResult rollResult;
|
||||
@@ -189,7 +189,7 @@ public class Player implements FieldVisitor<Void>{
|
||||
* @return List of all properties owned by this player
|
||||
*/
|
||||
public List<Integer> getProperties() {
|
||||
return properties;
|
||||
return new ArrayList<>(properties);
|
||||
}
|
||||
|
||||
/**
|
||||
@@ -578,8 +578,17 @@ DiceResult rollDice() {
|
||||
}
|
||||
|
||||
}
|
||||
|
||||
@Override
|
||||
public String toString() {
|
||||
return "Player{name=" + name + ", figure=" + figure + "}";
|
||||
}
|
||||
|
||||
public void addProperty(Integer id) {
|
||||
properties.add(id);
|
||||
}
|
||||
|
||||
public void removeProperty(Integer id) {
|
||||
properties.remove(id);
|
||||
}
|
||||
}
|
||||
|
@@ -2,6 +2,10 @@ package pp.monopoly.game.server;
|
||||
|
||||
import java.lang.System.Logger;
|
||||
import java.lang.System.Logger.Level;
|
||||
import java.util.HashSet;
|
||||
import java.util.List;
|
||||
import java.util.Properties;
|
||||
import java.util.Set;
|
||||
|
||||
import pp.monopoly.MonopolyConfig;
|
||||
import pp.monopoly.message.client.BuyPropertyResponse;
|
||||
@@ -21,6 +25,7 @@ import pp.monopoly.message.server.TradeRequest;
|
||||
import pp.monopoly.message.server.ViewAssetsResponse;
|
||||
import pp.monopoly.model.Figure;
|
||||
import pp.monopoly.model.Rotation;
|
||||
import pp.monopoly.model.TradeHandler;
|
||||
import pp.monopoly.model.card.DeckHelper;
|
||||
import pp.monopoly.model.fields.BoardManager;
|
||||
import pp.monopoly.model.fields.PropertyField;
|
||||
@@ -248,15 +253,76 @@ public class ServerGameLogic implements ClientInterpreter {
|
||||
*/
|
||||
@Override
|
||||
public void received(TradeResponse msg, int from) {
|
||||
Player responder = playerHandler.getPlayerById(from);
|
||||
Player initiator = playerHandler.getPlayerById(msg.getInitiatorId());
|
||||
|
||||
TradeHandler tradeHandler = msg.getTradeHandler();
|
||||
|
||||
Player receiver = playerHandler.getPlayerById(tradeHandler.getReceiver().getId());
|
||||
Player sender = playerHandler.getPlayerById(tradeHandler.getSender().getId());
|
||||
|
||||
Set<PropertyField> offered = new HashSet<>();
|
||||
|
||||
for (PropertyField propertyField : tradeHandler.getOfferedProperties()) {
|
||||
offered.add( (PropertyField) boardManager.getFieldAtIndex(propertyField.getId()));
|
||||
}
|
||||
|
||||
Set<PropertyField> requested = new HashSet<>();
|
||||
|
||||
for (PropertyField propertyField : tradeHandler.getRequestedProperties()) {
|
||||
requested.add( (PropertyField) boardManager.getFieldAtIndex(propertyField.getId()));
|
||||
}
|
||||
|
||||
executeTrade(sender, receiver, offered, requested);
|
||||
|
||||
sender.earnMoney(tradeHandler.getRequestedAmount());
|
||||
sender.pay(tradeHandler.getOfferedAmount());
|
||||
receiver.earnMoney(tradeHandler.getOfferedAmount());
|
||||
receiver.pay(tradeHandler.getRequestedAmount());
|
||||
|
||||
for (int i = 0; i < tradeHandler.getOfferedJailCards(); i++) {
|
||||
sender.removeJailCard();
|
||||
receiver.addJailCard();
|
||||
}
|
||||
|
||||
for (int i = 0; i < tradeHandler.getRequestedAmount(); i++) {
|
||||
sender.addJailCard();
|
||||
receiver.removeJailCard();
|
||||
}
|
||||
|
||||
updateAllPlayers();
|
||||
|
||||
if (responder != null && initiator != null) {
|
||||
LOGGER.log(Level.INFO, "Player {0} responded to trade with player {1}", responder.getName(), initiator.getName());
|
||||
send(initiator, new TradeReply(msg.getInitiatorId(), msg.getTradeHandler()));
|
||||
if (receiver != null && sender != null) {
|
||||
LOGGER.log(Level.INFO, "Player {0} responded to trade with player {1}", receiver.getName(), sender.getName());
|
||||
send(sender, new TradeReply(msg.isAccepted(), msg.getTradeHandler()));
|
||||
}
|
||||
}
|
||||
|
||||
/**
|
||||
* Executes the trade by transferring requested properties from the receiver
|
||||
* to the sender and offered properties from the sender to the receiver.
|
||||
*/
|
||||
public void executeTrade(Player sender, Player receiver, Set<PropertyField> requestedProperties, Set<PropertyField> offeredProperties) {
|
||||
// Transfer requested properties from receiver to sender
|
||||
for (PropertyField field : requestedProperties) {
|
||||
receiver.removeProperty(field.getId());
|
||||
sender.addProperty(field.getId());
|
||||
field.setOwner(sender); // Update ownership
|
||||
System.out.printf("Property %s transferred from %s to %s.\n",
|
||||
field.getName(), receiver.getName(), sender.getName());
|
||||
}
|
||||
|
||||
// Transfer offered properties from sender to receiver
|
||||
for (PropertyField field : offeredProperties) {
|
||||
sender.removeProperty(field.getId());
|
||||
receiver.addProperty(field.getId());
|
||||
field.setOwner(receiver); // Update ownership
|
||||
System.out.printf("Property %s transferred from %s to %s.\n",
|
||||
field.getName(), sender.getName(), receiver.getName());
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
|
||||
|
||||
/**
|
||||
* Handles a ViewAssetsRequest message, sending the player a response containing their assets.
|
||||
*
|
||||
|
@@ -9,7 +9,7 @@ import pp.monopoly.model.TradeHandler;
|
||||
*/
|
||||
@Serializable
|
||||
public class TradeResponse extends ClientMessage{
|
||||
private int initiatorId;
|
||||
private boolean status;
|
||||
private TradeHandler tradeHandler;
|
||||
|
||||
/**
|
||||
@@ -20,15 +20,15 @@ public class TradeResponse extends ClientMessage{
|
||||
/**
|
||||
* Constructs a TradeResponse with the specified response details.
|
||||
*
|
||||
* @param initiatorId the ID of the player who initiated the trade
|
||||
* @param status the ID of the player who initiated the trade
|
||||
* @param accepted true if the offer is accepted, false if declined
|
||||
*/
|
||||
public TradeResponse(int initiatorId, TradeHandler tradeHandler) {
|
||||
this.initiatorId = initiatorId;
|
||||
public TradeResponse(boolean status, TradeHandler tradeHandler) {
|
||||
this.status = status;
|
||||
this.tradeHandler = tradeHandler;
|
||||
}
|
||||
|
||||
public int getInitiatorId() { return initiatorId; }
|
||||
public boolean isAccepted() { return status; }
|
||||
public TradeHandler getTradeHandler() {
|
||||
return tradeHandler;
|
||||
}
|
||||
|
@@ -9,7 +9,7 @@ import pp.monopoly.model.TradeHandler;
|
||||
*/
|
||||
@Serializable
|
||||
public class TradeReply extends ServerMessage{
|
||||
private int initiatorId;
|
||||
private boolean status;
|
||||
private TradeHandler tradeHandler;
|
||||
|
||||
/**
|
||||
@@ -20,15 +20,15 @@ public class TradeReply extends ServerMessage{
|
||||
/**
|
||||
* Constructs a TradeResponse with the specified response details.
|
||||
*
|
||||
* @param initiatorId the ID of the player who initiated the trade
|
||||
* @param status the ID of the player who initiated the trade
|
||||
* @param accepted true if the offer is accepted, false if declined
|
||||
*/
|
||||
public TradeReply(int initiatorId, TradeHandler tradeHandler) {
|
||||
this.initiatorId = initiatorId;
|
||||
public TradeReply(boolean status, TradeHandler tradeHandler) {
|
||||
this.status = status;
|
||||
this.tradeHandler = tradeHandler;
|
||||
}
|
||||
|
||||
public int getInitiatorId() { return initiatorId; }
|
||||
public boolean isAccepted() { return status; }
|
||||
public TradeHandler getTradeHandler() {
|
||||
return tradeHandler;
|
||||
}
|
||||
|
@@ -100,135 +100,6 @@ public class TradeHandler {
|
||||
return sender;
|
||||
}
|
||||
|
||||
/**
|
||||
* Initiates the trade and validates its terms.
|
||||
*
|
||||
* @return true if the trade is valid and can proceed, false otherwise
|
||||
*/
|
||||
public boolean initiateTrade() {
|
||||
if (!validateTrade()) {
|
||||
|
||||
return false;
|
||||
}
|
||||
|
||||
return true;
|
||||
}
|
||||
|
||||
/**
|
||||
* Completes the trade by transferring money, properties, and jail cards.
|
||||
*/
|
||||
public void acceptTrade() {
|
||||
// Transfer money
|
||||
sender.earnMoney(-offeredAmount);
|
||||
receiver.earnMoney(offeredAmount);
|
||||
|
||||
receiver.earnMoney(-requestedAmount);
|
||||
sender.earnMoney(requestedAmount);
|
||||
|
||||
// Transfer properties
|
||||
if (offeredProperties != null) {
|
||||
for (PropertyField property : offeredProperties) {
|
||||
transferProperty(sender, receiver, property);
|
||||
}
|
||||
}
|
||||
if (requestedProperties != null) {
|
||||
for (PropertyField property : requestedProperties) {
|
||||
transferProperty(receiver, sender, property);
|
||||
}
|
||||
}
|
||||
|
||||
// Transfer jail cards
|
||||
transferJailCards(sender, receiver, offeredJailCards);
|
||||
transferJailCards(receiver, sender, requestedJailCards);
|
||||
|
||||
|
||||
}
|
||||
|
||||
/**
|
||||
* Rejects the trade.
|
||||
*/
|
||||
public void rejectTrade() {
|
||||
|
||||
}
|
||||
|
||||
/**
|
||||
* Validates the trade offer by checking ownership, balances, and jail cards.
|
||||
*
|
||||
* @return true if the trade is valid, false otherwise
|
||||
*/
|
||||
private boolean validateTrade() {
|
||||
// Validate sender's ability to offer money
|
||||
if (sender.getAccountBalance() < offeredAmount) {
|
||||
|
||||
return false;
|
||||
}
|
||||
|
||||
// Validate receiver's ability to fulfill the requested amount
|
||||
if (receiver.getAccountBalance() < requestedAmount) {
|
||||
|
||||
return false;
|
||||
}
|
||||
|
||||
// Validate property ownership
|
||||
if (offeredProperties != null) {
|
||||
for (PropertyField property : offeredProperties) {
|
||||
if (!sender.getProperties().contains(property)) {
|
||||
|
||||
return false;
|
||||
}
|
||||
}
|
||||
}
|
||||
if (requestedProperties != null) {
|
||||
for (PropertyField property : requestedProperties) {
|
||||
if (!receiver.getProperties().contains(property)) {
|
||||
|
||||
return false;
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
// Validate jail cards
|
||||
if (sender.getNumJailCard() < offeredJailCards) {
|
||||
|
||||
return false;
|
||||
}
|
||||
if (receiver.getNumJailCard() < requestedJailCards) {
|
||||
|
||||
return false;
|
||||
}
|
||||
|
||||
return true;
|
||||
}
|
||||
|
||||
/**
|
||||
* Transfers a property between players.
|
||||
*
|
||||
* @param from the Player transferring the property
|
||||
* @param to the Player receiving the property
|
||||
* @param property the PropertyField being transferred
|
||||
*/
|
||||
private void transferProperty(Player from, Player to, PropertyField property) {
|
||||
from.sellProperty(property);
|
||||
to.buyProperty(property);
|
||||
property.setOwner(to);
|
||||
|
||||
}
|
||||
|
||||
/**
|
||||
* Transfers jail cards between players.
|
||||
*
|
||||
* @param from the Player transferring jail cards
|
||||
* @param to the Player receiving jail cards
|
||||
* @param numCards the number of jail cards to transfer
|
||||
*/
|
||||
private void transferJailCards(Player from, Player to, int numCards) {
|
||||
for (int i = 0; i < numCards; i++) {
|
||||
from.removeJailCard();
|
||||
to.addJailCard();
|
||||
}
|
||||
|
||||
}
|
||||
|
||||
public void setOfferedAmount(int offeredAmount) {
|
||||
this.offeredAmount = offeredAmount;
|
||||
}
|
||||
|
Reference in New Issue
Block a user