summaryrefslogtreecommitdiffstats
path: root/core/src/ch/asynk
diff options
context:
space:
mode:
Diffstat (limited to 'core/src/ch/asynk')
-rw-r--r--core/src/ch/asynk/tankontank/game/Ctrl.java39
1 files changed, 15 insertions, 24 deletions
diff --git a/core/src/ch/asynk/tankontank/game/Ctrl.java b/core/src/ch/asynk/tankontank/game/Ctrl.java
index 234b1f9..849742e 100644
--- a/core/src/ch/asynk/tankontank/game/Ctrl.java
+++ b/core/src/ch/asynk/tankontank/game/Ctrl.java
@@ -55,10 +55,10 @@ public class Ctrl implements Disposable
this.cfg = game.config;
game.ctrl = this;
- this.player = battle.getPlayer(true, true);
- this.opponent = battle.getPlayer(false, true);
this.map = battle.getMap();
battle.setup(this, map);
+ this.player = battle.getPlayer();
+ this.opponent = battle.opponent(player);
this.selectState = new StateSelect(this, map);
this.pathState = new StateMove();
@@ -139,16 +139,6 @@ public class Ctrl implements Disposable
hud.victory(winner, ((winner == player) ? opponent : player));
}
- private void switchPlayer()
- {
- TankOnTank.debug("Ctrl", "switch Players");
- endPlayerTurn();
- Player tmp = player;
- player = opponent;
- opponent = tmp;
- startPlayerTurn();
- }
-
private StateType actionAborted()
{
hud.notify("Action canceled");
@@ -160,6 +150,14 @@ public class Ctrl implements Disposable
return nextState;
}
+ private void turnDone()
+ {
+ endPlayerTurn();
+ player = battle.getPlayer();
+ opponent = battle.opponent(player);
+ startPlayerTurn();
+ }
+
private StateType actionDone()
{
StateType nextState = this.state.done();
@@ -183,15 +181,7 @@ public class Ctrl implements Disposable
private StateType deploymentDone()
{
StateType nextState = this.state.done();
-
- if (player.isDeploymentDone() && opponent.isDeploymentDone()) {
- endPlayerTurn();
- player = battle.getPlayer(true, false);
- opponent = battle.getPlayer(false, false);
- startPlayerTurn();
- } else
- switchPlayer();
-
+ turnDone();
return nextState;
}
@@ -306,10 +296,11 @@ public class Ctrl implements Disposable
game.setScreen(new OptionsScreen(game));
}
- public void abortPlayerTurn()
+ public void endPlayerTurn(boolean abort)
{
- state.abort();
- switchPlayer();
+ if (abort)
+ state.abort();
+ turnDone();
}
public void exitBoard(boolean doit)