From 9d8447c002b0f3f39362b01131b8e18d287cb48d Mon Sep 17 00:00:00 2001 From: lordIcocain Date: Fri, 27 Dec 2024 10:39:28 +0200 Subject: [PATCH 1/6] super --- .../client/gui/GuiFluidPatternTerminal.java | 15 ++ .../client/gui/GuiFluidPatternTerminalEx.java | 9 +- .../github/client/gui/GuiPatternMulti.java | 152 ++++++++++++++++++ .../client/gui/base/FCGuiEncodeTerminal.java | 9 +- .../ContainerFluidPatternTerminal.java | 4 +- .../gui/container/ContainerPatternMulti.java | 38 +++++ .../base/FCContainerEncodeTerminal.java | 99 ++++++++---- .../github/inventory/gui/GuiType.java | 15 ++ .../github/loader/ChannelLoader.java | 5 + .../network/CPacketFluidPatternTermBtns.java | 2 +- .../network/CPacketInventoryAction.java | 35 +++- .../network/CPacketPatternMultiSet.java | 93 +++++++++++ .../ae2fc/textures/gui/patternMulti.png | Bin 0 -> 811 bytes 13 files changed, 432 insertions(+), 44 deletions(-) create mode 100644 src/main/java/com/glodblock/github/client/gui/GuiPatternMulti.java create mode 100644 src/main/java/com/glodblock/github/client/gui/container/ContainerPatternMulti.java create mode 100644 src/main/java/com/glodblock/github/network/CPacketPatternMultiSet.java create mode 100644 src/main/resources/assets/ae2fc/textures/gui/patternMulti.png diff --git a/src/main/java/com/glodblock/github/client/gui/GuiFluidPatternTerminal.java b/src/main/java/com/glodblock/github/client/gui/GuiFluidPatternTerminal.java index 9d0900a9a..f9c8178f2 100644 --- a/src/main/java/com/glodblock/github/client/gui/GuiFluidPatternTerminal.java +++ b/src/main/java/com/glodblock/github/client/gui/GuiFluidPatternTerminal.java @@ -6,10 +6,12 @@ import net.minecraft.item.ItemStack; import net.minecraft.util.StatCollector; +import com.glodblock.github.FluidCraft; import com.glodblock.github.client.gui.base.FCGuiEncodeTerminal; import com.glodblock.github.client.gui.container.ContainerFluidPatternTerminal; import com.glodblock.github.client.gui.container.ContainerFluidPatternWireless; import com.glodblock.github.inventory.item.IWirelessTerminal; +import com.glodblock.github.network.CPacketInventoryAction; import com.glodblock.github.util.ModAndClassUtil; import com.glodblock.github.util.NameConst; @@ -24,6 +26,7 @@ import appeng.container.slot.SlotFakeCraftingMatrix; import appeng.container.slot.SlotPatternTerm; import appeng.core.localization.GuiText; +import appeng.helpers.InventoryAction; public class GuiFluidPatternTerminal extends FCGuiEncodeTerminal { @@ -144,6 +147,18 @@ public void drawFG(final int offsetX, final int offsetY, final int mouseX, final 4210752); } + @Override + protected void mouseClicked(final int xCoord, final int yCoord, final int btn) { + + if (btn == 2 && doubleBtn.mousePressed(this.mc, xCoord, yCoord)) { // + InventoryAction action = InventoryAction.SET_PATTERN_MULTI; + + final CPacketInventoryAction p = new CPacketInventoryAction(action, 0, 0); + FluidCraft.proxy.netHandler.sendToServer(p); + } else super.mouseClicked(xCoord, yCoord, btn); + + } + @Override protected void handleMouseClick(final Slot slot, final int slotIdx, final int ctrlDown, final int mouseButton) { if (mouseButton == 3) { diff --git a/src/main/java/com/glodblock/github/client/gui/GuiFluidPatternTerminalEx.java b/src/main/java/com/glodblock/github/client/gui/GuiFluidPatternTerminalEx.java index 6ec82b0e6..a94024797 100644 --- a/src/main/java/com/glodblock/github/client/gui/GuiFluidPatternTerminalEx.java +++ b/src/main/java/com/glodblock/github/client/gui/GuiFluidPatternTerminalEx.java @@ -11,6 +11,7 @@ import com.glodblock.github.client.gui.container.ContainerFluidPatternTerminalEx; import com.glodblock.github.inventory.item.IWirelessTerminal; import com.glodblock.github.network.CPacketFluidPatternTermBtns; +import com.glodblock.github.network.CPacketInventoryAction; import com.glodblock.github.util.ModAndClassUtil; import com.glodblock.github.util.NameConst; @@ -21,6 +22,7 @@ import appeng.api.config.Settings; import appeng.api.storage.ITerminalHost; import appeng.client.gui.widgets.GuiImgButton; +import appeng.helpers.InventoryAction; public class GuiFluidPatternTerminalEx extends FCGuiEncodeTerminal { @@ -179,7 +181,12 @@ public void drawScreen(final int mouseX, final int mouseY, final float btn) { protected void mouseClicked(final int xCoord, final int yCoord, final int btn) { final int currentScroll = this.processingScrollBar.getCurrentScroll(); this.processingScrollBar.click(this, xCoord - this.guiLeft, yCoord - this.guiTop); - super.mouseClicked(xCoord, yCoord, btn); + if (btn == 2 && doubleBtn.mousePressed(this.mc, xCoord, yCoord)) { // + InventoryAction action = InventoryAction.SET_PATTERN_MULTI; + + final CPacketInventoryAction p = new CPacketInventoryAction(action, 0, 0); + FluidCraft.proxy.netHandler.sendToServer(p); + } else super.mouseClicked(xCoord, yCoord, btn); if (currentScroll != this.processingScrollBar.getCurrentScroll()) { changeActivePage(); diff --git a/src/main/java/com/glodblock/github/client/gui/GuiPatternMulti.java b/src/main/java/com/glodblock/github/client/gui/GuiPatternMulti.java new file mode 100644 index 000000000..7b500aab8 --- /dev/null +++ b/src/main/java/com/glodblock/github/client/gui/GuiPatternMulti.java @@ -0,0 +1,152 @@ +package com.glodblock.github.client.gui; + +import net.minecraft.client.gui.GuiButton; +import net.minecraft.entity.player.InventoryPlayer; + +import com.glodblock.github.FluidCraft; +import com.glodblock.github.common.item.ItemWirelessUltraTerminal; +import com.glodblock.github.common.parts.PartFluidPatternTerminal; +import com.glodblock.github.common.parts.PartFluidPatternTerminalEx; +import com.glodblock.github.common.parts.PartFluidTerminal; +import com.glodblock.github.common.parts.PartLevelTerminal; +import com.glodblock.github.inventory.gui.GuiType; +import com.glodblock.github.inventory.item.IWirelessTerminal; +import com.glodblock.github.inventory.item.WirelessLevelTerminalInventory; +import com.glodblock.github.inventory.item.WirelessPatternTerminalInventory; +import com.glodblock.github.loader.ItemAndBlockHolder; +import com.glodblock.github.network.CPacketPatternMultiSet; + +import appeng.api.config.ActionItems; +import appeng.api.config.Settings; +import appeng.api.storage.ITerminalHost; +import appeng.client.gui.implementations.GuiAmount; +import appeng.client.gui.widgets.GuiImgButton; +import appeng.container.implementations.ContainerPatternMulti; +import appeng.core.localization.GuiColors; +import appeng.core.localization.GuiText; +import appeng.helpers.Reflected; +import appeng.util.calculators.ArithHelper; +import appeng.util.calculators.Calculator; + +public class GuiPatternMulti extends GuiAmount { + + private static final int DEFAULT_VALUE = 0; + private GuiImgButton symbolSwitch; + protected GuiType originalGui; + + @Reflected + public GuiPatternMulti(final InventoryPlayer inventoryPlayer, final ITerminalHost te) { + super(new ContainerPatternMulti(inventoryPlayer, te)); + } + + @Override + public void initGui() { + super.initGui(); + + this.buttonList.add( + this.symbolSwitch = new GuiImgButton( + this.guiLeft + 22, + this.guiTop + 53, + Settings.ACTIONS, + ActionItems.MULTIPLY)); + + this.amountTextField.xPosition = this.guiLeft + 50; + this.amountTextField.setText(String.valueOf(DEFAULT_VALUE)); + this.amountTextField.setSelectionPos(0); + } + + @Override + public void drawFG(final int offsetX, final int offsetY, final int mouseX, final int mouseY) { + this.fontRendererObj + .drawString(GuiText.SelectAmount.getLocal(), 8, 6, GuiColors.CraftAmountSelectAmount.getColor()); + } + + @Override + public void drawBG(final int offsetX, final int offsetY, final int mouseX, final int mouseY) { + super.drawBG(offsetX, offsetY, mouseX, mouseY); + this.nextBtn.displayString = GuiText.Set.getLocal(); + + try { + int resultI = getAmount(); + + this.symbolSwitch.set(resultI >= 0 ? ActionItems.MULTIPLY : ActionItems.DIVIDE); + this.nextBtn.enabled = resultI < -1 || resultI > 1; + } catch (final NumberFormatException e) { + this.nextBtn.enabled = false; + } + + this.amountTextField.drawTextBox(); + } + + @Override + protected void actionPerformed(final GuiButton btn) { + super.actionPerformed(btn); + + try { + + if (btn == this.nextBtn && btn.enabled) { + int resultI = getAmount(); + if (resultI > 1 || resultI < -1) + FluidCraft.proxy.netHandler.sendToServer(new CPacketPatternMultiSet(this.originalGui, resultI)); + } + } catch (final NumberFormatException e) { + // nope.. + this.amountTextField.setText(String.valueOf(DEFAULT_VALUE)); + } + + if (btn == this.symbolSwitch) { + int resultI = -getAmount(); + this.amountTextField.setText(Integer.toString(resultI)); + } + + } + + @Override + protected int getAmount() { + String out = this.amountTextField.getText(); + + double resultD = Calculator.conversion(out); + + if (Double.isNaN(resultD)) { + return DEFAULT_VALUE; + } else { + return (int) ArithHelper.round(resultD, 0); + } + } + + @Override + protected int addOrderAmount(final int i) { + return i + getAmount(); + } + + @Override + protected String getBackground() { + return "guis/patternMulti.png"; + } + + @Override + protected void setOriginGUI(Object target) { + if (target instanceof PartFluidPatternTerminal) { + this.myIcon = ItemAndBlockHolder.FLUID_TERMINAL.stack(); + this.originalGui = GuiType.FLUID_PATTERN_TERMINAL; + } else if (target instanceof PartFluidPatternTerminalEx) { + this.myIcon = ItemAndBlockHolder.FLUID_TERMINAL_EX.stack(); + this.originalGui = GuiType.FLUID_PATTERN_TERMINAL_EX; + } else if (target instanceof PartFluidTerminal) { + this.myIcon = ItemAndBlockHolder.FLUID_TERM.stack(); + this.originalGui = GuiType.FLUID_TERMINAL; + } else if (target instanceof PartLevelTerminal) { + myIcon = ItemAndBlockHolder.LEVEL_TERMINAL.stack(); + originalGui = GuiType.LEVEL_TERMINAL; + } else if (target instanceof IWirelessTerminal terminal && terminal.isUniversal(target)) { + this.myIcon = ItemAndBlockHolder.WIRELESS_ULTRA_TERM.stack(); + this.originalGui = ItemWirelessUltraTerminal.readMode(terminal.getItemStack()); + } else if (target instanceof WirelessPatternTerminalInventory) { + this.myIcon = ItemAndBlockHolder.WIRELESS_PATTERN_TERM.stack(); + this.originalGui = GuiType.FLUID_TERMINAL; + } else if (target instanceof WirelessLevelTerminalInventory) { + myIcon = ItemAndBlockHolder.LEVEL_TERMINAL.stack(); + originalGui = GuiType.WIRELESS_LEVEL_TERMINAL; + } + } +} diff --git a/src/main/java/com/glodblock/github/client/gui/base/FCGuiEncodeTerminal.java b/src/main/java/com/glodblock/github/client/gui/base/FCGuiEncodeTerminal.java index 13cdac569..f6d294eb1 100644 --- a/src/main/java/com/glodblock/github/client/gui/base/FCGuiEncodeTerminal.java +++ b/src/main/java/com/glodblock/github/client/gui/base/FCGuiEncodeTerminal.java @@ -5,6 +5,7 @@ import net.minecraft.inventory.Slot; import org.lwjgl.input.Keyboard; +import org.lwjgl.input.Mouse; import org.lwjgl.opengl.GL11; import com.glodblock.github.FluidCraft; @@ -116,10 +117,10 @@ protected void actionPerformed(final GuiButton btn) { "PatternTerminal.Combine", this.combineDisableBtn == btn ? "1" : "0")); } else if (ModAndClassUtil.isDoubleButton && doubleBtn == btn) { - FluidCraft.proxy.netHandler.sendToServer( - new CPacketFluidPatternTermBtns( - "PatternTerminal.Double", - Keyboard.isKeyDown(Keyboard.KEY_LSHIFT) ? "1" : "0")); + int val = Keyboard.isKeyDown(Keyboard.KEY_LSHIFT) ? 1 : 0; + if (Mouse.isButtonDown(1)) val |= 0b10; + FluidCraft.proxy.netHandler + .sendToServer(new CPacketFluidPatternTermBtns("PatternTerminal.Double", String.valueOf(val))); } else if (ModAndClassUtil.isBeSubstitutionsButton && beSubstitutionsDisabledBtn == btn) { FluidCraft.proxy.netHandler .sendToServer(new CPacketFluidPatternTermBtns("PatternTerminal.beSubstitute", "1")); diff --git a/src/main/java/com/glodblock/github/client/gui/container/ContainerFluidPatternTerminal.java b/src/main/java/com/glodblock/github/client/gui/container/ContainerFluidPatternTerminal.java index 7dadc7e3f..6988496e8 100644 --- a/src/main/java/com/glodblock/github/client/gui/container/ContainerFluidPatternTerminal.java +++ b/src/main/java/com/glodblock/github/client/gui/container/ContainerFluidPatternTerminal.java @@ -153,9 +153,9 @@ private void setCraftingMode(final boolean craftingMode) { } @Override - public void doubleStacks(boolean isShift) { + public void doubleStacks(int val) { if (!isCraftingMode()) { - super.doubleStacks(isShift); + super.doubleStacks(val); } } } diff --git a/src/main/java/com/glodblock/github/client/gui/container/ContainerPatternMulti.java b/src/main/java/com/glodblock/github/client/gui/container/ContainerPatternMulti.java new file mode 100644 index 000000000..6199ec44e --- /dev/null +++ b/src/main/java/com/glodblock/github/client/gui/container/ContainerPatternMulti.java @@ -0,0 +1,38 @@ +package com.glodblock.github.client.gui.container; + +import net.minecraft.entity.player.InventoryPlayer; +import net.minecraft.world.World; + +import appeng.api.config.SecurityPermissions; +import appeng.api.networking.IGrid; +import appeng.api.networking.security.BaseActionSource; +import appeng.api.networking.security.IActionHost; +import appeng.api.networking.security.PlayerSource; +import appeng.api.storage.ITerminalHost; +import appeng.container.AEBaseContainer; + +public class ContainerPatternMulti extends AEBaseContainer { + + public ContainerPatternMulti(final InventoryPlayer ip, final ITerminalHost te) { + super(ip, te); + } + + @Override + public void detectAndSendChanges() { + super.detectAndSendChanges(); + this.verifyPermissions(SecurityPermissions.CRAFT, false); + } + + public IGrid getGrid() { + final IActionHost h = ((IActionHost) this.getTarget()); + return h.getActionableNode().getGrid(); + } + + public World getWorld() { + return this.getPlayerInv().player.worldObj; + } + + public BaseActionSource getActionSrc() { + return new PlayerSource(this.getPlayerInv().player, (IActionHost) this.getTarget()); + } +} diff --git a/src/main/java/com/glodblock/github/client/gui/container/base/FCContainerEncodeTerminal.java b/src/main/java/com/glodblock/github/client/gui/container/base/FCContainerEncodeTerminal.java index 6f47be0d3..57738b7c3 100644 --- a/src/main/java/com/glodblock/github/client/gui/container/base/FCContainerEncodeTerminal.java +++ b/src/main/java/com/glodblock/github/client/gui/container/base/FCContainerEncodeTerminal.java @@ -53,6 +53,8 @@ public abstract class FCContainerEncodeTerminal extends ContainerItemMonitor implements IAEAppEngInventory, IOptionalSlotHost, IContainerCraftingPacket, IPatternConsumer { + public static final int MULTIPLE_OF_BUTTON_CLICK = 2; + public static final int MULTIPLE_OF_BUTTON_CLICK_ON_SHIFT = 8; protected final IItemPatternTerminal patternTerminal; protected final AppEngInternalInventory cOut = new AppEngInternalInventory(null, 1); protected final IInventory crafting; @@ -537,52 +539,85 @@ public boolean useRealItems() { return false; } - static boolean canDouble(SlotFake[] slots, int mult) { - for (Slot s : slots) { - ItemStack st = s.getStack(); - if (st != null) { - if (st.getItem() instanceof ItemFluidPacket) { - long result = (long) ItemFluidPacket.getFluidAmount(st) * mult; - if (result > Integer.MAX_VALUE) { - return false; + public void doubleStacks(int val) { + multiplyOrDivideStacks( + ((val & 1) != 0 ? MULTIPLE_OF_BUTTON_CLICK_ON_SHIFT : MULTIPLE_OF_BUTTON_CLICK) + * ((val & 2) != 0 ? -1 : 1)); + } + + static boolean canMultiplyOrDivide(SlotFake[] slots, int mult) { + if (mult > 0) { + for (Slot s : slots) { + if (s.getStack() != null) { + if (s.getStack().getItem() instanceof ItemFluidPacket) { + long result = (long) ItemFluidPacket.getFluidAmount(s.getStack()) * mult; + if (result > Integer.MAX_VALUE) { + return false; + } + } else { + long val = (long) s.getStack().stackSize * mult; + if (val > Integer.MAX_VALUE) return false; } - } else { - long result = (long) s.getStack().stackSize * mult; - if (result > Integer.MAX_VALUE) { - return false; + } + } + return true; + } else if (mult < 0) { + mult = -mult; + for (Slot s : slots) { + if (s.getStack() != null) { // Although % is a very inefficient algorithm, it is not a performance issue + // here. :> + if (s.getStack().getItem() instanceof ItemFluidPacket) { + if (ItemFluidPacket.getFluidAmount(s.getStack()) % mult != 0) return false; + } else { + if (s.getStack().stackSize % mult != 0) return false; } } } + return true; } - return true; + return false; } - static void doubleStacksInternal(SlotFake[] slots, int mult) { + static void multiplyOrDivideStacksInternal(SlotFake[] slots, int mult) { List enabledSlots = Arrays.stream(slots).filter(SlotFake::isEnabled).collect(Collectors.toList()); - for (final Slot s : enabledSlots) { - ItemStack st = s.getStack(); - if (st != null) { - if (st.getItem() instanceof ItemFluidPacket) { - ItemFluidPacket.setFluidAmount(st, ItemFluidPacket.getFluidAmount(st) * mult); - } else { - st.stackSize *= mult; + if (mult > 0) { + for (final Slot s : enabledSlots) { + ItemStack st = s.getStack(); + if (st != null) { + if (st.getItem() instanceof ItemFluidPacket) { + ItemFluidPacket.setFluidAmount(st, ItemFluidPacket.getFluidAmount(st) * mult); + } else { + st.stackSize *= mult; + s.putStack(st); + } + } + } + } else if (mult < 0) { + mult = -mult; + for (final Slot s : enabledSlots) { + ItemStack st = s.getStack(); + if (st != null) { + if (st.getItem() instanceof ItemFluidPacket) { + ItemFluidPacket.setFluidAmount(st, ItemFluidPacket.getFluidAmount(st) / mult); + } else { + st.stackSize /= mult; + s.putStack(st); + } } } } } - public void doubleStacks(boolean isShift) { + /** + * Multiply or divide a number + * + * @param multi Positive numbers are multiplied and negative numbers are divided + */ + public void multiplyOrDivideStacks(int multi) { if (!isCraftingMode()) { - if (isShift) { - if (canDouble(this.craftingSlots, 8) && canDouble(this.outputSlots, 8)) { - doubleStacksInternal(this.craftingSlots, 8); - doubleStacksInternal(this.outputSlots, 8); - } - } else { - if (canDouble(this.craftingSlots, 2) && canDouble(this.outputSlots, 2)) { - doubleStacksInternal(this.craftingSlots, 2); - doubleStacksInternal(this.outputSlots, 2); - } + if (canMultiplyOrDivide(this.craftingSlots, multi) && canMultiplyOrDivide(this.outputSlots, multi)) { + multiplyOrDivideStacksInternal(this.craftingSlots, multi); + multiplyOrDivideStacksInternal(this.outputSlots, multi); } this.detectAndSendChanges(); } diff --git a/src/main/java/com/glodblock/github/inventory/gui/GuiType.java b/src/main/java/com/glodblock/github/inventory/gui/GuiType.java index 824aaaeda..49e5890f8 100644 --- a/src/main/java/com/glodblock/github/inventory/gui/GuiType.java +++ b/src/main/java/com/glodblock/github/inventory/gui/GuiType.java @@ -34,6 +34,7 @@ import com.glodblock.github.client.gui.GuiLevelTerminal; import com.glodblock.github.client.gui.GuiLevelWireless; import com.glodblock.github.client.gui.GuiOCPatternEditor; +import com.glodblock.github.client.gui.GuiPatternMulti; import com.glodblock.github.client.gui.GuiPatternValueAmount; import com.glodblock.github.client.gui.GuiRenamer; import com.glodblock.github.client.gui.container.ContainerCraftingWireless; @@ -61,6 +62,7 @@ import com.glodblock.github.client.gui.container.ContainerLevelTerminal; import com.glodblock.github.client.gui.container.ContainerLevelWireless; import com.glodblock.github.client.gui.container.ContainerOCPatternEditor; +import com.glodblock.github.client.gui.container.ContainerPatternMulti; import com.glodblock.github.client.gui.container.ContainerPatternValueAmount; import com.glodblock.github.client.gui.container.ContainerRenamer; import com.glodblock.github.common.parts.PartFluidLevelEmitter; @@ -512,6 +514,19 @@ protected Object createServerGui(EntityPlayer player, ITerminalHost inv) { protected Object createClientGui(EntityPlayer player, ITerminalHost inv) { return new GuiPatternValueAmount(player.inventory, inv); } + }), + + GUI_PATTERN_MULTI(new PartOrItemGuiFactory<>(ITerminalHost.class) { + + @Override + protected Object createServerGui(EntityPlayer player, ITerminalHost inv) { + return new ContainerPatternMulti(player.inventory, inv); + } + + @Override + protected Object createClientGui(EntityPlayer player, ITerminalHost inv) { + return new GuiPatternMulti(player.inventory, inv); + } }); public static final List VALUES = ImmutableList.copyOf(values()); diff --git a/src/main/java/com/glodblock/github/loader/ChannelLoader.java b/src/main/java/com/glodblock/github/loader/ChannelLoader.java index bd5244f6e..2527be3b4 100644 --- a/src/main/java/com/glodblock/github/loader/ChannelLoader.java +++ b/src/main/java/com/glodblock/github/loader/ChannelLoader.java @@ -13,6 +13,7 @@ import com.glodblock.github.network.CPacketInventoryAction; import com.glodblock.github.network.CPacketLevelMaintainer; import com.glodblock.github.network.CPacketLevelTerminalCommands; +import com.glodblock.github.network.CPacketPatternMultiSet; import com.glodblock.github.network.CPacketPatternValueSet; import com.glodblock.github.network.CPacketRenamer; import com.glodblock.github.network.CPacketSwitchGuis; @@ -78,6 +79,10 @@ public void run() { CPacketLevelTerminalCommands.class, id++, Side.SERVER); + netHandler + .registerMessage(new CPacketPatternMultiSet.Handler(), CPacketPatternMultiSet.class, id++, Side.SERVER); + netHandler + .registerMessage(new CPacketPatternMultiSet.Handler(), CPacketPatternMultiSet.class, id++, Side.CLIENT); } public static void sendPacketToAllPlayers(Packet packet, World world) { diff --git a/src/main/java/com/glodblock/github/network/CPacketFluidPatternTermBtns.java b/src/main/java/com/glodblock/github/network/CPacketFluidPatternTermBtns.java index 921382559..1f12f0dd4 100644 --- a/src/main/java/com/glodblock/github/network/CPacketFluidPatternTermBtns.java +++ b/src/main/java/com/glodblock/github/network/CPacketFluidPatternTermBtns.java @@ -77,7 +77,7 @@ public IMessage onMessage(CPacketFluidPatternTermBtns message, MessageContext ct case "PatternTerminal.Clear" -> cpt.clear(); case "PatternTerminal.Substitute" -> cpt.getPatternTerminal().setSubstitution(Value.equals("1")); case "PatternTerminal.Invert" -> cpt.getPatternTerminal().setInverted(Value.equals("1")); - case "PatternTerminal.Double" -> cpt.doubleStacks(Value.equals("1")); + case "PatternTerminal.Double" -> cpt.doubleStacks(Integer.parseInt(message.Value)); case "PatternTerminal.Combine" -> cpt.getPatternTerminal().setCombineMode(Value.equals("1")); case "PatternTerminal.beSubstitute" -> cpt.getPatternTerminal().setBeSubstitute(Value.equals("1")); case "PatternTerminal.ActivePage" -> cpt.getPatternTerminal() diff --git a/src/main/java/com/glodblock/github/network/CPacketInventoryAction.java b/src/main/java/com/glodblock/github/network/CPacketInventoryAction.java index c20fc7c98..b4b960839 100644 --- a/src/main/java/com/glodblock/github/network/CPacketInventoryAction.java +++ b/src/main/java/com/glodblock/github/network/CPacketInventoryAction.java @@ -11,6 +11,7 @@ import net.minecraftforge.fluids.FluidStack; import com.glodblock.github.FluidCraft; +import com.glodblock.github.client.gui.container.ContainerPatternMulti; import com.glodblock.github.client.gui.container.ContainerPatternValueAmount; import com.glodblock.github.common.item.ItemFluidPacket; import com.glodblock.github.inventory.InventoryHandler; @@ -105,12 +106,12 @@ public IMessage onMessage(CPacketInventoryAction message, MessageContext ctx) { new BlockPos(te), Objects.requireNonNull(baseContainer.getOpenContext().getSide()), GuiType.FLUID_CRAFTING_AMOUNT); - } else if (target instanceof IWirelessTerminal) { + } else if (target instanceof IWirelessTerminal wt) { InventoryHandler.openGui( sender, sender.worldObj, new BlockPos( - ((IWirelessTerminal) target).getInventorySlot(), + wt.getInventorySlot(), Util.GuiHelper.encodeType(0, Util.GuiHelper.GuiType.ITEM), 0), ForgeDirection.UNKNOWN, @@ -135,12 +136,12 @@ public IMessage onMessage(CPacketInventoryAction message, MessageContext ctx) { new BlockPos(te), Objects.requireNonNull(baseContainer.getOpenContext().getSide()), GuiType.PATTERN_VALUE_SET); - } else if (target instanceof IWirelessTerminal) { + } else if (target instanceof IWirelessTerminal wt) { InventoryHandler.openGui( sender, sender.worldObj, new BlockPos( - ((IWirelessTerminal) target).getInventorySlot(), + wt.getInventorySlot(), Util.GuiHelper.encodeType(0, Util.GuiHelper.GuiType.ITEM), 0), ForgeDirection.UNKNOWN, @@ -160,6 +161,32 @@ public IMessage onMessage(CPacketInventoryAction message, MessageContext ctx) { cpv.detectAndSendChanges(); } } + } else if (message.action == InventoryAction.SET_PATTERN_MULTI) { + final ContainerOpenContext context = baseContainer.getOpenContext(); + if (context != null) { + final TileEntity te = context.getTile(); + if (te != null) { + InventoryHandler.openGui( + sender, + te.getWorldObj(), + new BlockPos(te), + Objects.requireNonNull(baseContainer.getOpenContext().getSide()), + GuiType.GUI_PATTERN_MULTI); + } else if (target instanceof IWirelessTerminal wt) { + InventoryHandler.openGui( + sender, + sender.worldObj, + new BlockPos( + wt.getInventorySlot(), + Util.GuiHelper.encodeType(0, Util.GuiHelper.GuiType.ITEM), + 0), + ForgeDirection.UNKNOWN, + GuiType.GUI_PATTERN_MULTI); + } + if (sender.openContainer instanceof ContainerPatternMulti cpm) { + cpm.detectAndSendChanges(); + } + } } else { baseContainer.doAction(sender, message.action, message.slot, message.id); } diff --git a/src/main/java/com/glodblock/github/network/CPacketPatternMultiSet.java b/src/main/java/com/glodblock/github/network/CPacketPatternMultiSet.java new file mode 100644 index 000000000..346ab3f19 --- /dev/null +++ b/src/main/java/com/glodblock/github/network/CPacketPatternMultiSet.java @@ -0,0 +1,93 @@ +package com.glodblock.github.network; + +import java.util.Objects; + +import net.minecraft.entity.player.EntityPlayerMP; +import net.minecraft.tileentity.TileEntity; +import net.minecraftforge.common.util.ForgeDirection; + +import com.glodblock.github.client.gui.container.ContainerPatternMulti; +import com.glodblock.github.client.gui.container.base.FCContainerEncodeTerminal; +import com.glodblock.github.inventory.InventoryHandler; +import com.glodblock.github.inventory.gui.GuiType; +import com.glodblock.github.inventory.item.IWirelessTerminal; +import com.glodblock.github.util.BlockPos; +import com.glodblock.github.util.Util; + +import appeng.api.networking.IGridHost; +import appeng.container.ContainerOpenContext; +import cpw.mods.fml.common.network.simpleimpl.IMessage; +import cpw.mods.fml.common.network.simpleimpl.IMessageHandler; +import cpw.mods.fml.common.network.simpleimpl.MessageContext; +import io.netty.buffer.ByteBuf; + +public class CPacketPatternMultiSet implements IMessage { + + private static GuiType guiType; + private static int multi; + + public CPacketPatternMultiSet(GuiType guiType) { + this(guiType, 0); + } + + public CPacketPatternMultiSet(GuiType guiType, int multi) { + CPacketPatternMultiSet.guiType = guiType; + CPacketPatternMultiSet.multi = multi; + } + + public CPacketPatternMultiSet() { + // NO-OP + } + + @Override + public void fromBytes(ByteBuf byteBuf) { + guiType = GuiType.getByOrdinal(byteBuf.readByte()); + multi = byteBuf.readInt(); + } + + @Override + public void toBytes(ByteBuf byteBuf) { + byteBuf.writeByte(guiType != null ? guiType.ordinal() : 0); + byteBuf.writeInt(multi); + } + + public static class Handler implements IMessageHandler { + + @Override + public IMessage onMessage(CPacketPatternMultiSet message, MessageContext ctx) { + EntityPlayerMP player = ctx.getServerHandler().playerEntity; + if (player.openContainer instanceof ContainerPatternMulti cpv) { + final Object target = cpv.getTarget(); + if (target instanceof IGridHost) { + final ContainerOpenContext context = cpv.getOpenContext(); + if (context != null) { + final TileEntity te = context.getTile(); + if (te != null) { + InventoryHandler.openGui( + player, + te.getWorldObj(), + new BlockPos(te), + Objects.requireNonNull(cpv.getOpenContext().getSide()), + guiType); + } else if (target instanceof IWirelessTerminal wt) { + InventoryHandler.openGui( + player, + player.worldObj, + new BlockPos( + wt.getInventorySlot(), + Util.GuiHelper.encodeType(0, Util.GuiHelper.GuiType.ITEM), + 0), + ForgeDirection.UNKNOWN, + guiType); + } + if (player.openContainer instanceof FCContainerEncodeTerminal cpt) { + cpt.multiplyOrDivideStacks(multi); + } + } + } + } + return null; + } + } + +} diff --git a/src/main/resources/assets/ae2fc/textures/gui/patternMulti.png b/src/main/resources/assets/ae2fc/textures/gui/patternMulti.png new file mode 100644 index 0000000000000000000000000000000000000000..74874d2e0d0c9081c5b550d1f2b4d3046cd3b238 GIT binary patch literal 811 zcmeAS@N?(olHy`uVBq!ia0y~yU<5K5893O0R7}x|G$6&2?&#~tz_78O`%fY(kk47* z5n0T@z_$a08M7R}Mgs+u zFfI3VaSW-5dwa_Eu&I5Q;oN&(#4cQ6 zTCcUVr3dNMxc9IpWfkT-G@yGywq6 CGQao$ literal 0 HcmV?d00001 From 94be0bc52cf03e224f5b30ec71061a07aaf647dd Mon Sep 17 00:00:00 2001 From: lordIcocain Date: Fri, 27 Dec 2024 11:15:41 +0200 Subject: [PATCH 2/6] conflicts... --- .../base/FCContainerEncodeTerminal.java | 21 ++----------------- 1 file changed, 2 insertions(+), 19 deletions(-) diff --git a/src/main/java/com/glodblock/github/client/gui/container/base/FCContainerEncodeTerminal.java b/src/main/java/com/glodblock/github/client/gui/container/base/FCContainerEncodeTerminal.java index c4a629cf8..57738b7c3 100644 --- a/src/main/java/com/glodblock/github/client/gui/container/base/FCContainerEncodeTerminal.java +++ b/src/main/java/com/glodblock/github/client/gui/container/base/FCContainerEncodeTerminal.java @@ -605,27 +605,9 @@ static void multiplyOrDivideStacksInternal(SlotFake[] slots, int mult) { } } } - return true; - } else if (mult < 0) { - mult = Math.abs(mult); - for (Slot s : slots) { - ItemStack st = s.getStack(); - if (st == null) continue; - final int count; - if (st.getItem() instanceof ItemFluidPacket) { - count = ItemFluidPacket.getFluidAmount(st); - } else { - count = s.getStack().stackSize; - } - if (count % mult != 0) { - return false; - } - } - return true; } - return false; } - + /** * Multiply or divide a number * @@ -637,6 +619,7 @@ public void multiplyOrDivideStacks(int multi) { multiplyOrDivideStacksInternal(this.craftingSlots, multi); multiplyOrDivideStacksInternal(this.outputSlots, multi); } + this.detectAndSendChanges(); } } From c74d7cabd3c84bfb3cd1dc9a83f9a38405306765 Mon Sep 17 00:00:00 2001 From: Alexdoru <57050655+alexdoru@users.noreply.github.com> Date: Fri, 6 Dec 2024 20:30:11 +0200 Subject: [PATCH 3/6] rm --- .../base/FCContainerEncodeTerminal.java | 42 ++++++++++--------- 1 file changed, 23 insertions(+), 19 deletions(-) diff --git a/src/main/java/com/glodblock/github/client/gui/container/base/FCContainerEncodeTerminal.java b/src/main/java/com/glodblock/github/client/gui/container/base/FCContainerEncodeTerminal.java index 57738b7c3..ca5c01dff 100644 --- a/src/main/java/com/glodblock/github/client/gui/container/base/FCContainerEncodeTerminal.java +++ b/src/main/java/com/glodblock/github/client/gui/container/base/FCContainerEncodeTerminal.java @@ -548,29 +548,33 @@ public void doubleStacks(int val) { static boolean canMultiplyOrDivide(SlotFake[] slots, int mult) { if (mult > 0) { for (Slot s : slots) { - if (s.getStack() != null) { - if (s.getStack().getItem() instanceof ItemFluidPacket) { - long result = (long) ItemFluidPacket.getFluidAmount(s.getStack()) * mult; - if (result > Integer.MAX_VALUE) { - return false; - } - } else { - long val = (long) s.getStack().stackSize * mult; - if (val > Integer.MAX_VALUE) return false; - } + ItemStack st = s.getStack(); + if (st == null) continue; + final long count; + if (st.getItem() instanceof ItemFluidPacket) { + count = ItemFluidPacket.getFluidAmount(st); + } else { + count = s.getStack().stackSize; + } + long result = count * mult; + if (result > Integer.MAX_VALUE) { + return false; } } return true; } else if (mult < 0) { - mult = -mult; + mult = Math.abs(mult); for (Slot s : slots) { - if (s.getStack() != null) { // Although % is a very inefficient algorithm, it is not a performance issue - // here. :> - if (s.getStack().getItem() instanceof ItemFluidPacket) { - if (ItemFluidPacket.getFluidAmount(s.getStack()) % mult != 0) return false; - } else { - if (s.getStack().stackSize % mult != 0) return false; - } + ItemStack st = s.getStack(); + if (st == null) continue; + final int count; + if (st.getItem() instanceof ItemFluidPacket) { + count = ItemFluidPacket.getFluidAmount(st); + } else { + count = s.getStack().stackSize; + } + if (count % mult != 0) { + return false; } } return true; @@ -593,7 +597,7 @@ static void multiplyOrDivideStacksInternal(SlotFake[] slots, int mult) { } } } else if (mult < 0) { - mult = -mult; + mult = Math.abs(mult); for (final Slot s : enabledSlots) { ItemStack st = s.getStack(); if (st != null) { From 3f3be51fc4a9d8d4d60017eb89e2b92f887c558c Mon Sep 17 00:00:00 2001 From: lordIcocain Date: Fri, 27 Dec 2024 17:15:26 +0200 Subject: [PATCH 4/6] real --- src/main/java/com/glodblock/github/loader/ChannelLoader.java | 2 -- .../com/glodblock/github/network/CPacketPatternMultiSet.java | 4 ---- 2 files changed, 6 deletions(-) diff --git a/src/main/java/com/glodblock/github/loader/ChannelLoader.java b/src/main/java/com/glodblock/github/loader/ChannelLoader.java index 2527be3b4..1bccece49 100644 --- a/src/main/java/com/glodblock/github/loader/ChannelLoader.java +++ b/src/main/java/com/glodblock/github/loader/ChannelLoader.java @@ -81,8 +81,6 @@ public void run() { Side.SERVER); netHandler .registerMessage(new CPacketPatternMultiSet.Handler(), CPacketPatternMultiSet.class, id++, Side.SERVER); - netHandler - .registerMessage(new CPacketPatternMultiSet.Handler(), CPacketPatternMultiSet.class, id++, Side.CLIENT); } public static void sendPacketToAllPlayers(Packet packet, World world) { diff --git a/src/main/java/com/glodblock/github/network/CPacketPatternMultiSet.java b/src/main/java/com/glodblock/github/network/CPacketPatternMultiSet.java index 346ab3f19..e3656d2bb 100644 --- a/src/main/java/com/glodblock/github/network/CPacketPatternMultiSet.java +++ b/src/main/java/com/glodblock/github/network/CPacketPatternMultiSet.java @@ -26,10 +26,6 @@ public class CPacketPatternMultiSet implements IMessage { private static GuiType guiType; private static int multi; - public CPacketPatternMultiSet(GuiType guiType) { - this(guiType, 0); - } - public CPacketPatternMultiSet(GuiType guiType, int multi) { CPacketPatternMultiSet.guiType = guiType; CPacketPatternMultiSet.multi = multi; From 6cdc25386779ad15c53cadd60757c984d59efaaf Mon Sep 17 00:00:00 2001 From: lordIcocain Date: Fri, 27 Dec 2024 19:51:48 +0200 Subject: [PATCH 5/6] fix --- .../glodblock/github/inventory/ItemBiggerAppEngInventory.java | 4 +++- 1 file changed, 3 insertions(+), 1 deletion(-) diff --git a/src/main/java/com/glodblock/github/inventory/ItemBiggerAppEngInventory.java b/src/main/java/com/glodblock/github/inventory/ItemBiggerAppEngInventory.java index 08a070b18..0ae64beac 100644 --- a/src/main/java/com/glodblock/github/inventory/ItemBiggerAppEngInventory.java +++ b/src/main/java/com/glodblock/github/inventory/ItemBiggerAppEngInventory.java @@ -32,7 +32,9 @@ public void markDirty() { boolean isCraft = Platform.openNbtData(is).getBoolean("craftingMode"); boolean isCraftingTerm = Platform.openNbtData(is).getString("mode_main") .equals(GuiType.WIRELESS_CRAFTING_TERMINAL.toString()); - if (!isCraftingTerm && isCraft) { + boolean isExPattern = Platform.openNbtData(is).getString("mode_main") + .equals(GuiType.WIRELESS_FLUID_PATTERN_TERMINAL_EX.toString()); + if (!isCraftingTerm && !isExPattern && isCraft) { for (int x = 0; x < this.getSizeInventory(); x++) { final ItemStack is = this.getStackInSlot(x); if (is != null) { From 29b000ff5964dbfb2b8b35a7af372ff840a7f2ac Mon Sep 17 00:00:00 2001 From: lordIcocain Date: Fri, 27 Dec 2024 21:21:30 +0200 Subject: [PATCH 6/6] fix --- .../glodblock/github/network/CPacketTransferRecipe.java | 7 ++++--- 1 file changed, 4 insertions(+), 3 deletions(-) diff --git a/src/main/java/com/glodblock/github/network/CPacketTransferRecipe.java b/src/main/java/com/glodblock/github/network/CPacketTransferRecipe.java index f28486e34..721003952 100644 --- a/src/main/java/com/glodblock/github/network/CPacketTransferRecipe.java +++ b/src/main/java/com/glodblock/github/network/CPacketTransferRecipe.java @@ -32,7 +32,8 @@ public class CPacketTransferRecipe implements IMessage { private List> inputs; private List> outputs; private boolean isCraft; - private static final int MAX_INDEX = 32; + private static final int MAX_INDEX = 81; + private static final int MAX_SLOTS_INDEX = 32; private boolean shift; public CPacketTransferRecipe() {} @@ -79,11 +80,11 @@ public void fromBytes(ByteBuf buf) { NBTTagCompound nbt_o = nbt_m.getCompoundTag("o"); for (int i = 0; i < MAX_INDEX; i++) { OrderStack tmp = OrderStack.readFromNBT(nbt_i, null, i); - if (tmp != null) inputs.add(tmp); + if (tmp != null && inputs.size() < MAX_SLOTS_INDEX) inputs.add(tmp); } for (int i = 0; i < MAX_INDEX; i++) { OrderStack tmp = OrderStack.readFromNBT(nbt_o, null, i); - if (tmp != null) outputs.add(tmp); + if (tmp != null && inputs.size() < MAX_SLOTS_INDEX) outputs.add(tmp); } }