mirror of
https://github.com/Ellpeck/ActuallyAdditions.git
synced 2024-09-27 11:21:05 +02:00
126 lines
4.5 KiB
Java
126 lines
4.5 KiB
Java
/*
|
|
* This file ("FluidDisplay.java") is part of the Actually Additions mod for Minecraft.
|
|
* It is created and owned by Ellpeck and distributed
|
|
* under the Actually Additions License to be found at
|
|
* http://ellpeck.de/actaddlicense
|
|
* View the source code at https://github.com/Ellpeck/ActuallyAdditions
|
|
*
|
|
* © 2015-2017 Ellpeck
|
|
*/
|
|
|
|
package de.ellpeck.actuallyadditions.mod.inventory.gui;
|
|
|
|
import com.mojang.blaze3d.matrix.MatrixStack;
|
|
import com.mojang.blaze3d.platform.GlStateManager;
|
|
import de.ellpeck.actuallyadditions.mod.util.AssetUtil;
|
|
import de.ellpeck.actuallyadditions.mod.util.StringUtil;
|
|
import net.minecraft.client.Minecraft;
|
|
import net.minecraft.client.gui.AbstractGui;
|
|
import net.minecraft.fluid.Fluid;
|
|
import net.minecraft.util.ResourceLocation;
|
|
import net.minecraftforge.api.distmarker.Dist;
|
|
import net.minecraftforge.api.distmarker.OnlyIn;
|
|
import net.minecraftforge.fluids.FluidStack;
|
|
import net.minecraftforge.fluids.capability.templates.FluidTank;
|
|
import net.minecraftforge.fml.client.gui.GuiUtils;
|
|
|
|
import java.text.NumberFormat;
|
|
import java.util.Collections;
|
|
|
|
@OnlyIn(Dist.CLIENT)
|
|
public class FluidDisplay extends AbstractGui {
|
|
|
|
private FluidTank fluidReference;
|
|
private Fluid oldFluid;
|
|
|
|
private int x;
|
|
private int y;
|
|
private boolean outline;
|
|
|
|
private ResourceLocation resLoc;
|
|
|
|
private boolean drawTextNextTo;
|
|
|
|
public FluidDisplay(int x, int y, FluidTank fluidReference, boolean outline, boolean drawTextNextTo) {
|
|
this.setData(x, y, fluidReference, outline, drawTextNextTo);
|
|
}
|
|
|
|
public FluidDisplay(int x, int y, FluidTank fluidReference) {
|
|
this(x, y, fluidReference, false, false);
|
|
}
|
|
|
|
public void setData(int x, int y, FluidTank fluidReference, boolean outline, boolean drawTextNextTo) {
|
|
this.x = x;
|
|
this.y = y;
|
|
this.fluidReference = fluidReference;
|
|
this.outline = outline;
|
|
this.drawTextNextTo = drawTextNextTo;
|
|
}
|
|
|
|
public void draw(MatrixStack matrices) {
|
|
Minecraft mc = Minecraft.getInstance();
|
|
mc.getTextureManager().bindTexture(AssetUtil.GUI_INVENTORY_LOCATION);
|
|
|
|
int barX = this.x;
|
|
int barY = this.y;
|
|
|
|
if (this.outline) {
|
|
this.blit(matrices, this.x, this.y, 52, 163, 26, 93);
|
|
|
|
barX += 4;
|
|
barY += 4;
|
|
}
|
|
this.blit(matrices, barX, barY, 0, 171, 18, 85);
|
|
|
|
FluidStack stack = this.fluidReference.getFluid();
|
|
Fluid fluid = stack == null
|
|
? null
|
|
: stack.getFluid();
|
|
|
|
if (this.resLoc == null || this.oldFluid != fluid) {
|
|
this.oldFluid = fluid;
|
|
|
|
if (fluid != null && fluid.getStill() != null) {
|
|
this.resLoc = new ResourceLocation(fluid.getStill().getNamespace(), "textures/" + fluid.getStill().getPath() + ".png");
|
|
}
|
|
}
|
|
|
|
if (stack != null && fluid != null && this.resLoc != null) {
|
|
mc.getTextureManager().bindTexture(this.resLoc);
|
|
|
|
GlStateManager.pushMatrix();
|
|
GlStateManager.enableBlend();
|
|
GlStateManager.disableAlpha();
|
|
GlStateManager.tryBlendFuncSeparate(770, 771, 1, 0);
|
|
int i = this.fluidReference.getFluidAmount() * 83 / this.fluidReference.getCapacity();
|
|
Gui.drawModalRectWithCustomSizedTexture(barX + 1, barY + 84 - i, 36, 172, 16, i, 16, 512);
|
|
GlStateManager.disableBlend();
|
|
GlStateManager.enableAlpha();
|
|
GlStateManager.popMatrix();
|
|
}
|
|
|
|
if (this.drawTextNextTo) {
|
|
this.drawString(mc.fontRenderer, this.getOverlayText(), barX + 25, barY + 78, StringUtil.DECIMAL_COLOR_WHITE);
|
|
}
|
|
}
|
|
|
|
public void render(MatrixStack matrices, int mouseX, int mouseY) {
|
|
if (mouseX >= this.x && mouseY >= this.y && mouseX < this.x + (this.outline
|
|
? 26
|
|
: 18) && mouseY < this.y + (this.outline
|
|
? 93
|
|
: 85)) {
|
|
Minecraft mc = Minecraft.getInstance();
|
|
GuiUtils.drawHoveringText(Collections.singletonList(this.getOverlayText()), mouseX, mouseY, mc.displayWidth, mc.displayHeight, -1, mc.fontRenderer);
|
|
}
|
|
}
|
|
|
|
private String getOverlayText() {
|
|
NumberFormat format = NumberFormat.getInstance();
|
|
FluidStack stack = this.fluidReference.getFluid();
|
|
String cap = format.format(this.fluidReference.getCapacity());
|
|
return stack == null || stack.getFluid() == null
|
|
? "0/" + cap + " mB"
|
|
: format.format(this.fluidReference.getFluidAmount()) + "/" + cap + " mB " + stack.getLocalizedName();
|
|
}
|
|
}
|