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:
parent
c398c081ed
commit
1660736239
5 changed files with 36 additions and 70 deletions
|
@ -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;
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -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) {
|
||||||
|
|
|
@ -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);
|
|
||||||
}
|
}
|
|
@ -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
|
|
||||||
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -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());
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/** */
|
/** */
|
||||||
|
|
Reference in a new issue