summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--core/src/ch/asynk/tankontank/engine/Pawn.java135
1 files changed, 53 insertions, 82 deletions
diff --git a/core/src/ch/asynk/tankontank/engine/Pawn.java b/core/src/ch/asynk/tankontank/engine/Pawn.java
index 446c3cd..52af8ca 100644
--- a/core/src/ch/asynk/tankontank/engine/Pawn.java
+++ b/core/src/ch/asynk/tankontank/engine/Pawn.java
@@ -24,9 +24,9 @@ public abstract class Pawn implements Drawable, Disposable
{
private static final float MOVE_TIME = 0.4f;
+ private Vector3 position = new Vector3(0f, 0f, 0f);
private Image image;
private StackedImages overlays;
- private ArrayDeque<Vector3> moves = new ArrayDeque<Vector3>();
public abstract int getMovementPoints();
public abstract int getRoadMarchBonus();
@@ -46,10 +46,15 @@ public abstract class Pawn implements Drawable, Disposable
this.overlays = new StackedImages(atlas);
}
- public Vector3 getLastPosition()
+ @Override
+ public void dispose()
{
- if ((moves == null) || (moves.size() == 0)) return null;
- return moves.getFirst();
+ image.dispose();
+ }
+
+ public Vector3 getPosition()
+ {
+ return position;
}
public Vector2 getCenter()
@@ -70,80 +75,6 @@ public abstract class Pawn implements Drawable, Disposable
return pos;
}
- public Orientation getOrientation()
- {
- return Orientation.fromRotation(getRotation());
- }
-
- public void moveDone()
- {
- Vector3 v = moves.pop();
- moves.clear();
- moves.push(v);
- }
-
- public void pushMove(float x, float y, Orientation o)
- {
- float r = ((o == Orientation.KEEP) ? getRotation() : o.r());
- setPosition(x, y, r);
- Vector3 v = new Vector3(x, y, r);
- if ((moves.size() == 0) || (!v.equals(moves.getFirst())))
- moves.push(new Vector3(x, y, r));
- }
-
- public AnimationSequence getResetMovesAnimation()
- {
- final Vector3 finalPos = moves.getLast();
-
- AnimationSequence seq = AnimationSequence.get(moves.size() + 1);
-
- while(moves.size() != 0) {
- seq.addAnimation(MoveToAnimation.get(this, moves.pop(), MOVE_TIME));
- }
-
- seq.addAnimation(RunnableAnimation.get(this, new Runnable() {
- @Override
- public void run() {
- moves.push(finalPos);
- }
- }));
-
- return seq;
- }
-
- public AnimationSequence getMoveAnimation(Vector<Vector3> path)
- {
- int s = path.size();
- final Vector3 finalPos = path.get(s - 1);
-
- AnimationSequence seq = AnimationSequence.get(s + 1);
-
- for (Vector3 v : path) {
- seq.addAnimation(MoveToAnimation.get(this, v, MOVE_TIME));
- }
-
- seq.addAnimation(RunnableAnimation.get(this, new Runnable() {
- @Override
- public void run() {
- moves.push(finalPos);
- }
- }));
-
- return seq;
- }
-
- public boolean hasOverlayEnabled()
- {
- return overlays.isEnabled();
- }
-
- public boolean enableOverlay(int i, boolean enable)
- {
- overlays.enable(i, enable);
- if (enable) return true;
- return hasOverlayEnabled();
- }
-
public float getX()
{
return image.getX();
@@ -169,24 +100,64 @@ public abstract class Pawn implements Drawable, Disposable
return image.getRotation();
}
+ public Orientation getOrientation()
+ {
+ return Orientation.fromRotation(getRotation());
+ }
+
public void setPosition(float x, float y)
{
+ position.set(x, y, 0f);
image.setPosition(x, y);
float cx = x + (getWidth() / 2f);
float cy = y + (getHeight() / 2f);
overlays.centerOn(cx, cy);
}
+ public void setRotation(float z)
+ {
+ position.z = z;
+ image.setRotation(z);
+ overlays.setRotation(z);
+ }
+
public void setPosition(float x, float y, float z)
{
setPosition(x, y);
- overlays.setRotation(z);
+ setRotation(z);
}
- @Override
- public void dispose()
+ public boolean hasOverlayEnabled()
{
- image.dispose();
+ return overlays.isEnabled();
+ }
+
+ public boolean enableOverlay(int i, boolean enable)
+ {
+ overlays.enable(i, enable);
+ if (enable) return true;
+ return hasOverlayEnabled();
+ }
+
+ public AnimationSequence getMoveAnimation(Vector<Vector3> path)
+ {
+ int s = path.size();
+ final Vector3 finalPos = path.get(s - 1);
+
+ AnimationSequence seq = AnimationSequence.get(s + 1);
+
+ for (Vector3 v : path) {
+ seq.addAnimation(MoveToAnimation.get(this, v, MOVE_TIME));
+ }
+
+ seq.addAnimation(RunnableAnimation.get(this, new Runnable() {
+ @Override
+ public void run() {
+ setPosition(finalPos.x, finalPos.y, finalPos.z);
+ }
+ }));
+
+ return seq;
}
@Override