From 70c1354a4a96698758a88c032866288f79de6f5a Mon Sep 17 00:00:00 2001 From: Benjamin Culkin Date: Sat, 24 Aug 2024 08:16:37 -0400 Subject: Initial commit --- .../java/jp/plusplus/fbs/nei/AppraisalHandler.java | 105 +++++++++++++++++++++ 1 file changed, 105 insertions(+) create mode 100644 src/main/java/jp/plusplus/fbs/nei/AppraisalHandler.java (limited to 'src/main/java/jp/plusplus/fbs/nei/AppraisalHandler.java') diff --git a/src/main/java/jp/plusplus/fbs/nei/AppraisalHandler.java b/src/main/java/jp/plusplus/fbs/nei/AppraisalHandler.java new file mode 100644 index 0000000..a6130c1 --- /dev/null +++ b/src/main/java/jp/plusplus/fbs/nei/AppraisalHandler.java @@ -0,0 +1,105 @@ +package jp.plusplus.fbs.nei; + +import codechicken.lib.gui.GuiDraw; +import codechicken.nei.NEIClientUtils; +import codechicken.nei.PositionedStack; +import codechicken.nei.recipe.TemplateRecipeHandler; +import jp.plusplus.fbs.FBS; +import jp.plusplus.fbs.Registry; +import jp.plusplus.fbs.alchemy.AlchemyRegistry; +import jp.plusplus.fbs.gui.GuiExtractingFurnace; +import net.minecraft.client.gui.inventory.GuiContainer; +import net.minecraft.item.ItemStack; +import org.lwjgl.opengl.GL11; + +import java.awt.*; +import java.util.ArrayList; +import java.util.Iterator; + +/** + * Created by pluslus_F on 2015/06/24. + */ +public class AppraisalHandler extends TemplateRecipeHandler { + @Override + public void loadTransferRects() { + this.transferRects.add(new RecipeTransferRect(new Rectangle(68, 35, 22, 15), "fbs.appraisal", new Object[0])); + } + + @Override + public String getOverlayIdentifier() { + return "fbs.appraisal"; + } + + @Override + public void drawBackground(int recipe) { + GL11.glColor4f(1.0F, 1.0F, 1.0F, 1.0F); + GuiDraw.changeTexture(this.getGuiTexture()); + GuiDraw.drawTexturedModalRect(0, 0, 5, 11, 139-5, 65); + } + @Override + public void drawExtras(int recipe) { + } + + @Override + public void loadCraftingRecipes(String outputId, Object... results) { + if(outputId.equals("fbs.appraisal") && this.getClass() == AppraisalHandler.class) { + for(AlchemyRegistry.ItemPair ip : AlchemyRegistry.GetAlllAppraisal()) { + arecipes.add(new CachedAppraisalRecipe(ip.getItem1(), ip.getItem2())); + } + } else { + super.loadCraftingRecipes(outputId, results); + } + + } + + @Override + public void loadCraftingRecipes(ItemStack result) { + //登録済みアイテムから探す + for(AlchemyRegistry.ItemPair ip : AlchemyRegistry.GetAlllAppraisal()){ + if(ip.getItem2().isItemEqual(result)){ + arecipes.add(new CachedAppraisalRecipe(ip.getItem1(), result)); + } + } + } + + @Override + public void loadUsageRecipes(ItemStack ingredient) { + //登録済みアイテムから探す + for(AlchemyRegistry.ItemPair ip : AlchemyRegistry.GetAlllAppraisal()){ + if(ip.getItem1().isItemEqual(ingredient)){ + arecipes.add(new CachedAppraisalRecipe(ingredient, ip.getItem2())); + } + } + } + + @Override + public String getGuiTexture() { + return FBS.MODID+":textures/gui/appraisal.png"; + } + + @Override + public String getRecipeName() { + return NEIClientUtils.translate("recipe.fbs.appraisal", new Object[0]); + } + + public class CachedAppraisalRecipe extends CachedRecipe { + public ArrayList ingredients=new ArrayList(); + public PositionedStack result; + + public CachedAppraisalRecipe(ItemStack in, ItemStack out){ + ingredients.add(new PositionedStack(in, 56-5, 35-11)); + result=new PositionedStack(out, 115-5,35-11); + } + + @Override + public java.util.List getIngredients() { + return getCycledIngredients(AppraisalHandler.this.cycleticks / 20, ingredients); + } + + @Override + public PositionedStack getResult() { + return result; + } + + } +} -- cgit v1.2.3