ActuallyAdditions/src/main/java/de/ellpeck/actuallyadditions/mod/jei/FermentingCategory.java
2024-03-03 19:02:05 +01:00

89 lines
3.5 KiB
Java

package de.ellpeck.actuallyadditions.mod.jei;
import de.ellpeck.actuallyadditions.mod.ActuallyAdditions;
import de.ellpeck.actuallyadditions.mod.crafting.FermentingRecipe;
import de.ellpeck.actuallyadditions.mod.inventory.gui.FluidDisplay;
import de.ellpeck.actuallyadditions.mod.util.AssetUtil;
import mezz.jei.api.gui.builder.IRecipeLayoutBuilder;
import mezz.jei.api.gui.drawable.IDrawable;
import mezz.jei.api.gui.drawable.IDrawableStatic;
import mezz.jei.api.gui.ingredient.IRecipeSlotsView;
import mezz.jei.api.helpers.IGuiHelper;
import mezz.jei.api.recipe.IFocusGroup;
import mezz.jei.api.recipe.RecipeIngredientRole;
import mezz.jei.api.recipe.RecipeType;
import mezz.jei.api.recipe.category.IRecipeCategory;
import net.minecraft.client.gui.GuiGraphics;
import net.minecraft.network.chat.Component;
import net.minecraft.resources.ResourceLocation;
import net.minecraftforge.fluids.FluidStack;
import net.minecraftforge.fluids.FluidType;
public class FermentingCategory implements IRecipeCategory<FermentingRecipe> {
private final IDrawableStatic background;
private final IDrawableStatic fluidBackground;
public FermentingCategory(IGuiHelper guiHelper) {
background = guiHelper.drawableBuilder(new ResourceLocation(ActuallyAdditions.MODID, "textures/gui/gui_fermenting_barrel.png"), 41, 4, 94, 86).setTextureSize(256,256).build();
fluidBackground = guiHelper.drawableBuilder(AssetUtil.GUI_INVENTORY_LOCATION, 0, 171, 18, 85).build();
}
@Override
public RecipeType<FermentingRecipe> getRecipeType() {
return JEIActuallyAdditionsPlugin.FERMENTING;
}
@Override
public Component getTitle() {
return Component.literal("Fermenting Recipe");
}
@Override
public IDrawable getBackground() {
return background;
}
@Override
public IDrawable getIcon() {
return null;
}
@Override
public void setRecipe(IRecipeLayoutBuilder builder, FermentingRecipe recipe, IFocusGroup focuses) {
// int maxFluid = Math.max(FluidType.BUCKET_VOLUME, Math.max(recipe.getInput().getAmount(), recipe.getOutput().getAmount()));
// recipe.setInputDisplay(new FluidDisplay(19, 1, recipe.getInput(), maxFluid, false));
// recipe.setOutputDisplay(new FluidDisplay(19+38, 1, recipe.getOutput(), maxFluid, false));
FluidStack input = recipe.getInput();
int height = (int)(83D / 1000 * input.getAmount());
int offset = 83 - height;
builder.addSlot(RecipeIngredientRole.INPUT, 20, 1 + offset)
.addFluidStack(input.getFluid(), input.getAmount())
.setFluidRenderer(input.getAmount(), false, 16, height)
.setBackground(fluidBackground, -1, -1 - offset);
FluidStack output = recipe.getOutput();
height = (int)(83D / 1000 * input.getAmount());
offset = 83 - height;;
builder.addSlot(RecipeIngredientRole.OUTPUT, 20+38, 1 + offset)
.addFluidStack(output.getFluid(), output.getAmount())
.setFluidRenderer(output.getAmount(), false, 16, height)
.setBackground(fluidBackground, -1, -1 - offset);
}
@Override
public void draw(FermentingRecipe recipe, IRecipeSlotsView recipeSlotsView, GuiGraphics guiGraphics, double mouseX, double mouseY) {
// IRecipeCategory.super.draw(recipe, recipeSlotsView, guiGraphics, mouseX, mouseY);
// recipe.getInputDisplay().ifPresent(display -> {
// display.draw(guiGraphics);
// display.render(guiGraphics, (int) mouseX, (int) mouseY);
// });
//
// recipe.getOutputDisplay().ifPresent(display -> {
// display.draw(guiGraphics);
// display.render(guiGraphics, (int) mouseX, (int) mouseY);
// });
//TODO draw the progress indicator, scaled to the recipe duration.
}
}