Heat conductor + phase heater
This commit is contained in:
@@ -1,6 +1,8 @@
|
||||
package mindustry.world.blocks.heat;
|
||||
|
||||
import arc.*;
|
||||
import arc.graphics.g2d.*;
|
||||
import arc.struct.*;
|
||||
import arc.util.*;
|
||||
import mindustry.entities.units.*;
|
||||
import mindustry.gen.*;
|
||||
@@ -10,12 +12,13 @@ import mindustry.world.*;
|
||||
import mindustry.world.draw.*;
|
||||
|
||||
public class HeatConductor extends Block{
|
||||
public float visualMaxHeat = 10f;
|
||||
public float visualMaxHeat = 15f;
|
||||
public DrawBlock drawer = new DrawBlock();
|
||||
|
||||
public HeatConductor(String name){
|
||||
super(name);
|
||||
update = solid = rotate = true;
|
||||
rotateDraw = false;
|
||||
size = 3;
|
||||
}
|
||||
|
||||
@@ -23,7 +26,8 @@ public class HeatConductor extends Block{
|
||||
public void setBars(){
|
||||
super.setBars();
|
||||
|
||||
bars.add("heat", (HeatConductorBuild entity) -> new Bar("bar.heat", Pal.lightOrange, () -> entity.heat / visualMaxHeat));
|
||||
//TODO show number
|
||||
bars.add("heat", (HeatConductorBuild entity) -> new Bar(() -> Core.bundle.format("bar.heatamount", (int)entity.heat), () -> Pal.lightOrange, () -> entity.heat / visualMaxHeat));
|
||||
}
|
||||
|
||||
@Override
|
||||
@@ -43,8 +47,10 @@ public class HeatConductor extends Block{
|
||||
return drawer.finalIcons(this);
|
||||
}
|
||||
|
||||
public class HeatConductorBuild extends Building implements HeatBlock{
|
||||
public class HeatConductorBuild extends Building implements HeatBlock, HeatConsumer{
|
||||
public float heat = 0f;
|
||||
public float[] sideHeat = new float[4];
|
||||
public IntSet cameFrom = new IntSet();
|
||||
|
||||
@Override
|
||||
public void draw(){
|
||||
@@ -57,9 +63,19 @@ public class HeatConductor extends Block{
|
||||
drawer.drawLights(this);
|
||||
}
|
||||
|
||||
@Override
|
||||
public float[] sideHeat(){
|
||||
return sideHeat;
|
||||
}
|
||||
|
||||
@Override
|
||||
public float heatRequirement(){
|
||||
return visualMaxHeat;
|
||||
}
|
||||
|
||||
@Override
|
||||
public void updateTile(){
|
||||
heat = calculateHeat(null);
|
||||
heat = calculateHeat(sideHeat, cameFrom);
|
||||
}
|
||||
|
||||
@Override
|
||||
|
||||
6
core/src/mindustry/world/blocks/heat/HeatConsumer.java
Normal file
6
core/src/mindustry/world/blocks/heat/HeatConsumer.java
Normal file
@@ -0,0 +1,6 @@
|
||||
package mindustry.world.blocks.heat;
|
||||
|
||||
public interface HeatConsumer{
|
||||
float[] sideHeat();
|
||||
float heatRequirement();
|
||||
}
|
||||
@@ -4,6 +4,7 @@ import arc.*;
|
||||
import arc.math.*;
|
||||
import mindustry.graphics.*;
|
||||
import mindustry.ui.*;
|
||||
import mindustry.world.blocks.heat.*;
|
||||
import mindustry.world.meta.*;
|
||||
|
||||
/** A crafter that requires contact from heater blocks to craft. */
|
||||
@@ -35,9 +36,10 @@ public class HeatCrafter extends GenericCrafter{
|
||||
super.setStats();
|
||||
|
||||
stats.add(Stat.input, heatRequirement, StatUnit.heatUnits);
|
||||
stats.add(Stat.maxEfficiency, (int)(maxEfficiency * 100f), StatUnit.percent);
|
||||
}
|
||||
|
||||
public class HeatCrafterBuild extends GenericCrafterBuild{
|
||||
public class HeatCrafterBuild extends GenericCrafterBuild implements HeatConsumer{
|
||||
//TODO sideHeat could be smooth
|
||||
public float[] sideHeat = new float[4];
|
||||
public float heat = 0f;
|
||||
@@ -49,10 +51,16 @@ public class HeatCrafter extends GenericCrafter{
|
||||
super.updateTile();
|
||||
}
|
||||
|
||||
@Override
|
||||
public float heatRequirement(){
|
||||
return heatRequirement;
|
||||
}
|
||||
|
||||
@Override
|
||||
public float[] sideHeat(){
|
||||
return sideHeat;
|
||||
}
|
||||
|
||||
@Override
|
||||
public float warmupTarget(){
|
||||
return Mathf.clamp(heat / heatRequirement);
|
||||
|
||||
Reference in New Issue
Block a user