2015-11-15 18:05:58 +01:00
|
|
|
/*
|
|
|
|
* This file ("AtomicReconstructorRecipeHandler.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://github.com/Ellpeck/ActuallyAdditions/blob/master/README.md
|
|
|
|
* View the source code at https://github.com/Ellpeck/ActuallyAdditions
|
|
|
|
*
|
|
|
|
* © 2015 Ellpeck
|
|
|
|
*/
|
|
|
|
|
|
|
|
package ellpeck.actuallyadditions.nei;
|
|
|
|
|
|
|
|
import codechicken.lib.gui.GuiDraw;
|
|
|
|
import codechicken.nei.PositionedStack;
|
|
|
|
import codechicken.nei.recipe.RecipeInfo;
|
|
|
|
import codechicken.nei.recipe.TemplateRecipeHandler;
|
|
|
|
import ellpeck.actuallyadditions.blocks.InitBlocks;
|
2015-11-27 16:48:01 +01:00
|
|
|
import ellpeck.actuallyadditions.booklet.BookletUtils;
|
2015-11-15 18:39:05 +01:00
|
|
|
import ellpeck.actuallyadditions.booklet.page.BookletPage;
|
2015-12-04 12:59:37 +01:00
|
|
|
import ellpeck.actuallyadditions.items.lens.LensColor;
|
2015-12-03 22:49:31 +01:00
|
|
|
import ellpeck.actuallyadditions.items.lens.LensNoneRecipeHandler;
|
2015-11-15 18:05:58 +01:00
|
|
|
import ellpeck.actuallyadditions.util.ItemUtil;
|
|
|
|
import ellpeck.actuallyadditions.util.ModUtil;
|
|
|
|
import ellpeck.actuallyadditions.util.StringUtil;
|
2015-12-04 12:59:37 +01:00
|
|
|
import ellpeck.actuallyadditions.util.Util;
|
|
|
|
import net.minecraft.block.Block;
|
2015-11-15 18:39:05 +01:00
|
|
|
import net.minecraft.client.Minecraft;
|
2015-11-15 18:05:58 +01:00
|
|
|
import net.minecraft.client.gui.inventory.GuiContainer;
|
2015-12-04 12:59:37 +01:00
|
|
|
import net.minecraft.item.Item;
|
2015-11-15 18:05:58 +01:00
|
|
|
import net.minecraft.item.ItemStack;
|
|
|
|
import org.lwjgl.opengl.GL11;
|
|
|
|
|
|
|
|
import java.awt.*;
|
|
|
|
import java.util.ArrayList;
|
|
|
|
import java.util.Collections;
|
2015-12-01 23:41:33 +01:00
|
|
|
import java.util.List;
|
2015-11-15 18:05:58 +01:00
|
|
|
|
2015-11-27 15:22:44 +01:00
|
|
|
public class NEIReconstructorRecipe extends TemplateRecipeHandler implements INEIRecipeHandler{
|
2015-11-15 18:05:58 +01:00
|
|
|
|
|
|
|
public static final String NAME = "actuallyadditions.reconstructor";
|
|
|
|
|
2015-11-27 15:22:44 +01:00
|
|
|
public NEIReconstructorRecipe(){
|
2015-11-15 18:05:58 +01:00
|
|
|
super();
|
|
|
|
RecipeInfo.setGuiOffset(this.getGuiClass(), 0, 0);
|
|
|
|
}
|
|
|
|
|
|
|
|
@Override
|
2015-11-27 16:48:01 +01:00
|
|
|
public BookletPage getPageForInfo(int page){
|
|
|
|
return BookletUtils.getFirstPageForStack(new ItemStack(InitBlocks.blockAtomicReconstructor));
|
2015-11-15 18:05:58 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
@Override
|
|
|
|
public String getRecipeName(){
|
|
|
|
return StringUtil.localize("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){
|
2015-11-27 15:22:44 +01:00
|
|
|
if(outputId.equals(NAME) && getClass() == NEIReconstructorRecipe.class){
|
2015-12-04 12:59:37 +01:00
|
|
|
//Default Recipes
|
2015-12-03 22:49:31 +01:00
|
|
|
ArrayList<LensNoneRecipeHandler.Recipe> recipes = LensNoneRecipeHandler.recipes;
|
|
|
|
for(LensNoneRecipeHandler.Recipe recipe : recipes){
|
2015-12-01 23:23:55 +01:00
|
|
|
arecipes.add(new CachedReconstructorRecipe(recipe));
|
2015-11-15 18:05:58 +01:00
|
|
|
}
|
2015-12-04 12:59:37 +01:00
|
|
|
//Color Recipes
|
|
|
|
for(Object o : LensColor.CONVERTABLE_BLOCKS){
|
|
|
|
ItemStack stack;
|
|
|
|
if(o instanceof Block){
|
|
|
|
stack = new ItemStack((Block)o);
|
|
|
|
}
|
|
|
|
else{
|
|
|
|
stack = new ItemStack((Item)o);
|
|
|
|
}
|
|
|
|
for(int i = 0; i < 16; i++){
|
|
|
|
ItemStack stackCopy = stack.copy();
|
|
|
|
stackCopy.setItemDamage(i >= 15 ? 0 : i+1);
|
|
|
|
stack.setItemDamage(i);
|
|
|
|
arecipes.add(new CachedReconstructorRecipe(new LensNoneRecipeHandler.Recipe(stack, stackCopy, LensColor.ENERGY_USE)));
|
|
|
|
}
|
|
|
|
}
|
2015-11-15 18:05:58 +01:00
|
|
|
}
|
|
|
|
else{
|
|
|
|
super.loadCraftingRecipes(outputId, results);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
@Override
|
|
|
|
public void loadCraftingRecipes(ItemStack result){
|
2015-12-03 22:49:31 +01:00
|
|
|
ArrayList<LensNoneRecipeHandler.Recipe> recipes = LensNoneRecipeHandler.recipes;
|
2015-12-04 12:59:37 +01:00
|
|
|
//Default Recipes
|
2015-12-03 22:49:31 +01:00
|
|
|
for(LensNoneRecipeHandler.Recipe recipe : recipes){
|
2015-12-01 23:23:55 +01:00
|
|
|
if(ItemUtil.contains(recipe.getOutputs(), result, true)){
|
|
|
|
arecipes.add(new CachedReconstructorRecipe(recipe));
|
2015-11-15 18:05:58 +01:00
|
|
|
}
|
|
|
|
}
|
2015-12-04 12:59:37 +01:00
|
|
|
//Color Recipes
|
|
|
|
if(result.getItem() != null && (Util.arrayContains(LensColor.CONVERTABLE_BLOCKS, result.getItem()) >= 0 || Util.arrayContains(LensColor.CONVERTABLE_BLOCKS, Block.getBlockFromItem(result.getItem())) >= 0)){
|
|
|
|
int meta = result.getItemDamage();
|
|
|
|
ItemStack input = result.copy();
|
|
|
|
input.setItemDamage(meta <= 0 ? 15 : meta-1);
|
|
|
|
arecipes.add(new CachedReconstructorRecipe(new LensNoneRecipeHandler.Recipe(input, result, LensColor.ENERGY_USE)));
|
|
|
|
}
|
2015-11-15 18:05:58 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
@Override
|
|
|
|
public void loadUsageRecipes(ItemStack ingredient){
|
2015-12-03 22:49:31 +01:00
|
|
|
ArrayList<LensNoneRecipeHandler.Recipe> recipes = LensNoneRecipeHandler.recipes;
|
2015-12-04 12:59:37 +01:00
|
|
|
//Default Recipes
|
2015-12-03 22:49:31 +01:00
|
|
|
for(LensNoneRecipeHandler.Recipe recipe : recipes){
|
2015-12-01 23:23:55 +01:00
|
|
|
if(ItemUtil.contains(recipe.getInputs(), ingredient, true)){
|
|
|
|
CachedReconstructorRecipe theRecipe = new CachedReconstructorRecipe(recipe);
|
2015-11-15 18:05:58 +01:00
|
|
|
theRecipe.setIngredientPermutation(Collections.singletonList(theRecipe.input), ingredient);
|
|
|
|
arecipes.add(theRecipe);
|
|
|
|
}
|
|
|
|
}
|
2015-12-04 12:59:37 +01:00
|
|
|
//Color Recipes
|
|
|
|
if(ingredient.getItem() != null && (Util.arrayContains(LensColor.CONVERTABLE_BLOCKS, ingredient.getItem()) >= 0 || Util.arrayContains(LensColor.CONVERTABLE_BLOCKS, Block.getBlockFromItem(ingredient.getItem())) >= 0)){
|
|
|
|
int meta = ingredient.getItemDamage();
|
|
|
|
ItemStack output = ingredient.copy();
|
|
|
|
output.setItemDamage(meta >= 15 ? 0 : meta+1);
|
|
|
|
arecipes.add(new CachedReconstructorRecipe(new LensNoneRecipeHandler.Recipe(ingredient, output, LensColor.ENERGY_USE)));
|
|
|
|
}
|
2015-11-15 18:05:58 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
@Override
|
|
|
|
public String getGuiTexture(){
|
2015-11-15 18:39:05 +01:00
|
|
|
return ModUtil.MOD_ID_LOWER+":textures/gui/guiNEIAtomicReconstructor.png";
|
2015-11-15 18:05:58 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
@Override
|
|
|
|
public String getOverlayIdentifier(){
|
|
|
|
return NAME;
|
|
|
|
}
|
|
|
|
|
|
|
|
@Override
|
|
|
|
public Class<? extends GuiContainer> getGuiClass(){
|
|
|
|
return null;
|
|
|
|
}
|
|
|
|
|
|
|
|
@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);
|
|
|
|
}
|
|
|
|
|
2015-11-15 18:39:05 +01:00
|
|
|
@Override
|
|
|
|
public void drawForeground(int recipe){
|
|
|
|
if(Minecraft.getMinecraft().currentScreen != null){
|
|
|
|
BookletPage.renderItem(Minecraft.getMinecraft().currentScreen, new ItemStack(InitBlocks.blockAtomicReconstructor), 32+34, 19, 1.0F);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2015-11-15 18:05:58 +01:00
|
|
|
@Override
|
|
|
|
public int recipiesPerPage(){
|
|
|
|
return 2;
|
|
|
|
}
|
|
|
|
|
|
|
|
public class CachedReconstructorRecipe extends CachedRecipe{
|
|
|
|
|
|
|
|
public PositionedStack result;
|
|
|
|
public PositionedStack input;
|
|
|
|
|
2015-12-03 22:49:31 +01:00
|
|
|
public CachedReconstructorRecipe(LensNoneRecipeHandler.Recipe recipe){
|
2015-12-01 23:23:55 +01:00
|
|
|
this.result = new PositionedStack(recipe.getOutputs(), 67+32, 19);
|
|
|
|
this.input = new PositionedStack(recipe.getInputs(), 5+32, 19);
|
2015-11-15 18:05:58 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
@Override
|
|
|
|
public PositionedStack getResult(){
|
2015-12-01 23:41:33 +01:00
|
|
|
return null;
|
2015-11-15 18:05:58 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
@Override
|
2015-12-01 23:41:33 +01:00
|
|
|
public List<PositionedStack> getIngredients(){
|
|
|
|
return this.getCycledIngredients(cycleticks/48, Collections.singletonList(this.input));
|
|
|
|
}
|
|
|
|
|
|
|
|
@Override
|
|
|
|
public java.util.List<PositionedStack> getOtherStacks(){
|
|
|
|
ArrayList<PositionedStack> list = new ArrayList<PositionedStack>();
|
|
|
|
list.addAll(this.getCycledIngredients(cycleticks/48, Collections.singletonList(this.result)));
|
|
|
|
return list;
|
2015-11-15 18:05:58 +01:00
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|