diff options
Diffstat (limited to 'core/src/ch/asynk/tankontank/engine/MapNode.java')
-rw-r--r-- | core/src/ch/asynk/tankontank/engine/MapNode.java | 29 |
1 files changed, 29 insertions, 0 deletions
diff --git a/core/src/ch/asynk/tankontank/engine/MapNode.java b/core/src/ch/asynk/tankontank/engine/MapNode.java index 740074e..bf9928a 100644 --- a/core/src/ch/asynk/tankontank/engine/MapNode.java +++ b/core/src/ch/asynk/tankontank/engine/MapNode.java @@ -31,6 +31,9 @@ public class MapNode extends Image implements Map private Matrix4 prevTransform; private Matrix4 nextTransform; + private Pawn currentPawn; + private GridPoint2 currentHex = new GridPoint2(-1, -1); + private final Vector<Animation> animations = new Vector<Animation>(2); private final Vector<Animation> nextAnimations = new Vector<Animation>(2); private final LinkedHashSet<Tile> tilesToDraw = new LinkedHashSet<Tile>(); @@ -277,5 +280,31 @@ public class MapNode extends Image implements Map return hex; } + + @Override + public boolean drag(float dx, float dy) + { + if (currentPawn == null) return false; + currentPawn.translate(dx, dy); + return true; + } + + @Override + public void touchDown(float x, float y) + { + getHexAt(currentHex, x, y); + if (currentHex.x != -1) { + currentPawn = getTopPawnAt(currentHex); + } + } + + @Override + public void touchUp(float x, float y) + { + getHexAt(currentHex, x, y); + if (currentPawn != null) { + movePawnTo(currentPawn, currentHex); + } + } } |