diff options
Diffstat (limited to 'src/main/java/me/shedaniel/rei/gui/ContainerGuiOverlay.java')
| -rw-r--r-- | src/main/java/me/shedaniel/rei/gui/ContainerGuiOverlay.java | 105 |
1 files changed, 81 insertions, 24 deletions
diff --git a/src/main/java/me/shedaniel/rei/gui/ContainerGuiOverlay.java b/src/main/java/me/shedaniel/rei/gui/ContainerGuiOverlay.java index 42bd77bf5..3ffd95238 100644 --- a/src/main/java/me/shedaniel/rei/gui/ContainerGuiOverlay.java +++ b/src/main/java/me/shedaniel/rei/gui/ContainerGuiOverlay.java @@ -1,16 +1,16 @@ package me.shedaniel.rei.gui; -import me.shedaniel.rei.RoughlyEnoughItemsCore; +import com.mojang.blaze3d.platform.GlStateManager; import me.shedaniel.rei.client.ClientHelper; -import me.shedaniel.rei.gui.widget.IWidget; -import me.shedaniel.rei.gui.widget.ItemListOverlay; -import me.shedaniel.rei.gui.widget.LabelWidget; -import me.shedaniel.rei.gui.widget.QueuedTooltip; +import me.shedaniel.rei.gui.widget.*; import me.shedaniel.rei.listeners.IMixinContainerGui; import net.minecraft.client.MinecraftClient; import net.minecraft.client.gui.ContainerGui; import net.minecraft.client.gui.Gui; -import net.minecraft.client.gui.widget.ButtonWidget; +import net.minecraft.client.gui.GuiEventListener; +import net.minecraft.client.gui.widget.TextFieldWidget; +import net.minecraft.client.render.GuiLighting; +import net.minecraft.client.resource.language.I18n; import net.minecraft.client.util.Window; import net.minecraft.util.math.MathHelper; @@ -20,14 +20,15 @@ import java.util.List; public class ContainerGuiOverlay extends Gui { + private static int page = 0; + private final List<IWidget> widgets; + private final List<QueuedTooltip> queuedTooltips; private Rectangle rectangle; private IMixinContainerGui containerGui; private Window window; - private static int page = 0; - private final List<IWidget> widgets; private ItemListOverlay itemListOverlay; private ButtonWidget buttonLeft, buttonRight; - private final List<QueuedTooltip> queuedTooltips; + private TextFieldWidget searchField; public ContainerGuiOverlay(ContainerGui containerGui) { this.queuedTooltips = new ArrayList<>(); @@ -36,6 +37,7 @@ public class ContainerGuiOverlay extends Gui { } public void onInitialized() { + String searchTerm = searchField != null ? searchField.getText() : ""; //Update Variables this.widgets.clear(); this.window = MinecraftClient.getInstance().window; @@ -44,23 +46,36 @@ public class ContainerGuiOverlay extends Gui { this.rectangle = calculateBoundary(); widgets.add(this.itemListOverlay = new ItemListOverlay(this, containerGui, page)); - this.itemListOverlay.updateList(getItemListArea(), page); - addButton(buttonLeft = new ButtonWidget(-1, rectangle.x, rectangle.y + 3, 16, 20, "<") { + this.itemListOverlay.updateList(getItemListArea(), page, searchTerm); + widgets.add(buttonLeft = new ButtonWidget(rectangle.x, rectangle.y + 5, 16, 16, "<") { @Override - public void onPressed(double double_1, double double_2) { + public void onPressed(int button, double mouseX, double mouseY) { page--; if (page < 0) page = getTotalPage(); - itemListOverlay.updateList(getItemListArea(), page); + itemListOverlay.updateList(getItemListArea(), page, searchField.getText()); } }); - addButton(buttonRight = new ButtonWidget(-1, rectangle.x + rectangle.width - 18, rectangle.y + 3, 16, 20, ">") { + widgets.add(buttonRight = new ButtonWidget(rectangle.x + rectangle.width - 18, rectangle.y + 5, 16, 16, ">") { @Override - public void onPressed(double double_1, double double_2) { + public void onPressed(int button, double mouseX, double mouseY) { page++; if (page > getTotalPage()) page = 0; - itemListOverlay.updateList(getItemListArea(), page); + itemListOverlay.updateList(getItemListArea(), page, searchField.getText()); + } + }); + page = MathHelper.clamp(page, 0, getTotalPage()); + widgets.add(new ButtonWidget(10, 10, 40, 20, "") { + @Override + public void draw(int int_1, int int_2, float float_1) { + this.text = getCheatModeText(); + super.draw(int_1, int_2, float_1); + } + + @Override + public void onPressed(int button, double mouseX, double mouseY) { + ClientHelper.setCheating(!ClientHelper.isCheating()); } }); this.widgets.add(new LabelWidget(rectangle.x + (rectangle.width / 2), rectangle.y + 10, "") { @@ -70,10 +85,29 @@ public class ContainerGuiOverlay extends Gui { super.draw(mouseX, mouseY, partialTicks); } }); + Rectangle textFieldArea = getTextFieldArea(); + this.listeners.add(searchField = new TextFieldWidget(-1, MinecraftClient.getInstance().fontRenderer, + (int) textFieldArea.getX(), (int) textFieldArea.getY(), (int) textFieldArea.getWidth(), (int) textFieldArea.getHeight())); + searchField.setChangedListener((id, text) -> { + itemListOverlay.updateList(page, text); + }); + searchField.setText(searchTerm); this.listeners.addAll(widgets); } + private Rectangle getTextFieldArea() { + if (MinecraftClient.getInstance().currentGui instanceof RecipeViewingWidget) { + RecipeViewingWidget widget = (RecipeViewingWidget) MinecraftClient.getInstance().currentGui; + return new Rectangle(widget.getBounds().x, window.getScaledHeight() - 22, widget.getBounds().width, 18); + } + return new Rectangle(containerGui.getContainerLeft(), window.getScaledHeight() - 22, containerGui.getContainerWidth(), 18); + } + + private String getCheatModeText() { + return I18n.translate(String.format("%s%s", "text.rei.", ClientHelper.isCheating() ? "cheat" : "nocheat")); + } + private Rectangle getItemListArea() { return new Rectangle(rectangle.x + 2, rectangle.y + 24, rectangle.width - 4, rectangle.height - 27); } @@ -83,9 +117,14 @@ public class ContainerGuiOverlay extends Gui { } public void render(int mouseX, int mouseY, float partialTicks) { - draw(mouseX, mouseY, partialTicks); + GlStateManager.color4f(1.0F, 1.0F, 1.0F, 1.0F); + GuiLighting.disable(); + this.draw(mouseX, mouseY, partialTicks); + GuiLighting.disable(); queuedTooltips.forEach(queuedTooltip -> containerGui.getContainerGui().drawTooltip(queuedTooltip.text, queuedTooltip.mouse.x, queuedTooltip.mouse.y)); queuedTooltips.clear(); + GuiLighting.disable(); + searchField.render(mouseX, mouseY, partialTicks); } public void addTooltip(QueuedTooltip queuedTooltip) { @@ -94,28 +133,37 @@ public class ContainerGuiOverlay extends Gui { @Override public void draw(int int_1, int int_2, float float_1) { - widgets.forEach(widget -> widget.draw(int_1, int_2, float_1)); + widgets.forEach(widget -> { + GuiLighting.disable(); + widget.draw(int_1, int_2, float_1); + }); + GuiLighting.disable(); itemListOverlay.draw(int_1, int_2, float_1); + GuiLighting.disable(); super.draw(int_1, int_2, float_1); } private Rectangle calculateBoundary() { int startX = containerGui.getContainerLeft() + containerGui.getContainerWidth() + 10; int width = window.getScaledWidth() - startX; + if (MinecraftClient.getInstance().currentGui instanceof RecipeViewingWidget) { + RecipeViewingWidget widget = (RecipeViewingWidget) MinecraftClient.getInstance().currentGui; + width = window.getScaledWidth() - (widget.getBounds().x + widget.getBounds().width + 10); + } return new Rectangle(startX, 0, width, window.getScaledHeight()); } private int getTotalPage() { - return MathHelper.ceil(ClientHelper.getItemList().size() / itemListOverlay.getTotalSlotsPerPage()); + return MathHelper.ceil(itemListOverlay.getCurrentDisplayed().size() / itemListOverlay.getTotalSlotsPerPage()); } @Override public boolean mouseScrolled(double amount) { if (rectangle.contains(ClientHelper.getMouseLocation())) { if (amount > 0 && buttonLeft.enabled) - buttonLeft.onPressed(0, 0); + buttonLeft.onPressed(0, 0, 0); else if (amount < 0 && buttonRight.enabled) - buttonRight.onPressed(0, 0); + buttonRight.onPressed(0, 0, 0); else return false; return true; } @@ -126,10 +174,19 @@ public class ContainerGuiOverlay extends Gui { } @Override - public boolean mouseClicked(double double_1, double double_2, int int_1) { - for(IWidget widget : widgets) - if (widget.mouseClicked(double_1, double_2, int_1)) + public boolean keyPressed(int int_1, int int_2, int int_3) { + for(GuiEventListener listener : listeners) + if (listener.keyPressed(int_1, int_2, int_3)) return true; return false; } + + @Override + public boolean charTyped(char char_1, int int_1) { + for(GuiEventListener listener : listeners) + if (listener.charTyped(char_1, int_1)) + return true; + return super.charTyped(char_1, int_1); + } + } |
