Man kann jetzt die Anzahl der Steinsätze einstellen

git-svn-id: svn://sunsvr01.isp.uni-luebeck.de/swproj13/trunk@328 72836036-5685-4462-b002-a69064685172
This commit is contained in:
Ida Massow 2011-05-30 20:16:48 +02:00
parent c398c081ed
commit 1660736239
5 changed files with 36 additions and 70 deletions

View file

@ -35,8 +35,6 @@ public class MockSettingsPanel implements ISettingsPanel {
public boolean addPlayerButtonEnabled = true; public boolean addPlayerButtonEnabled = true;
/** */ /** */
public boolean removePlayerButtonsEnabled = false; public boolean removePlayerButtonsEnabled = false;
/** */
public GameSettings gameSettings = new GameSettings();
/** */ /** */
public MockEvent1<Integer> changeInitialMeldThresholdEvent = new MockEvent1<Integer>(); public MockEvent1<Integer> changeInitialMeldThresholdEvent = new MockEvent1<Integer>();
@ -107,13 +105,9 @@ public class MockSettingsPanel implements ISettingsPanel {
@Override @Override
public void setGameSettings(GameSettings gameSettings) { public void setGameSettings(GameSettings gameSettings) {
this.gameSettings = gameSettings; initialMeldThreshold = gameSettings.getInitialMeldThreshold();
jokerNumber = gameSettings.getJokerNumber();
} stoneSetNumber = gameSettings.getStoneSetNumber();
@Override
public void setInitialMeldThreshold(int value) {
initialMeldThreshold = value;
} }
@Override @Override
@ -121,11 +115,6 @@ public class MockSettingsPanel implements ISettingsPanel {
return changeJokerNumberEvent; return changeJokerNumberEvent;
} }
@Override
public void setJokerNumber(int jokerNumber) {
this.jokerNumber = jokerNumber;
}
@Override @Override
public IEvent2<Integer, Type> getChangePlayerTypeEvent() { public IEvent2<Integer, Type> getChangePlayerTypeEvent() {
return changePlayerTypeEvent; return changePlayerTypeEvent;
@ -136,9 +125,4 @@ public class MockSettingsPanel implements ISettingsPanel {
return changeStoneSetNumberEvent; return changeStoneSetNumberEvent;
} }
@Override
public void setStoneSetNumber(int number) {
stoneSetNumber = number;
}
} }

View file

@ -56,10 +56,6 @@ public class SettingsControl {
* Start the operation of the settings control * Start the operation of the settings control
*/ */
public void startSettings() { public void startSettings() {
view.getSettingsPanel().setInitialMeldThreshold(
settings.getInitialMeldThreshold());
view.getSettingsPanel().setJokerNumber(settings.getJokerNumber());
connections.add(view.getSettingsPanel() connections.add(view.getSettingsPanel()
.getChangeInitialMeldThresholdEvent() .getChangeInitialMeldThresholdEvent()
.add(new IListener1<Integer>() { .add(new IListener1<Integer>() {
@ -79,6 +75,15 @@ public class SettingsControl {
} }
})); }));
connections.add(view.getSettingsPanel().getChangeStoneSetNumberEvent()
.add(new IListener1<Integer>() {
@Override
public void handle(Integer value) {
settings.setStoneSetNumber(value);
update();
}
}));
addPlayerSettingsListeners(); addPlayerSettingsListeners();
view.showSettingsPanel(true); view.showSettingsPanel(true);
@ -237,7 +242,8 @@ public class SettingsControl {
int totalStonesDealt = settings.getNumberOfStonesDealt() int totalStonesDealt = settings.getNumberOfStonesDealt()
* settings.getPlayerList().size(); * settings.getPlayerList().size();
int totalStones = settings.getHighestCard() * settings.getStoneSetNumber() int totalStones = settings.getHighestCard()
* settings.getStoneSetNumber()
* settings.getStoneColors().size() + settings.getJokerNumber(); * settings.getStoneColors().size() + settings.getJokerNumber();
if (totalStones <= totalStonesDealt) { if (totalStones <= totalStonesDealt) {

View file

@ -131,6 +131,13 @@ public interface ISettingsPanel {
*/ */
public void setGameSettings(GameSettings gameSettings); public void setGameSettings(GameSettings gameSettings);
/**
* Emitted when the joker number is changed
*
* @return the event
*/
public IEvent1<Integer> getChangeJokerNumberEvent();
/** /**
* Specifies the different kinds of settings errors that can be displayed * Specifies the different kinds of settings errors that can be displayed
*/ */
@ -150,30 +157,4 @@ public interface ISettingsPanel {
/** Only computer players added */ /** Only computer players added */
COMPUTER_PLAYERS_ONLY_WARNING COMPUTER_PLAYERS_ONLY_WARNING
} }
/**
* Sets the initial meld threshold in the option pane
*
* @param value
* initial meld threshold
*/
public void setInitialMeldThreshold(int value);
public void setStoneSetNumber(int number);
/**
* Emitted when the joker number is changed
*
* @return the event
*/
public IEvent1<Integer> getChangeJokerNumberEvent();
/**
* Sets the joker number in the option pane
*
* @param jokerNumber
* the joker number
*/
public void setJokerNumber(int jokerNumber);
} }

View file

@ -65,6 +65,7 @@ class SettingsPanel extends JPanel implements ISettingsPanel {
private List<PlayerSettingsPanel> playerSettingsPanels = new ArrayList<PlayerSettingsPanel>(); private List<PlayerSettingsPanel> playerSettingsPanels = new ArrayList<PlayerSettingsPanel>();
private JSpinner initialMeldThresholdSpinner; private JSpinner initialMeldThresholdSpinner;
private JSpinner stoneSetNumberSpinner;
private JSpinner jokerNumberSpinner; private JSpinner jokerNumberSpinner;
private Event startGameEvent = new Event(); private Event startGameEvent = new Event();
@ -174,6 +175,11 @@ class SettingsPanel extends JPanel implements ISettingsPanel {
updatePlayerSettingsPanel(i, gameSettings.getPlayerList().get(i)); updatePlayerSettingsPanel(i, gameSettings.getPlayerList().get(i));
} }
initialMeldThresholdSpinner.setValue(gameSettings
.getInitialMeldThreshold());
stoneSetNumberSpinner.setValue(gameSettings.getStoneSetNumber());
jokerNumberSpinner.setValue(gameSettings.getJokerNumber());
playerSettingsViewport.revalidate(); playerSettingsViewport.revalidate();
} }
@ -241,13 +247,17 @@ class SettingsPanel extends JPanel implements ISettingsPanel {
initialMeldThresholdSpinner = makeOptionSpinner(0, 1, 999, 1, initialMeldThresholdSpinner = makeOptionSpinner(0, 1, 999, 1,
changeInitialMeldThresholdEvent); changeInitialMeldThresholdEvent);
makeOptionLabel(1, "Jokeranzahl:"); makeOptionLabel(1, "Anzahl Steins\u00e4tze:");
jokerNumberSpinner = makeOptionSpinner(1, 1, 999, 1, stoneSetNumberSpinner = makeOptionSpinner(1, 1, 999, 1,
changeStoneSetNumberEvent);
makeOptionLabel(2, "Jokeranzahl:");
jokerNumberSpinner = makeOptionSpinner(2, 1, 999, 1,
changeJokerNumberEvent); changeJokerNumberEvent);
GridBagConstraints c = new GridBagConstraints(); GridBagConstraints c = new GridBagConstraints();
c.gridx = 1; c.gridx = 1;
c.gridy = 2; c.gridy = 3;
c.fill = GridBagConstraints.BOTH; c.fill = GridBagConstraints.BOTH;
c.weightx = 1; c.weightx = 1;
c.weighty = 1; c.weighty = 1;
@ -502,29 +512,13 @@ class SettingsPanel extends JPanel implements ISettingsPanel {
} }
} }
@Override
public void setInitialMeldThreshold(int value) {
initialMeldThresholdSpinner.setValue(value);
}
@Override @Override
public IEvent1<Integer> getChangeJokerNumberEvent() { public IEvent1<Integer> getChangeJokerNumberEvent() {
return changeJokerNumberEvent; return changeJokerNumberEvent;
} }
@Override
public void setJokerNumber(int jokerNumber) {
jokerNumberSpinner.setValue(jokerNumber);
}
@Override @Override
public IEvent2<Integer, Type> getChangePlayerTypeEvent() { public IEvent2<Integer, Type> getChangePlayerTypeEvent() {
return changePlayerTypeEvent; return changePlayerTypeEvent;
} }
@Override
public void setStoneSetNumber(int number) {
// TODO Auto-generated method stub
}
} }

View file

@ -61,6 +61,7 @@ public class SettingsControlTest {
for (int i = 0; i < 14; i++) { for (int i = 0; i < 14; i++) {
view.settingsPanel.addPlayerEvent.emit(); view.settingsPanel.addPlayerEvent.emit();
} }
view.settingsPanel.changeStoneSetNumberEvent.emit(8);
view.settingsPanel.startGameEvent.emit(); view.settingsPanel.startGameEvent.emit();
assertNotNull(gameSettings); assertNotNull(gameSettings);
assertEquals(16, gameSettings.getPlayerList().size()); assertEquals(16, gameSettings.getPlayerList().size());
@ -75,6 +76,7 @@ public class SettingsControlTest {
view.settingsPanel.addPlayerEvent.emit(); view.settingsPanel.addPlayerEvent.emit();
} }
view.settingsPanel.removePlayerEvent.emit(0); view.settingsPanel.removePlayerEvent.emit(0);
view.settingsPanel.changeStoneSetNumberEvent.emit(8);
view.settingsPanel.startGameEvent.emit(); view.settingsPanel.startGameEvent.emit();
assertNotNull(gameSettings); assertNotNull(gameSettings);
assertEquals(15, gameSettings.getPlayerList().size()); assertEquals(15, gameSettings.getPlayerList().size());
@ -209,7 +211,6 @@ public class SettingsControlTest {
view.settingsPanel.changeStoneSetNumberEvent.emit(3); view.settingsPanel.changeStoneSetNumberEvent.emit(3);
view.settingsPanel.startGameEvent.emit(); view.settingsPanel.startGameEvent.emit();
assertEquals(3, gameSettings.getStoneSetNumber()); assertEquals(3, gameSettings.getStoneSetNumber());
} }
/** */ /** */