Browse Source

refactoring: PropertyChangeSupport in Player

main
fdai7906 11 months ago
parent
commit
48b053a8f3
  1. 23
      src/main/java/de/hsfulda/onses/models/Player.java

23
src/main/java/de/hsfulda/onses/models/Player.java

@ -2,9 +2,13 @@ package de.hsfulda.onses.models;
import de.hsfulda.onses.services.PlayerService; import de.hsfulda.onses.services.PlayerService;
import java.beans.PropertyChangeSupport;
import java.util.ArrayList; import java.util.ArrayList;
public class Player { public class Player {
public final static String PROPERTY_PLAYER_DECK = "playerDeck";
protected PropertyChangeSupport listeners;
private PlayerService playerService; private PlayerService playerService;
private Game game; private Game game;
@ -15,11 +19,11 @@ public class Player {
} }
public void addCardToPlayerDeck(Card card) { public void addCardToPlayerDeck(Card card) {
final ArrayList<Card> oldplayerDeck = new ArrayList<>(this.playerDeck);
playerDeck.add(card); playerDeck.add(card);
this.firePropertyChange(PROPERTY_PLAYER_DECK, oldplayerDeck, playerDeck);
} }
public PlayerService getPlayerService() { public PlayerService getPlayerService() {
return playerService; return playerService;
} }
@ -37,4 +41,19 @@ public class Player {
this.game = game; this.game = game;
return this; return this;
} }
public PropertyChangeSupport listeners() {
if(this.listeners == null) {
this.listeners = new PropertyChangeSupport(this);
}
return this.listeners;
}
public boolean firePropertyChange(String propertyName, Object oldValue, Object newValue) {
if (this.listeners != null) {
this.listeners.firePropertyChange(propertyName, oldValue, newValue);
return true;
}
return false;
}
} }
Loading…
Cancel
Save