diff options
| author | Jérémy Zurcher <jeremy@asynk.ch> | 2014-11-10 15:02:28 +0100 | 
|---|---|---|
| committer | Jérémy Zurcher <jeremy@asynk.ch> | 2014-11-10 15:02:28 +0100 | 
| commit | 5ccc85eae3da7e5bd171bd17e6632114ddfe50a7 (patch) | |
| tree | 110e97e6d1f08376fd168a877fba20266b2a62af /core/src/ch/asynk/tankontank | |
| parent | 2404b4b89c1641a8d1f5398b6a9bd2e0f816211d (diff) | |
| download | RustAndDust-5ccc85eae3da7e5bd171bd17e6632114ddfe50a7.zip RustAndDust-5ccc85eae3da7e5bd171bd17e6632114ddfe50a7.tar.gz | |
add game/hud/Statistics
Diffstat (limited to 'core/src/ch/asynk/tankontank')
| -rw-r--r-- | core/src/ch/asynk/tankontank/game/hud/Statistics.java | 100 | 
1 files changed, 100 insertions, 0 deletions
| diff --git a/core/src/ch/asynk/tankontank/game/hud/Statistics.java b/core/src/ch/asynk/tankontank/game/hud/Statistics.java new file mode 100644 index 0000000..bfad178 --- /dev/null +++ b/core/src/ch/asynk/tankontank/game/hud/Statistics.java @@ -0,0 +1,100 @@ +package ch.asynk.tankontank.game.hud; + +import com.badlogic.gdx.graphics.g2d.Batch; +import com.badlogic.gdx.graphics.g2d.BitmapFont; +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.game.Player; + +public class Statistics extends Bg +{ +    public float padding; +    protected Label title; +    protected Label header; +    protected Label stats1; +    protected Label stats2; +    protected Bg okBtn; + +    public Statistics(BitmapFont font, TextureRegion region, TextureAtlas atlas, float padding) +    { +        super(region); +        this.title = new Label(font); +        this.header = new Label(font); +        this.stats1 = new Label(font); +        this.stats2 = new Label(font); +        this.okBtn = new Bg(atlas.findRegion("ok")); +        this.visible = false; +        this.padding = padding; +        this.header.write("\nActions\nUnits Left\nCasualties\nWon Attacks\nLost Attacks"); +    } + +    public void show(Player winner, Player loser, Position position) +    { +        title.write(winner.getName() + " player won the battle in " + winner.getTurn() + " turns."); +        stats1.write(winner.getStats()); +        stats2.write(loser.getStats()); + +        float height = (title.getHeight() + header.getHeight() + okBtn.getHeight() + (4 * padding)); +        float width = (header.getWidth() + stats1.getWidth() + stats2.getWidth() + (6 * padding)); +        float w2 = (title.getWidth() + (2 * padding)); +        if (w2 > width) width = w2; +        float x = position.getX(width); +        float y = position.getY(height); +        set(x, y, width, height); + +        y += padding; +        okBtn.setPosition((x + width - okBtn.getWidth() - padding), y); +        x += padding; +        y += (okBtn.getHeight() + padding); +        header.setPosition(x, y); +        stats1.setPosition((x + header.getWidth() + (2 * padding)), y); +        stats2.setPosition((stats1.getX() + stats1.getWidth() + (2 * padding)), y); +        y += (header.getHeight() + padding); +        title.setPosition(x, y); +        visible = true; +    } + +    public boolean hit(float x, float y) +    { +        if (okBtn.hit(x, y)) +            return true; +        return false; +    } + +    @Override +    public void dispose() +    { +        super.dispose(); +        title.dispose(); +        header.dispose(); +        stats1.dispose(); +        stats2.dispose(); +        okBtn.dispose(); +    } + +    @Override +    public void draw(Batch batch) +    { +        if (!visible) return; +        super.draw(batch); +        title.draw(batch); +        header.draw(batch); +        stats1.draw(batch); +        stats2.draw(batch); +        okBtn.draw(batch); +    } + +    @Override +    public void drawDebug(ShapeRenderer shapes) +    { +        if (!visible) return; +        super.drawDebug(shapes); +        title.drawDebug(shapes); +        header.drawDebug(shapes); +        stats1.drawDebug(shapes); +        stats2.drawDebug(shapes); +        okBtn.drawDebug(shapes); +    } +} | 
