summaryrefslogtreecommitdiffstats
path: root/core/src
diff options
context:
space:
mode:
authorJérémy Zurcher <jeremy@asynk.ch>2014-09-25 00:06:01 +0200
committerJérémy Zurcher <jeremy@asynk.ch>2014-09-25 00:06:01 +0200
commit357eddc4a412bb928787ab02f5e0f4c3caf74100 (patch)
tree15b9f54a81f2889deba9d9e48f0f19b0c2f77427 /core/src
parent7dc1371623866537b615c3eda59ee7a124d6bc60 (diff)
downloadRustAndDust-357eddc4a412bb928787ab02f5e0f4c3caf74100.zip
RustAndDust-357eddc4a412bb928787ab02f5e0f4c3caf74100.tar.gz
add engine/HeadedPawn
Diffstat (limited to 'core/src')
-rw-r--r--core/src/ch/asynk/tankontank/engine/HeadedPawn.java65
1 files changed, 65 insertions, 0 deletions
diff --git a/core/src/ch/asynk/tankontank/engine/HeadedPawn.java b/core/src/ch/asynk/tankontank/engine/HeadedPawn.java
new file mode 100644
index 0000000..36eb2a2
--- /dev/null
+++ b/core/src/ch/asynk/tankontank/engine/HeadedPawn.java
@@ -0,0 +1,65 @@
+package ch.asynk.tankontank.engine;
+
+import com.badlogic.gdx.graphics.g2d.Batch;
+import com.badlogic.gdx.graphics.g2d.TextureAtlas;
+import com.badlogic.gdx.graphics.g2d.TextureRegion;
+import com.badlogic.gdx.graphics.glutils.ShapeRenderer;
+
+import ch.asynk.tankontank.engine.gfx.Image;
+
+import com.badlogic.gdx.math.Vector3;
+
+public abstract class HeadedPawn extends Pawn
+{
+ private Image head;
+
+ public HeadedPawn(TextureRegion region, TextureRegion head, TextureAtlas atlas)
+ {
+ super(region, atlas);
+ this.head = new Image(head);
+ }
+
+ @Override
+ public void dispose()
+ {
+ super.dispose();
+ head.dispose();
+ }
+
+ @Override
+ public float getRotation()
+ {
+ return head.getRotation();
+ }
+
+ @Override
+ public void translate(float dx, float dy)
+ {
+ super.translate(dx, dy);
+ head.translate(dx, dy);
+ }
+
+ @Override
+ public void setPosition(float x, float y, float z)
+ {
+ super.setPosition(x, y);
+ float cx = x + (getWidth() / 2f) - (head.getWidth() / 2f);
+ float cy = y + (getHeight() / 2f) - (head.getHeight() / 2f);
+ head.setPosition(cx, cy);
+ head.setRotation(z);
+ }
+
+ @Override
+ public void draw(Batch batch)
+ {
+ head.draw(batch);
+ super.draw(batch);
+ }
+
+ @Override
+ public void drawDebug(ShapeRenderer debugShapes)
+ {
+ head.drawDebug(debugShapes);
+ super.drawDebug(debugShapes);
+ }
+}