aboutsummaryrefslogtreecommitdiff
path: root/src/main/java/me/shedaniel/rei/gui/renderables/SimpleRecipeRenderer.java
diff options
context:
space:
mode:
authorUnknown <shekwancheung0528@gmail.com>2019-05-09 22:38:34 +0800
committerUnknown <shekwancheung0528@gmail.com>2019-05-09 22:38:34 +0800
commitc1b0219e8d5458ddf1eccc194d34893f698b7d88 (patch)
treea0ed116ad122b66721c5fe9345925e04f3c73a47 /src/main/java/me/shedaniel/rei/gui/renderables/SimpleRecipeRenderer.java
parent6017255b2b2704031a784eafd2bd720f1e7b8fc2 (diff)
downloadRoughlyEnoughItems-c1b0219e8d5458ddf1eccc194d34893f698b7d88.tar.gz
RoughlyEnoughItems-c1b0219e8d5458ddf1eccc194d34893f698b7d88.tar.bz2
RoughlyEnoughItems-c1b0219e8d5458ddf1eccc194d34893f698b7d88.zip
VillagerRecipeViewingScreen done
Diffstat (limited to 'src/main/java/me/shedaniel/rei/gui/renderables/SimpleRecipeRenderer.java')
-rw-r--r--src/main/java/me/shedaniel/rei/gui/renderables/SimpleRecipeRenderer.java104
1 files changed, 104 insertions, 0 deletions
diff --git a/src/main/java/me/shedaniel/rei/gui/renderables/SimpleRecipeRenderer.java b/src/main/java/me/shedaniel/rei/gui/renderables/SimpleRecipeRenderer.java
new file mode 100644
index 000000000..6067993a9
--- /dev/null
+++ b/src/main/java/me/shedaniel/rei/gui/renderables/SimpleRecipeRenderer.java
@@ -0,0 +1,104 @@
+package me.shedaniel.rei.gui.renderables;
+
+import com.google.common.collect.Lists;
+import me.shedaniel.rei.api.Renderable;
+import me.shedaniel.rei.gui.VillagerRecipeViewingScreen;
+import net.minecraft.client.MinecraftClient;
+import net.minecraft.client.render.GuiLighting;
+import net.minecraft.item.ItemStack;
+import net.minecraft.util.Identifier;
+import net.minecraft.util.Pair;
+import net.minecraft.util.math.MathHelper;
+
+import java.util.List;
+import java.util.Optional;
+import java.util.concurrent.atomic.AtomicInteger;
+import java.util.function.Supplier;
+import java.util.stream.Collectors;
+
+public class SimpleRecipeRenderer extends RecipeRenderer {
+
+ private static final Identifier CHEST_GUI_TEXTURE = new Identifier("roughlyenoughitems", "textures/gui/recipecontainer.png");
+ private List<ItemStackRenderer> inputRenderer;
+ private ItemStackRenderer outputRenderer;
+
+ public SimpleRecipeRenderer(Supplier<List<List<ItemStack>>> input, Supplier<List<ItemStack>> output) {
+ List<Pair<List<ItemStack>, AtomicInteger>> newList = Lists.newArrayList();
+ List<Pair<List<ItemStack>, Integer>> a = input.get().stream().map(stacks -> new Pair<>(stacks, stacks.stream().map(ItemStack::getAmount).max(Integer::compareTo).orElse(1))).collect(Collectors.toList());
+ for(Pair<List<ItemStack>, Integer> pair : a) {
+ Optional<Pair<List<ItemStack>, AtomicInteger>> any = newList.stream().filter(pairr -> pair.getLeft().equals(pairr.getLeft())).findAny();
+ if (any.isPresent()) {
+ any.get().getRight().addAndGet(pair.getRight());
+ } else
+ newList.add(new Pair<>(pair.getLeft(), new AtomicInteger(pair.getRight())));
+ }
+ List<List<ItemStack>> b = Lists.newArrayList();
+ for(Pair<List<ItemStack>, AtomicInteger> pair : newList)
+ b.add(pair.getLeft().stream().map(stack -> {
+ ItemStack s = stack.copy();
+ s.setAmount(pair.getRight().get());
+ return s;
+ }).collect(Collectors.toList()));
+ this.inputRenderer = b.stream().filter(stacks -> !stacks.isEmpty()).map(stacks -> Renderable.fromItemStacks(stacks)).collect(Collectors.toList());
+ this.outputRenderer = Renderable.fromItemStacks(output.get().stream().filter(stack -> !stack.isEmpty()).collect(Collectors.toList()));
+ }
+
+ @Override
+ public void render(int x, int y, double mouseX, double mouseY, float delta) {
+ int xx = x + 5, yy = y + 5;
+ int j = 0;
+ int itemsPerLine = getItemsPerLine();
+ for(ItemStackRenderer itemStackRenderer : inputRenderer) {
+ itemStackRenderer.setBlitOffset(getBlitOffset() + 50);
+ itemStackRenderer.drawTooltip = MinecraftClient.getInstance().currentScreen instanceof VillagerRecipeViewingScreen;
+ itemStackRenderer.render(xx + 8, yy + 6, mouseX, mouseY, delta);
+ xx += 18;
+ j++;
+ if (j >= getItemsPerLine()) {
+ yy += 18;
+ xx = x + 5;
+ j = 0;
+ }
+ }
+ if (itemsPerLine - j + 1 < 3) {
+ j = 0;
+ xx = x + 5;
+ yy += 18;
+ }
+ GuiLighting.disable();
+ MinecraftClient.getInstance().getTextureManager().bindTexture(CHEST_GUI_TEXTURE);
+ blit(xx, yy, 0, 28, 36, 18);
+ xx += 36;
+ j += 2;
+ if (j >= getItemsPerLine()) {
+ yy += 18;
+ xx = x + 5;
+ j = 0;
+ }
+ outputRenderer.setBlitOffset(getBlitOffset() + 50);
+ outputRenderer.drawTooltip = MinecraftClient.getInstance().currentScreen instanceof VillagerRecipeViewingScreen;
+ outputRenderer.render(xx + 8, yy + 6, mouseX, mouseY, delta);
+ }
+
+ @Override
+ public int getHeight() {
+ return 10 + getEntriesHeight() * 18;
+ }
+
+ public int getItemsHeight() {
+ return MathHelper.ceil(((float) inputRenderer.size()) / getItemsPerLine());
+ }
+
+ public int getEntriesHeight() {
+ int itemsPerLine = getItemsPerLine();
+ if (itemsPerLine - (inputRenderer.size() - MathHelper.floor(((float) inputRenderer.size()) / itemsPerLine)) < 3)
+ return getItemsHeight() + 1;
+ else
+ return getItemsHeight();
+ }
+
+ public int getItemsPerLine() {
+ return MathHelper.floor((getWidth() - 10f) / 18f);
+ }
+
+}