diff options
| author | Daniel She <shekwancheung0528@gmail.com> | 2019-06-06 20:14:42 +0800 |
|---|---|---|
| committer | Daniel She <shekwancheung0528@gmail.com> | 2019-06-06 20:14:42 +0800 |
| commit | fab214806ccc3ffbfd03e4034af6cee906124b7a (patch) | |
| tree | d5c1a2e108b81d3a57988d4f03ed515c991e75e4 /src/main/java/me/shedaniel/rei/gui/renderables/SimpleRecipeRenderer.java | |
| parent | d414c887e0c42325cf2e7c778b32e3fb13ee2e69 (diff) | |
| parent | 558504bd65af2138d73825f1ffa8066a5d70e8f5 (diff) | |
| download | RoughlyEnoughItems-fab214806ccc3ffbfd03e4034af6cee906124b7a.tar.gz RoughlyEnoughItems-fab214806ccc3ffbfd03e4034af6cee906124b7a.tar.bz2 RoughlyEnoughItems-fab214806ccc3ffbfd03e4034af6cee906124b7a.zip | |
Merge branch 'fabric-dev' into 1.14
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.java | 45 |
1 files changed, 36 insertions, 9 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 index 422b0e447..71fd9a4a4 100644 --- a/src/main/java/me/shedaniel/rei/gui/renderables/SimpleRecipeRenderer.java +++ b/src/main/java/me/shedaniel/rei/gui/renderables/SimpleRecipeRenderer.java @@ -15,6 +15,7 @@ import net.minecraft.util.Identifier; import net.minecraft.util.Pair; import net.minecraft.util.math.MathHelper; +import java.util.Comparator; import java.util.List; import java.util.Optional; import java.util.concurrent.atomic.AtomicInteger; @@ -23,6 +24,19 @@ import java.util.stream.Collectors; public class SimpleRecipeRenderer extends RecipeRenderer { + public static final Comparator<ItemStack> ITEM_STACK_COMPARATOR = (o1, o2) -> { + if (o1.getItem() == o2.getItem()) { + if (o1.getAmount() != o2.getAmount()) + return o1.getAmount() - o2.getAmount(); + int compare = Boolean.compare(o1.hasTag(), o2.hasTag()); + if (compare != 0) + return compare; + if (o1.getTag().getSize() != o2.getTag().getSize()) + return o1.getTag().getSize() - o2.getTag().getSize(); + return o1.getTag().hashCode() - o2.getTag().hashCode(); + } + return o1.getItem().hashCode() - o2.getItem().hashCode(); + }; private static final Identifier CHEST_GUI_TEXTURE = new Identifier("roughlyenoughitems", "textures/gui/recipecontainer.png"); private List<ItemStackRenderer> inputRenderer; private ItemStackRenderer outputRenderer; @@ -31,7 +45,7 @@ public class SimpleRecipeRenderer extends RecipeRenderer { 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(); + Optional<Pair<List<ItemStack>, AtomicInteger>> any = newList.stream().filter(pairr -> equalsList(pair.getLeft(), pairr.getLeft())).findAny(); if (any.isPresent()) { any.get().getRight().addAndGet(pair.getRight()); } else @@ -48,9 +62,22 @@ public class SimpleRecipeRenderer extends RecipeRenderer { this.outputRenderer = Renderable.fromItemStacks(output.get().stream().filter(stack -> !stack.isEmpty()).collect(Collectors.toList())); } + public static boolean equalsList(List<ItemStack> list_1, List<ItemStack> list_2) { + List<ItemStack> stacks_1 = list_1.stream().distinct().sorted(ITEM_STACK_COMPARATOR).collect(Collectors.toList()); + List<ItemStack> stacks_2 = list_2.stream().distinct().sorted(ITEM_STACK_COMPARATOR).collect(Collectors.toList()); + if (stacks_1.equals(stacks_2)) + return true; + if (stacks_1.size() != stacks_2.size()) + return false; + for(int i = 0; i < stacks_1.size(); i++) + if (!stacks_1.get(i).isEqualIgnoreTags(stacks_2.get(i))) + return false; + return true; + } + @Override public void render(int x, int y, double mouseX, double mouseY, float delta) { - int xx = x + 5, yy = y + 5; + int xx = x + 4, yy = y + 2; int j = 0; int itemsPerLine = getItemsPerLine(); for(ItemStackRenderer itemStackRenderer : inputRenderer) { @@ -59,18 +86,18 @@ public class SimpleRecipeRenderer extends RecipeRenderer { itemStackRenderer.render(xx + 8, yy + 6, mouseX, mouseY, delta); xx += 18; j++; - if (j >= getItemsPerLine() - 3) { + if (j >= getItemsPerLine() - 2) { yy += 18; xx = x + 5; j = 0; } } - xx = x + 5 + 18 * (getItemsPerLine() - 3); + xx = x + 5 + 18 * (getItemsPerLine() - 2); yy = y + getHeight() / 2 - 8; GuiLighting.disable(); MinecraftClient.getInstance().getTextureManager().bindTexture(CHEST_GUI_TEXTURE); - blit(xx, yy, 0, 28, 36, 18); - xx += 36; + blit(xx, yy, 0, 28, 18, 18); + xx += 18; outputRenderer.setBlitOffset(getBlitOffset() + 50); outputRenderer.drawTooltip = MinecraftClient.getInstance().currentScreen instanceof VillagerRecipeViewingScreen; outputRenderer.render(xx + 8, yy + 6, mouseX, mouseY, delta); @@ -78,15 +105,15 @@ public class SimpleRecipeRenderer extends RecipeRenderer { @Override public int getHeight() { - return 10 + getItemsHeight() * 18; + return 4 + getItemsHeight() * 18; } public int getItemsHeight() { - return MathHelper.ceil(((float) inputRenderer.size()) / (getItemsPerLine() - 3)); + return MathHelper.ceil(((float) inputRenderer.size()) / (getItemsPerLine() - 2)); } public int getItemsPerLine() { - return MathHelper.floor((getWidth() - 10f) / 18f); + return MathHelper.floor((getWidth() - 4f) / 18f); } } |
