Neuer Button im WinPanel mit funktion

git-svn-id: svn://sunsvr01.isp.uni-luebeck.de/swproj13/trunk@309 72836036-5685-4462-b002-a69064685172
This commit is contained in:
Ida Massow 2011-05-29 20:19:17 +02:00
parent eb7ccb46c5
commit 794777c2fe
7 changed files with 159 additions and 69 deletions

View file

@ -39,6 +39,9 @@ public class MockView implements IView {
/** */ /** */
public MockEvent newRoundEvent = new MockEvent(); public MockEvent newRoundEvent = new MockEvent();
/** */
public MockEvent newGameEvent = new MockEvent();
@Override @Override
public MockTablePanel getTablePanel() { public MockTablePanel getTablePanel() {
return tablePanel; return tablePanel;
@ -80,7 +83,7 @@ public class MockView implements IView {
} }
@Override @Override
public IEvent getFinalScoreEvent() { public IEvent getEndProgramEvent() {
return quitEvent; return quitEvent;
} }
@ -123,4 +126,9 @@ public class MockView implements IView {
} }
@Override
public IEvent getNewGameEvent() {
return newGameEvent;
}
} }

View file

@ -1,6 +1,11 @@
package jrummikub.control; package jrummikub.control;
import java.util.ArrayList;
import java.util.List;
import jrummikub.model.GameSettings; import jrummikub.model.GameSettings;
import jrummikub.util.Connection;
import jrummikub.util.IListener;
import jrummikub.util.IListener1; import jrummikub.util.IListener1;
import jrummikub.view.IView; import jrummikub.view.IView;
@ -25,12 +30,21 @@ public class ApplicationControl {
* Starts the application by showing the game settings dialog panel * Starts the application by showing the game settings dialog panel
*/ */
public void startApplication() { public void startApplication() {
SettingsControl settingsControl = new SettingsControl(view, new GameSettings()); view.showScorePanel(false);
view.enableWinPanel(false);
SettingsControl settingsControl = new SettingsControl(view,
new GameSettings());
settingsControl.getStartGameEvent().add(new IListener1<GameSettings>() { settingsControl.getStartGameEvent().add(new IListener1<GameSettings>() {
@Override @Override
public void handle(GameSettings settings) { public void handle(GameSettings settings) {
GameControl gameControl = new GameControl(settings, view); GameControl gameControl = new GameControl(settings, view);
gameControl.getEndOfGameEvent().add(new IListener() {
@Override
public void handle() {
startApplication();
}
});
gameControl.startGame(); gameControl.startGame();
} }

View file

@ -9,6 +9,8 @@ import jrummikub.model.IRoundState;
import jrummikub.model.RoundState; import jrummikub.model.RoundState;
import jrummikub.model.Score; import jrummikub.model.Score;
import jrummikub.util.Connection; import jrummikub.util.Connection;
import jrummikub.util.Event;
import jrummikub.util.IEvent;
import jrummikub.util.IListener; import jrummikub.util.IListener;
import jrummikub.util.IListener1; import jrummikub.util.IListener1;
import jrummikub.view.IView; import jrummikub.view.IView;
@ -22,14 +24,15 @@ public class GameControl {
RoundControl roundControl; RoundControl roundControl;
private GameState gameState; private GameState gameState;
private List<Connection> connections = new ArrayList<Connection>(); private List<Connection> connections = new ArrayList<Connection>();
private Event endOfGameEvent = new Event();
/** /**
* Constructor * Constructor
* *
* @param gameSettings * @param gameSettings
* the game settings * the game settings
* @param view * @param view
* the view * the view
*/ */
public GameControl(GameSettings gameSettings, IView view) { public GameControl(GameSettings gameSettings, IView view) {
this.gameSettings = gameSettings; this.gameSettings = gameSettings;
@ -45,12 +48,31 @@ public class GameControl {
startRound(); startRound();
} }
})); }));
connections.add(view.getFinalScoreEvent().add(new IListener() {
connections.add(view.getNewGameEvent().add(new IListener() {
@Override @Override
public void handle() { public void handle() {
finalScore(); endGame();
} }
})); }));
connections.add(view.getEndProgramEvent().add(new IListener() {
@Override
public void handle() {
endProgram();
}
}));
}
public IEvent getEndOfGameEvent() {
return endOfGameEvent;
}
private void endGame() {
for (Connection c : connections) {
c.remove();
}
endOfGameEvent.emit();
} }
/** /**
@ -105,12 +127,13 @@ public class GameControl {
view.getScorePanel().setPlayers(gameSettings.getPlayerList()); view.getScorePanel().setPlayers(gameSettings.getPlayerList());
view.getScorePanel().setScores(gameState.getScores()); view.getScorePanel().setScores(gameState.getScores());
view.getScorePanel().setAccumulatedScore(gameState.getAccumulatedScore()); view.getScorePanel().setAccumulatedScore(
gameState.getAccumulatedScore());
view.getScorePanel().update(); view.getScorePanel().update();
view.showScorePanel(true); view.showScorePanel(true);
} }
private void finalScore() { private void endProgram() {
System.exit(0); System.exit(0);
} }

View file

@ -1,9 +1,12 @@
package jrummikub.control; package jrummikub.control;
import java.awt.Color; import java.awt.Color;
import java.util.ArrayList;
import java.util.List;
import jrummikub.model.GameSettings; import jrummikub.model.GameSettings;
import jrummikub.model.PlayerSettings; import jrummikub.model.PlayerSettings;
import jrummikub.util.Connection;
import jrummikub.util.Event1; import jrummikub.util.Event1;
import jrummikub.util.IEvent1; import jrummikub.util.IEvent1;
import jrummikub.util.IListener; import jrummikub.util.IListener;
@ -18,6 +21,7 @@ import jrummikub.view.IView;
public class SettingsControl { public class SettingsControl {
private IView view; private IView view;
private Event1<GameSettings> startGameEvent = new Event1<GameSettings>(); private Event1<GameSettings> startGameEvent = new Event1<GameSettings>();
private List<Connection> connections = new ArrayList<Connection>();
private GameSettings settings; private GameSettings settings;
@ -25,9 +29,9 @@ public class SettingsControl {
* Create a new settings control * Create a new settings control
* *
* @param view * @param view
* the view to use * the view to use
* @param settings * @param settings
* initial game settings * initial game settings
*/ */
public SettingsControl(IView view, GameSettings settings) { public SettingsControl(IView view, GameSettings settings) {
this.view = view; this.view = view;
@ -37,8 +41,8 @@ public class SettingsControl {
} }
/** /**
* the start game event is emitted when the user wants to start a game and the * the start game event is emitted when the user wants to start a game and
* settings made are valid * the settings made are valid
* *
* @return the event * @return the event
*/ */
@ -50,24 +54,28 @@ 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().setInitialMeldThreshold(
settings.getInitialMeldThreshold());
view.getSettingsPanel().setJokerNumber(settings.getJokerNumber()); view.getSettingsPanel().setJokerNumber(settings.getJokerNumber());
view.getSettingsPanel().getChangeInitialMeldThresholdEvent().add(new IListener1<Integer>() { connections.add(view.getSettingsPanel()
@Override .getChangeInitialMeldThresholdEvent()
public void handle(Integer value) { .add(new IListener1<Integer>() {
settings.setInitialMeldThreshold(value); @Override
update(); public void handle(Integer value) {
} settings.setInitialMeldThreshold(value);
}); update();
}
}));
view.getSettingsPanel().getChangeJokerNumberEvent().add(new IListener1<Integer>() { connections.add(view.getSettingsPanel().getChangeJokerNumberEvent()
@Override .add(new IListener1<Integer>() {
public void handle(Integer value) { @Override
settings.setJokerNumber(value); public void handle(Integer value) {
update(); settings.setJokerNumber(value);
} update();
}); }
}));
addPlayerSettingsListeners(); addPlayerSettingsListeners();
@ -75,39 +83,41 @@ public class SettingsControl {
} }
private void addPlayerSettingsListeners() { private void addPlayerSettingsListeners() {
view.getSettingsPanel().getStartGameEvent().add(new IListener() { connections.add(view.getSettingsPanel().getStartGameEvent()
@Override .add(new IListener() {
public void handle() { @Override
startGame(); public void handle() {
} startGame();
}); }
view.getSettingsPanel().getAddPlayerEvent().add(new IListener() { }));
@Override connections.add(view.getSettingsPanel().getAddPlayerEvent()
public void handle() { .add(new IListener() {
addPlayer(); @Override
} public void handle() {
}); addPlayer();
view.getSettingsPanel().getRemovePlayerEvent() }
}));
connections.add(view.getSettingsPanel().getRemovePlayerEvent()
.add(new IListener1<Integer>() { .add(new IListener1<Integer>() {
@Override @Override
public void handle(Integer i) { public void handle(Integer i) {
removePlayer(i); removePlayer(i);
} }
}); }));
view.getSettingsPanel().getChangePlayerColorEvent() connections.add(view.getSettingsPanel().getChangePlayerColorEvent()
.add(new IListener2<Integer, Color>() { .add(new IListener2<Integer, Color>() {
@Override @Override
public void handle(Integer i, Color color) { public void handle(Integer i, Color color) {
setPlayerColor(i, color); setPlayerColor(i, color);
} }
}); }));
view.getSettingsPanel().getChangePlayerNameEvent() connections.add(view.getSettingsPanel().getChangePlayerNameEvent()
.add(new IListener2<Integer, String>() { .add(new IListener2<Integer, String>() {
@Override @Override
public void handle(Integer i, String name) { public void handle(Integer i, String name) {
setPlayerName(i, name); setPlayerName(i, name);
} }
}); }));
} }
private void addPlayer() { private void addPlayer() {
@ -142,7 +152,8 @@ public class SettingsControl {
break; break;
} }
settings.getPlayerList().add(new PlayerSettings("Spieler " + num, color)); settings.getPlayerList().add(
new PlayerSettings("Spieler " + num, color));
update(); update();
} }
@ -178,8 +189,9 @@ public class SettingsControl {
private void update() { private void update() {
view.getSettingsPanel().enableRemovePlayerButtons( view.getSettingsPanel().enableRemovePlayerButtons(
settings.getPlayerList().size() > 2); settings.getPlayerList().size() > 2);
view.getSettingsPanel().enableAddPlayerButton( view.getSettingsPanel()
settings.getPlayerList().size() < ISettingsPanel.PLAYER_COLORS.length); .enableAddPlayerButton(
settings.getPlayerList().size() < ISettingsPanel.PLAYER_COLORS.length);
checkSettings(); checkSettings();
@ -220,6 +232,9 @@ public class SettingsControl {
view.showSettingsPanel(false); view.showSettingsPanel(false);
for (Connection c : connections) {
c.remove();
}
startGameEvent.emit(settings); startGameEvent.emit(settings);
} }
} }

View file

@ -87,7 +87,7 @@ public interface IView {
* *
* @return the event * @return the event
*/ */
public IEvent getFinalScoreEvent(); public IEvent getEndProgramEvent();
/** /**
* The new round event is emitted when the player wants to start a new round * The new round event is emitted when the player wants to start a new round
@ -115,4 +115,6 @@ public interface IView {
public void setCurrentPlayerColor(Color color); public void setCurrentPlayerColor(Color color);
public void setHasLaidOut(boolean hasLaidOut); public void setHasLaidOut(boolean hasLaidOut);
IEvent getNewGameEvent();
} }

View file

@ -205,7 +205,13 @@ public class View extends JFrame implements IView {
} }
@Override @Override
public IEvent getFinalScoreEvent() { public IEvent getNewGameEvent() {
return winPanel.getFinalScoreEvent(); return winPanel.getNewGameEvent();
} }
@Override
public IEvent getEndProgramEvent() {
return winPanel.getEndProgramEvent();
}
} }

View file

@ -27,9 +27,11 @@ class WinPanel extends JPanel {
private JLabel winLabel; private JLabel winLabel;
private JButton newRoundButton; private JButton newRoundButton;
private JButton finalScoreButton; private JButton newGameButton;
private JButton endProgramButton;
private Event finalScoreEvent = new Event(); private Event endProgramEvent = new Event();
private Event newGameEvent = new Event();
private Event newRoundEvent = new Event(); private Event newRoundEvent = new Event();
/** /**
@ -56,14 +58,23 @@ class WinPanel extends JPanel {
}); });
add(newRoundButton); add(newRoundButton);
finalScoreButton = new JButton("Endauswertung"); newGameButton = new JButton("Neues Spiel");
finalScoreButton.addActionListener(new ActionListener() { newGameButton.addActionListener(new ActionListener() {
@Override @Override
public void actionPerformed(ActionEvent arg0) { public void actionPerformed(ActionEvent arg0) {
finalScoreEvent.emit(); newGameEvent.emit();
} }
}); });
add(finalScoreButton); add(newGameButton);
endProgramButton = new JButton("Programm verlassen");
endProgramButton.addActionListener(new ActionListener() {
@Override
public void actionPerformed(ActionEvent arg0) {
endProgramEvent.emit();
}
});
add(endProgramButton);
addComponentListener(new ComponentAdapter() { addComponentListener(new ComponentAdapter() {
@Override @Override
@ -77,7 +88,7 @@ class WinPanel extends JPanel {
* Sets the name of the current player * Sets the name of the current player
* *
* @param name * @param name
* the player name * the player name
*/ */
void setCurrentPlayerName(String name) { void setCurrentPlayerName(String name) {
winLabel.setText("Du hast gewonnen, " + name + "!"); winLabel.setText("Du hast gewonnen, " + name + "!");
@ -92,19 +103,24 @@ class WinPanel extends JPanel {
return newRoundEvent; return newRoundEvent;
} }
IEvent getNewGameEvent() {
return newGameEvent;
}
/** /**
* The quit event is emitted when the player wants to quit the program * The end program is emitted when the player wants to quit the program
* *
* @return the event * @return the event
*/ */
IEvent getFinalScoreEvent() { IEvent getEndProgramEvent() {
return finalScoreEvent; return endProgramEvent;
} }
private void rescale() { private void rescale() {
Insets insets = getInsets(); Insets insets = getInsets();
int x = insets.left, y = insets.top, width = getWidth() - insets.left int x = insets.left, y = insets.top, width = getWidth() - insets.left
- insets.right, height = getHeight() - insets.top - insets.bottom; - insets.right, height = getHeight() - insets.top
- insets.bottom;
if (width > PANEL_MAX_WIDTH) { if (width > PANEL_MAX_WIDTH) {
x += (width - PANEL_MAX_WIDTH) / 4; x += (width - PANEL_MAX_WIDTH) / 4;
@ -112,7 +128,7 @@ class WinPanel extends JPanel {
} }
int firstLineHeight = (int) ((height - PANEL_SEPARATOR) * PANEL_FIRST_LINE_HEIGHT); int firstLineHeight = (int) ((height - PANEL_SEPARATOR) * PANEL_FIRST_LINE_HEIGHT);
int buttonWidth = (width - PANEL_SEPARATOR) / 2; int buttonWidth = (width - 2 * PANEL_SEPARATOR) / 3;
int buttonHeight = height - PANEL_SEPARATOR - firstLineHeight; int buttonHeight = height - PANEL_SEPARATOR - firstLineHeight;
float fontSize = (float) Math.sqrt(buttonWidth * buttonHeight) / 5; float fontSize = (float) Math.sqrt(buttonWidth * buttonHeight) / 5;
if (fontSize > MAX_BUTTON_FONT_SIZE) if (fontSize > MAX_BUTTON_FONT_SIZE)
@ -123,8 +139,14 @@ class WinPanel extends JPanel {
buttonWidth, buttonHeight); buttonWidth, buttonHeight);
newRoundButton.setFont(newRoundButton.getFont().deriveFont(fontSize)); newRoundButton.setFont(newRoundButton.getFont().deriveFont(fontSize));
finalScoreButton.setBounds(x + buttonWidth + PANEL_SEPARATOR, y + firstLineHeight newGameButton.setBounds(x + buttonWidth + PANEL_SEPARATOR, y
+ PANEL_SEPARATOR, buttonWidth, buttonHeight); + firstLineHeight + PANEL_SEPARATOR, buttonWidth, buttonHeight);
finalScoreButton.setFont(finalScoreButton.getFont().deriveFont(fontSize)); newGameButton.setFont(newGameButton.getFont().deriveFont(fontSize));
endProgramButton.setBounds(x + 2 * (buttonWidth + PANEL_SEPARATOR), y
+ firstLineHeight + PANEL_SEPARATOR, buttonWidth, buttonHeight);
endProgramButton.setFont(endProgramButton.getFont()
.deriveFont(fontSize));
} }
} }