From 9e55b44b710f38c63a4bfd17d0b07318d5c68535 Mon Sep 17 00:00:00 2001 From: Daniel She Date: Mon, 25 Feb 2019 21:18:26 +0800 Subject: REI v2.3.1 (#40) - API Changes - Updated Config Screen - Added Tipped Arrows Recipes - Updated Mappings - Added IRecipeHelper - Turning things to Optional - Removed Cheats button, now included with the new config button - Buttons for switching gamemodes / time / weather (default: off) [Maybe not in this update] - Clickable Labels - 3+ recipes at the same time - Fixed RecipeBaseWidget bad rendering when too big - Fixed #42 Patched up item deleting & cheating - Choose Page Dialog --- .../shedaniel/rei/plugin/DefaultCustomDisplay.java | 70 ++++++++++++++++++++++ 1 file changed, 70 insertions(+) create mode 100644 src/main/java/me/shedaniel/rei/plugin/DefaultCustomDisplay.java (limited to 'src/main/java/me/shedaniel/rei/plugin/DefaultCustomDisplay.java') diff --git a/src/main/java/me/shedaniel/rei/plugin/DefaultCustomDisplay.java b/src/main/java/me/shedaniel/rei/plugin/DefaultCustomDisplay.java new file mode 100644 index 000000000..0920c78d8 --- /dev/null +++ b/src/main/java/me/shedaniel/rei/plugin/DefaultCustomDisplay.java @@ -0,0 +1,70 @@ +package me.shedaniel.rei.plugin; + +import com.google.common.collect.Lists; +import net.minecraft.item.ItemStack; +import net.minecraft.recipe.Recipe; + +import java.util.Collections; +import java.util.List; +import java.util.Optional; + +public class DefaultCustomDisplay implements DefaultCraftingDisplay { + + private List> input; + private List output; + private Recipe possibleRecipe; + private int width, height; + + public DefaultCustomDisplay(List> input, List output, Recipe possibleRecipe) { + this.input = input; + this.output = output; + this.possibleRecipe = possibleRecipe; + List row = Lists.newArrayList(false, false, false); + List column = Lists.newArrayList(false, false, false); + for(int i = 0; i < 9; i++) + if (i < input.size()) { + List stacks = input.get(i); + if (stacks.stream().filter(stack -> !stack.isEmpty()).count() > 0) { + row.set((i - (i % 3)) / 3, true); + column.set(i % 3, true); + } + } + width = (int) column.stream().filter(b -> b).count(); + height = (int) row.stream().filter(b -> b).count(); + } + + public DefaultCustomDisplay(List> input, List output) { + this(input, output, null); + } + + @Override + public Optional getRecipe() { + return Optional.ofNullable(possibleRecipe); + } + + @Override + public List> getInput() { + return Collections.unmodifiableList(input); + } + + @Override + public List getOutput() { + return Collections.unmodifiableList(output); + } + + @Override + public List> getRequiredItems() { + return Collections.unmodifiableList(input); + } + + @Override + public int getWidth() { + return width; + } + + @Override + public int getHeight() { + return height; + } + +} -- cgit