Display modes for waves

This commit is contained in:
Anuken
2020-07-28 15:27:43 -04:00
parent be530abd4b
commit 7cc94057a1
5 changed files with 146 additions and 50 deletions

View File

@@ -3,6 +3,7 @@ package mindustry.editor;
import arc.graphics.*;
import arc.graphics.g2d.*;
import arc.math.*;
import arc.scene.ui.*;
import arc.scene.ui.layout.*;
import arc.struct.*;
import arc.util.*;
@@ -10,6 +11,7 @@ import arc.util.pooling.*;
import mindustry.*;
import mindustry.game.*;
import mindustry.gen.*;
import mindustry.graphics.*;
import mindustry.type.*;
import mindustry.ui.*;
@@ -17,9 +19,11 @@ public class WaveGraph extends Table{
public Seq<SpawnGroup> groups = new Seq<>();
public int from, to = 20;
private Mode mode = Mode.counts;
private int[][] values;
private OrderedSet<UnitType> used = new OrderedSet<>();
private int max;
private int max, maxTotal;
private float maxHealth;
private Table colors;
private ObjectSet<UnitType> hidden = new ObjectSet<>();
@@ -30,29 +34,64 @@ public class WaveGraph extends Table{
Lines.stroke(Scl.scl(3f));
Lines.precise(true);
float offsetX = Scl.scl(30f), offsetY = Scl.scl(20f);
float graphX = x + offsetX, graphY = y + offsetY, graphW = width - offsetX, graphH = height - offsetY;
float spacing = graphW / (values.length - 1);
for(UnitType type : used){
Draw.color(color(type));
Draw.alpha(parentAlpha);
Lines.beginLine();
for(int i = 0; i < values.length; i++){
int val = values[i][type.id];
float cx = graphX + i*spacing, cy = 2f + graphY + val * (graphH - 4f) / max;
Lines.linePoint(cx, cy);
}
Lines.endLine();
}
GlyphLayout lay = Pools.obtain(GlyphLayout.class, GlyphLayout::new);
BitmapFont font = Fonts.outline;
lay.setText(font, "1");
float fh = lay.height;
float offsetX = Scl.scl(30f), offsetY = Scl.scl(22f) + fh + Scl.scl(5f);
float graphX = x + offsetX, graphY = y + offsetY, graphW = width - offsetX, graphH = height - offsetY;
float spacing = graphW / (values.length - 1);
if(mode == Mode.counts){
for(UnitType type : used.orderedItems()){
Draw.color(color(type));
Draw.alpha(parentAlpha);
Lines.beginLine();
for(int i = 0; i < values.length; i++){
int val = values[i][type.id];
float cx = graphX + i*spacing, cy = 2f + graphY + val * (graphH - 4f) / max;
Lines.linePoint(cx, cy);
}
Lines.endLine();
}
}else if(mode == Mode.totals){
Lines.beginLine();
Draw.color(Pal.accent);
for(int i = 0; i < values.length; i++){
int sum = 0;
for(UnitType type : used.orderedItems()){
sum += values[i][type.id];
}
float cx = graphX + i*spacing, cy = 2f + graphY + sum * (graphH - 4f) / maxTotal;
Lines.linePoint(cx, cy);
}
Lines.endLine();
}else if(mode == Mode.health){
Lines.beginLine();
Draw.color(Pal.health);
for(int i = 0; i < values.length; i++){
float sum = 0;
for(UnitType type : used.orderedItems()){
sum += type.health * values[i][type.id];
}
float cx = graphX + i*spacing, cy = 2f + graphY + sum * (graphH - 4f) / maxHealth;
Lines.linePoint(cx, cy);
}
Lines.endLine();
}
//how many numbers can fit here
float totalMarks = (height - offsetY - getMarginBottom() *2f - 1f) / (lay.height * 2);
@@ -68,13 +107,18 @@ public class WaveGraph extends Table{
font.draw("" + i, cx, cy + lay.height/2f - Scl.scl(3f), Align.right);
}
float len = 4f;
float len = Scl.scl(4f);
font.setColor(Color.lightGray);
for(int i = 0; i < values.length; i++){
float cy = y, cx = x + graphW / (values.length - 1) * i + offsetX;
float cy = y + fh, cx = x + graphW / (values.length - 1) * i + offsetX;
Lines.line(cx, cy, cx, cy + len);
if(i == values.length/2){
font.draw("" + (i + from), cx, cy - 2f, Align.center);
}
}
font.setColor(Color.white);
Pools.free(lay);
@@ -85,15 +129,31 @@ public class WaveGraph extends Table{
row();
table(t -> colors = t).growX();
row();
table(t -> {
t.left();
ButtonGroup<Button> group = new ButtonGroup<>();
for(Mode m : Mode.all){
t.button("$wavemode." + m.name(), Styles.fullTogglet, () -> {
mode = m;
}).group(group).height(32f).update(b -> b.setChecked(m == mode)).width(100f);
}
}).growX();
}
public void rebuild(){
values = new int[to - from + 1][Vars.content.units().size];
used.clear();
max = 1;
max = maxTotal = 1;
maxHealth = 1f;
for(int i = from; i <= to; i++){
int index = i - from;
float healthsum = 0f;
int sum = 0;
for(SpawnGroup spawn : groups){
int spawned = spawn.getUnitsSpawned(i);
@@ -102,7 +162,11 @@ public class WaveGraph extends Table{
used.add(spawn.type);
}
max = Math.max(max, values[index][spawn.type.id]);
healthsum += spawned * spawn.type.health;
sum += spawned;
}
maxTotal = Math.max(maxTotal, sum);
maxHealth = Math.max(maxHealth,healthsum);
}
ObjectSet<UnitType> usedCopy = new ObjectSet<>(used);
@@ -129,10 +193,14 @@ public class WaveGraph extends Table{
for(UnitType type : hidden){
used.remove(type);
}
}
Color color(UnitType type){
return Tmp.c1.fromHsv(type.id / (float)Vars.content.units().size * 360f, 0.7f, 1f);
}
enum Mode{
counts, totals, health;
static Mode[] all = values();
}
}

View File

@@ -22,7 +22,7 @@ import static mindustry.Vars.*;
import static mindustry.game.SpawnGroup.*;
public class WaveInfoDialog extends BaseDialog{
private static final int displayed = 20;
private int displayed = 20;
private Seq<SpawnGroup> groups = new Seq<>();
private Table table;
@@ -47,28 +47,6 @@ public class WaveInfoDialog extends BaseDialog{
onResize(this::setup);
addCloseButton();
buttons.button("<<", () -> {
}).update(t -> {
if(t.getClickListener().isPressed()){
updateTimer += Time.delta;
if(updateTimer >= updatePeriod){
start = Math.max(start - 1, 0);
updateTimer = 0f;
updateWaves();
}
}
});
buttons.button(">>", () -> {
}).update(t -> {
if(t.getClickListener().isPressed()){
updateTimer += Time.delta;
if(updateTimer >= updatePeriod){
start++;
updateTimer = 0f;
updateWaves();
}
}
});
buttons.button("$waves.edit", () -> {
BaseDialog dialog = new BaseDialog("$waves.edit");
@@ -99,6 +77,50 @@ public class WaveInfoDialog extends BaseDialog{
}));
dialog.show();
}).size(270f, 64f);
buttons.defaults().width(60f);
buttons.button("<", () -> {}).update(t -> {
if(t.getClickListener().isPressed()){
shift(-1);
}
});
buttons.button(">", () -> {}).update(t -> {
if(t.getClickListener().isPressed()){
shift(1);
}
});
buttons.button("-", () -> {}).update(t -> {
if(t.getClickListener().isPressed()){
view(-1);
}
});
buttons.button("+", () -> {}).update(t -> {
if(t.getClickListener().isPressed()){
view(1);
}
});
}
void view(int amount){
updateTimer += Time.delta;
if(updateTimer >= updatePeriod){
displayed += amount;
if(displayed < 5) displayed = 5;
updateTimer = 0f;
updateWaves();
}
}
void shift(int amount){
updateTimer += Time.delta;
if(updateTimer >= updatePeriod){
start += amount;
if(start < 0) start = 0;
updateTimer = 0f;
updateWaves();
}
}
void setup(){
@@ -120,7 +142,7 @@ public class WaveInfoDialog extends BaseDialog{
setAlignment(Align.center, Align.center);
}}).width(390f).growY();
cont.add(graph).grow();
cont.add(graph = new WaveGraph()).grow();
buildGroups();
}