mirror of
https://github.com/Ellpeck/ActuallyAdditions.git
synced 2024-09-29 20:31:05 +02:00
134 lines
No EOL
4.6 KiB
Java
134 lines
No EOL
4.6 KiB
Java
package ellpeck.actuallyadditions.nei;
|
|
|
|
import codechicken.lib.gui.GuiDraw;
|
|
import codechicken.nei.NEIServerUtils;
|
|
import codechicken.nei.PositionedStack;
|
|
import codechicken.nei.recipe.RecipeInfo;
|
|
import codechicken.nei.recipe.TemplateRecipeHandler;
|
|
import ellpeck.actuallyadditions.recipe.TreasureChestHandler;
|
|
import ellpeck.actuallyadditions.util.ModUtil;
|
|
import ellpeck.actuallyadditions.util.StringUtil;
|
|
import net.minecraft.client.gui.inventory.GuiContainer;
|
|
import net.minecraft.item.ItemStack;
|
|
import net.minecraft.util.StatCollector;
|
|
import org.lwjgl.opengl.GL11;
|
|
|
|
import java.awt.*;
|
|
import java.util.ArrayList;
|
|
import java.util.Collections;
|
|
|
|
public class TreasureChestRecipeHandler extends TemplateRecipeHandler{
|
|
|
|
public static final String NAME = "actuallyadditions.treasureChest";
|
|
|
|
public TreasureChestRecipeHandler(){
|
|
super();
|
|
RecipeInfo.setGuiOffset(this.getGuiClass(), 0, 0);
|
|
}
|
|
|
|
public class CachedTreasure extends CachedRecipe{
|
|
|
|
public PositionedStack result;
|
|
public PositionedStack input;
|
|
public int chance;
|
|
public int minAmount;
|
|
public int maxAmount;
|
|
|
|
public CachedTreasure(ItemStack input, ItemStack result, int chance, int minAmount, int maxAmount){
|
|
this.result = new PositionedStack(result, 67+32, 19);
|
|
this.chance = chance;
|
|
this.input = new PositionedStack(input, 5+32, 19);
|
|
this.minAmount = minAmount;
|
|
this.maxAmount = maxAmount;
|
|
}
|
|
|
|
@Override
|
|
public PositionedStack getIngredient(){
|
|
return input;
|
|
}
|
|
|
|
@Override
|
|
public PositionedStack getResult(){
|
|
return result;
|
|
}
|
|
}
|
|
|
|
@Override
|
|
public int recipiesPerPage(){
|
|
return 2;
|
|
}
|
|
|
|
@Override
|
|
public Class<? extends GuiContainer> getGuiClass(){
|
|
return null;
|
|
}
|
|
|
|
@Override
|
|
public String getRecipeName(){
|
|
return StatCollector.translateToLocal("container.nei." + NAME + ".name");
|
|
}
|
|
|
|
@Override
|
|
public void loadTransferRects(){
|
|
transferRects.add(new RecipeTransferRect(new Rectangle(31+32, 18, 22, 16), NAME));
|
|
}
|
|
|
|
@Override
|
|
public void loadCraftingRecipes(String outputId, Object... results){
|
|
if(outputId.equals(NAME) && getClass() == TreasureChestRecipeHandler.class){
|
|
ArrayList<TreasureChestHandler.Return> recipes = TreasureChestHandler.returns;
|
|
for(TreasureChestHandler.Return recipe : recipes){
|
|
arecipes.add(new CachedTreasure(recipe.input, recipe.returnItem, recipe.itemWeight, recipe.minAmount, recipe.maxAmount));
|
|
}
|
|
}
|
|
else super.loadCraftingRecipes(outputId, results);
|
|
}
|
|
|
|
@Override
|
|
public void loadCraftingRecipes(ItemStack result){
|
|
ArrayList<TreasureChestHandler.Return> recipes = TreasureChestHandler.returns;
|
|
for(TreasureChestHandler.Return recipe : recipes){
|
|
if(NEIServerUtils.areStacksSameType(recipe.returnItem, result)) arecipes.add(new CachedTreasure(recipe.input, recipe.returnItem, recipe.itemWeight, recipe.minAmount, recipe.maxAmount));
|
|
}
|
|
}
|
|
|
|
@Override
|
|
public void loadUsageRecipes(ItemStack ingredient){
|
|
ArrayList<TreasureChestHandler.Return> recipes = TreasureChestHandler.returns;
|
|
for(TreasureChestHandler.Return recipe : recipes){
|
|
if(NEIServerUtils.areStacksSameTypeCrafting(recipe.input, ingredient)){
|
|
CachedTreasure theRecipe = new CachedTreasure(recipe.input, recipe.returnItem, recipe.itemWeight, recipe.minAmount, recipe.maxAmount);
|
|
theRecipe.setIngredientPermutation(Collections.singletonList(theRecipe.input), ingredient);
|
|
arecipes.add(theRecipe);
|
|
}
|
|
}
|
|
}
|
|
|
|
@Override
|
|
public String getGuiTexture(){
|
|
return ModUtil.MOD_ID_LOWER + ":textures/gui/guiNEITreasure.png";
|
|
}
|
|
|
|
@Override
|
|
public void drawBackground(int recipeIndex){
|
|
GL11.glColor4f(1.0F, 1.0F, 1.0F, 1.0F);
|
|
GuiDraw.changeTexture(getGuiTexture());
|
|
GuiDraw.drawTexturedModalRect(32, 0, 0, 0, 96, 60);
|
|
}
|
|
|
|
@Override
|
|
public void drawExtras(int rec){
|
|
CachedTreasure recipe = (CachedTreasure)this.arecipes.get(rec);
|
|
if(recipe.result != null){
|
|
int secondChance = recipe.chance;
|
|
String secondString = secondChance + "%";
|
|
//TODO
|
|
GuiDraw.drawString(recipe.minAmount + "-" + recipe.maxAmount + " Items at " + secondString, 65+10, 45, StringUtil.DECIMAL_COLOR_GRAY_TEXT, false);
|
|
}
|
|
}
|
|
|
|
@Override
|
|
public String getOverlayIdentifier(){
|
|
return NAME;
|
|
}
|
|
} |