mirror of
https://athene2.informatik.unibw-muenchen.de/progproj/gruppen-ht24/Gruppe-02.git
synced 2025-01-19 02:36:14 +01:00
Anzeige Spielerfarbe + Figur Pos
This commit is contained in:
parent
cfce176c82
commit
cfae369fd3
@ -96,12 +96,17 @@ public class TestWorld implements GameEventListener{
|
|||||||
Player player = players.get(i);
|
Player player = players.get(i);
|
||||||
try {
|
try {
|
||||||
// Lade das 3D-Modell der Spielfigur
|
// Lade das 3D-Modell der Spielfigur
|
||||||
com.jme3.scene.Spatial model = app.getAssetManager().loadModel("Models/" + player.getFigure().getType() + ".j3O");
|
com.jme3.scene.Spatial model = app.getAssetManager().loadModel("Models/" + player.getFigure().getType() + "/" + player.getFigure().getType() + ".j3o");
|
||||||
model.setLocalScale(0.5f); // Skaliere das Modell
|
model.setLocalScale(0.5f); // Skaliere das Modell
|
||||||
model.setLocalTranslation(0, 0, -i * 2); // Positioniere die Figur auf dem Startfeld
|
|
||||||
|
// Positioniere die Figur unten rechts
|
||||||
|
float startX = 9.1f; // X-Koordinate für die Ecke unten rechts
|
||||||
|
float startZ = -9.1f; // Z-Koordinate für die Ecke unten rechts
|
||||||
|
float spacing = 0.4f; // Abstand zwischen den Figuren
|
||||||
|
model.setLocalTranslation(startX, 0, startZ - (i * spacing)); // Position anpassen
|
||||||
|
|
||||||
app.getRootNode().attachChild(model);
|
app.getRootNode().attachChild(model);
|
||||||
System.out.println("Figur für Spieler " + player.getId() + " hinzugefügt.");
|
System.out.println("Figur für Spieler " + player.getId() + " positioniert bei (" + startX + ", 0, " + (startZ - (i * spacing)) + ")");
|
||||||
} catch (Exception e) {
|
} catch (Exception e) {
|
||||||
System.err.println("Fehler beim Laden des Modells für Spieler " + player.getId() + ": " + e.getMessage());
|
System.err.println("Fehler beim Laden des Modells für Spieler " + player.getId() + ": " + e.getMessage());
|
||||||
}
|
}
|
||||||
|
@ -15,10 +15,15 @@ import com.simsilica.lemur.style.ElementId;
|
|||||||
import pp.dialog.Dialog;
|
import pp.dialog.Dialog;
|
||||||
import pp.monopoly.client.MonopolyApp;
|
import pp.monopoly.client.MonopolyApp;
|
||||||
import pp.monopoly.game.server.Player;
|
import pp.monopoly.game.server.Player;
|
||||||
|
import pp.monopoly.game.server.PlayerColor;
|
||||||
import pp.monopoly.game.server.PlayerHandler;
|
import pp.monopoly.game.server.PlayerHandler;
|
||||||
import pp.monopoly.message.client.EndTurn;
|
import pp.monopoly.message.client.EndTurn;
|
||||||
import pp.monopoly.message.client.RollDice;
|
import pp.monopoly.message.client.RollDice;
|
||||||
import pp.monopoly.notification.*;
|
import pp.monopoly.notification.ButtonStatusEvent;
|
||||||
|
import pp.monopoly.notification.DiceRollEvent;
|
||||||
|
import pp.monopoly.notification.GameEventListener;
|
||||||
|
import pp.monopoly.notification.Sound;
|
||||||
|
import pp.monopoly.notification.UpdatePlayerView;
|
||||||
|
|
||||||
public class Toolbar extends Dialog implements GameEventListener {
|
public class Toolbar extends Dialog implements GameEventListener {
|
||||||
|
|
||||||
@ -49,28 +54,53 @@ public class Toolbar extends Dialog implements GameEventListener {
|
|||||||
}
|
}
|
||||||
|
|
||||||
private Container createToolbarContainer() {
|
private Container createToolbarContainer() {
|
||||||
|
// Erstelle den Hauptcontainer
|
||||||
Container container = new Container(new SpringGridLayout(Axis.X, Axis.Y), "toolbar");
|
Container container = new Container(new SpringGridLayout(Axis.X, Axis.Y), "toolbar");
|
||||||
container.setLocalTranslation(0, 200, 0);
|
container.setLocalTranslation(0, 200, 0);
|
||||||
container.setPreferredSize(new Vector3f(app.getCamera().getWidth(), 200, 0));
|
container.setPreferredSize(new Vector3f(app.getCamera().getWidth(), 200, 0));
|
||||||
|
|
||||||
// Create account and overview containers
|
// Spielerfarbe abrufen
|
||||||
|
Player currentPlayer = playerHandler.getPlayerById(app.getId());
|
||||||
|
ColorRGBA playerColor = convertPlayerColor(currentPlayer.getColor());
|
||||||
|
|
||||||
|
// Füge einen farbigen Balken hinzu
|
||||||
|
Container playerColorBar = new Container();
|
||||||
|
playerColorBar.setPreferredSize(new Vector3f(app.getCamera().getWidth(), 40, 0)); // Höhe des Balkens auf 10 festlegen
|
||||||
|
playerColorBar.setBackground(new QuadBackgroundComponent(playerColor));
|
||||||
|
playerColorBar.setLocalTranslation(0, 200, 1); // Positioniere ihn an der oberen Kante der Toolbar
|
||||||
|
container.attachChild(playerColorBar);
|
||||||
|
|
||||||
|
// Übersicht und Konto
|
||||||
accountContainer = container.addChild(new Container());
|
accountContainer = container.addChild(new Container());
|
||||||
overviewContainer = container.addChild(new Container());
|
overviewContainer = container.addChild(new Container());
|
||||||
receivedEvent(new UpdatePlayerView());
|
receivedEvent(new UpdatePlayerView()); // Initiale Aktualisierung
|
||||||
|
|
||||||
// Dice section
|
// Würfel-Bereich
|
||||||
container.addChild(createDiceSection());
|
container.addChild(createDiceSection());
|
||||||
|
|
||||||
// Action menu
|
// Aktionsmenü
|
||||||
Container menuContainer = container.addChild(new Container());
|
Container menuContainer = container.addChild(new Container());
|
||||||
menuContainer.addChild(createTradeButton());
|
menuContainer.addChild(createTradeButton());
|
||||||
menuContainer.addChild(createPropertyMenuButton());
|
menuContainer.addChild(createPropertyMenuButton());
|
||||||
menuContainer.addChild(createEndTurnButton());
|
menuContainer.addChild(createEndTurnButton());
|
||||||
menuContainer.setBackground(createBackground());
|
menuContainer.setBackground(createBackground());
|
||||||
|
|
||||||
return container;
|
return container;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
private ColorRGBA convertPlayerColor(PlayerColor color) {
|
||||||
|
switch (color) {
|
||||||
|
case CYAN: return new ColorRGBA(0f, 1f, 1f, 1f); // Cyan
|
||||||
|
case YELLOW: return ColorRGBA.Yellow;
|
||||||
|
case RED: return ColorRGBA.Red;
|
||||||
|
case PINK: return new ColorRGBA(1f, 0.75f, 0.8f, 1f); // Pink
|
||||||
|
case GREEN: return ColorRGBA.Green;
|
||||||
|
case PURPLE: return new ColorRGBA(0.5f, 0f, 0.5f, 1f); // Purple
|
||||||
|
default: return ColorRGBA.Gray; // Fallback
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
private Container createDiceSection() {
|
private Container createDiceSection() {
|
||||||
Container diceContainer = new Container(new SpringGridLayout(Axis.X, Axis.Y));
|
Container diceContainer = new Container(new SpringGridLayout(Axis.X, Axis.Y));
|
||||||
diceContainer.addChild(createDiceDisplay());
|
diceContainer.addChild(createDiceDisplay());
|
||||||
@ -171,7 +201,7 @@ public class Toolbar extends Dialog implements GameEventListener {
|
|||||||
|
|
||||||
private void animateDice(long startTime) throws InterruptedException {
|
private void animateDice(long startTime) throws InterruptedException {
|
||||||
int[] currentFace = {1};
|
int[] currentFace = {1};
|
||||||
while (System.currentTimeMillis() - startTime < 2500) { // Animation duration
|
while (System.currentTimeMillis() - startTime < 2000) { // Animation duration
|
||||||
currentFace[0] = (currentFace[0] % 6) + 1;
|
currentFace[0] = (currentFace[0] % 6) + 1;
|
||||||
|
|
||||||
String rotatingImage1 = diceToString(currentFace[0]);
|
String rotatingImage1 = diceToString(currentFace[0]);
|
||||||
@ -238,10 +268,20 @@ public class Toolbar extends Dialog implements GameEventListener {
|
|||||||
overviewContainer.addChild(new Label("Übersicht", new ElementId("label-Bold")));
|
overviewContainer.addChild(new Label("Übersicht", new ElementId("label-Bold")));
|
||||||
for (Player player : playerHandler.getPlayers()) {
|
for (Player player : playerHandler.getPlayers()) {
|
||||||
if (player.getId() != app.getId()) {
|
if (player.getId() != app.getId()) {
|
||||||
overviewContainer.addChild(new Label(
|
// Spielerfarbe abrufen
|
||||||
player.getName() + ": " + player.getAccountBalance() + " EUR",
|
ColorRGBA playerColor = convertPlayerColor(player.getColor());
|
||||||
new ElementId("label-Text")
|
|
||||||
));
|
// Label für den Spieler erstellen
|
||||||
|
Label playerLabel = new Label(
|
||||||
|
player.getName() + ": " + player.getAccountBalance() + " EUR",
|
||||||
|
new ElementId("label-Text")
|
||||||
|
);
|
||||||
|
|
||||||
|
// Farbe setzen
|
||||||
|
playerLabel.setColor(playerColor);
|
||||||
|
|
||||||
|
// Label zum Container hinzufügen
|
||||||
|
overviewContainer.addChild(playerLabel);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
overviewContainer.setBackground(createBackground());
|
overviewContainer.setBackground(createBackground());
|
||||||
|
Loading…
Reference in New Issue
Block a user