diff options
| author | Jérémy Zurcher <jeremy@asynk.ch> | 2016-01-22 14:50:03 +0100 | 
|---|---|---|
| committer | Jérémy Zurcher <jeremy@asynk.ch> | 2016-01-22 14:50:03 +0100 | 
| commit | fc4192de4512f1bcffac7d718ec935849340fc13 (patch) | |
| tree | b9cd9c3b91b285eed8adc065ad6d5d659778f911 /core/src/ch/asynk/rustanddust/game/hud | |
| parent | 1ffb71d6566dd3d0262915ef9e956c0d2c4d2aed (diff) | |
| download | RustAndDust-fc4192de4512f1bcffac7d718ec935849340fc13.zip RustAndDust-fc4192de4512f1bcffac7d718ec935849340fc13.tar.gz | |
OptionsPanel: add Battle Objectives
Diffstat (limited to 'core/src/ch/asynk/rustanddust/game/hud')
| -rw-r--r-- | core/src/ch/asynk/rustanddust/game/hud/OptionsPanel.java | 27 | 
1 files changed, 26 insertions, 1 deletions
| diff --git a/core/src/ch/asynk/rustanddust/game/hud/OptionsPanel.java b/core/src/ch/asynk/rustanddust/game/hud/OptionsPanel.java index 5f1a892..ddb2aea 100644 --- a/core/src/ch/asynk/rustanddust/game/hud/OptionsPanel.java +++ b/core/src/ch/asynk/rustanddust/game/hud/OptionsPanel.java @@ -29,6 +29,8 @@ public class OptionsPanel extends Patch      private int fxVolumeIdx;      private Label fxVolume;      private Label fxVolumeValue; +    private Label objectives; +    private ObjectivesPanel objectivesPanel;      private Label quit;      private Label [] checkLabels;      private boolean [] checkValues; @@ -43,6 +45,9 @@ public class OptionsPanel extends Patch          this.fxVolume = new Label(game.font, LABEL_PADDING);          this.fxVolume.write("Fx Volume");          this.fxVolumeValue = new Label(game.font, LABEL_PADDING); +        this.objectives = new Label(game.font, LABEL_PADDING); +        this.objectives.write("Battle Objectives"); +        this.objectivesPanel = new ObjectivesPanel(game);          this.quit = new Label(game.font, LABEL_PADDING);          this.quit.write("Quit battle");          this.visible = false; @@ -64,6 +69,7 @@ public class OptionsPanel extends Patch          float dx = (position.getX(rect.width) - rect.x);          float dy = (position.getY(rect.height) - rect.y);          translate(dx, dy); +        objectivesPanel.updatePosition();      }      public void show() @@ -78,10 +84,11 @@ public class OptionsPanel extends Patch          float h = (title.getHeight() + TITLE_PADDING + fxVolumeValue.getHeight());          for (int i = 0; i < checkLabels.length; i++)              h += checkLabels[i].getHeight(); +        h += objectives.getHeight();          h += quit.getHeight();          h += (2 * PADDING); -        float w = (fxVolume.getWidth() + fxVolumeValue.getWidth()); +        float w = (objectives.getWidth());          for (int i = 0; i < checkLabels.length; i++) {              float t = checkLabels[i].getWidth();              if (t > w) @@ -96,6 +103,9 @@ public class OptionsPanel extends Patch          y += PADDING;          x += PADDING + HSPACING; +        objectives.setPosition(x, y); +        y += fxVolume.getHeight(); +          fxVolume.setPosition(x, y);          fxVolumeValue.setPosition((x + fxVolume.getWidth() + OPT_PADDING), y);          y += fxVolume.getHeight(); @@ -134,6 +144,12 @@ public class OptionsPanel extends Patch      @Override      public boolean hit(float x, float y)      { +        if (objectivesPanel.hit(x, y)) { +            objectivesPanel.visible = false; +            this.visible = true; +            return false; +        } +          if (!visible) return false;          if (fxVolume.hit(x, y) || fxVolumeValue.hit(x, y)) { @@ -141,6 +157,10 @@ public class OptionsPanel extends Patch          } else if (quit.hit(x, y)) {              game.ctrl.hud.askQuitBattle();              return false; +        } else if (objectives.hit(x, y)) { +            this.visible = false; +            objectivesPanel.show(game.config.battle); +            return false;          } else {              for (int i = 0; i < checkLabels.length; i++) {                  if (checkLabels[i].hit(x, y)) @@ -165,6 +185,7 @@ public class OptionsPanel extends Patch      {          super.dispose();          title.dispose(); +        objectives.dispose();          fxVolume.dispose();          fxVolumeValue.dispose();          quit.dispose(); @@ -175,9 +196,11 @@ public class OptionsPanel extends Patch      @Override      public void draw(Batch batch)      { +        objectivesPanel.draw(batch);          if (!visible) return;          super.draw(batch);          title.draw(batch); +        objectives.draw(batch);          fxVolume.draw(batch);          fxVolumeValue.draw(batch);          quit.draw(batch); @@ -192,9 +215,11 @@ public class OptionsPanel extends Patch      @Override      public void drawDebug(ShapeRenderer shapes)      { +        objectivesPanel.drawDebug(shapes);          if (!visible) return;          super.drawDebug(shapes);          title.drawDebug(shapes); +        objectives.drawDebug(shapes);          fxVolume.drawDebug(shapes);          fxVolumeValue.drawDebug(shapes);          quit.drawDebug(shapes); | 
