From ba446965dad004cb38679f0f0e1a526151d84213 Mon Sep 17 00:00:00 2001 From: shedaniel Date: Wed, 29 Jul 2020 12:25:47 +0800 Subject: 5.x - 20w30a Signed-off-by: shedaniel --- .../me/shedaniel/rei/gui/OverlaySearchField.java | 179 --------------------- 1 file changed, 179 deletions(-) delete mode 100644 src/main/java/me/shedaniel/rei/gui/OverlaySearchField.java (limited to 'src/main/java/me/shedaniel/rei/gui/OverlaySearchField.java') diff --git a/src/main/java/me/shedaniel/rei/gui/OverlaySearchField.java b/src/main/java/me/shedaniel/rei/gui/OverlaySearchField.java deleted file mode 100644 index ef8d2a6ec..000000000 --- a/src/main/java/me/shedaniel/rei/gui/OverlaySearchField.java +++ /dev/null @@ -1,179 +0,0 @@ -/* - * This file is licensed under the MIT License, part of Roughly Enough Items. - * Copyright (c) 2018, 2019, 2020 shedaniel - * - * Permission is hereby granted, free of charge, to any person obtaining a copy - * of this software and associated documentation files (the "Software"), to deal - * in the Software without restriction, including without limitation the rights - * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell - * copies of the Software, and to permit persons to whom the Software is - * furnished to do so, subject to the following conditions: - * - * The above copyright notice and this permission notice shall be included in all - * copies or substantial portions of the Software. - * - * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR - * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, - * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE - * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER - * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, - * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE - * SOFTWARE. - */ - -package me.shedaniel.rei.gui; - -import com.google.common.collect.Lists; -import com.mojang.blaze3d.systems.RenderSystem; -import me.shedaniel.math.Point; -import me.shedaniel.math.impl.PointHelper; -import me.shedaniel.rei.api.REIHelper; -import me.shedaniel.rei.gui.widget.TextFieldWidget; -import me.shedaniel.rei.impl.ScreenHelper; -import net.minecraft.client.MinecraftClient; -import net.minecraft.client.resource.language.I18n; -import net.minecraft.client.sound.PositionedSoundInstance; -import net.minecraft.client.util.InputUtil; -import net.minecraft.client.util.math.MatrixStack; -import net.minecraft.sound.SoundEvents; -import net.minecraft.util.Pair; -import org.jetbrains.annotations.ApiStatus; - -import java.util.List; - -@ApiStatus.Internal -public class OverlaySearchField extends TextFieldWidget { - - public static boolean isSearching = false; - public long keybindFocusTime = -1; - public int keybindFocusKey = -1; - public boolean isMain = true; - protected Pair lastClickedDetails = null; - private List history = Lists.newArrayListWithCapacity(100); - - public OverlaySearchField(int x, int y, int width, int height) { - super(x, y, width, height); - setMaxLength(10000); - } - - @Override - public void setFocused(boolean boolean_1) { - if (isFocused() != boolean_1 && isMain) - addToHistory(getText()); - super.setFocused(boolean_1); - } - - @ApiStatus.Internal - public void addToHistory(String text) { - if (!text.isEmpty()) { - history.removeIf(str -> str.equalsIgnoreCase(text)); - history.add(text); - if (history.size() > 100) - history.remove(0); - } - } - - public void laterRender(MatrixStack matrices, int int_1, int int_2, float float_1) { - RenderSystem.disableDepthTest(); - setEditableColor(isMain && ContainerScreenOverlay.getEntryListWidget().getAllStacks().isEmpty() && !getText().isEmpty() ? 16733525 : isSearching && isMain ? -852212 : (containsMouse(PointHelper.ofMouse()) || isFocused()) ? (REIHelper.getInstance().isDarkThemeEnabled() ? -17587 : -1) : -6250336); - setSuggestion(!isFocused() && getText().isEmpty() ? I18n.translate("text.rei.search.field.suggestion") : null); - super.render(matrices, int_1, int_2, float_1); - RenderSystem.enableDepthTest(); - } - - @Override - protected void renderSuggestion(MatrixStack matrices, int x, int y) { - if (containsMouse(PointHelper.ofMouse()) || isFocused()) - this.font.drawWithShadow(matrices, this.font.trimToWidth(this.getSuggestion(), this.getWidth()), x, y, REIHelper.getInstance().isDarkThemeEnabled() ? 0xccddaa3d : 0xddeaeaea); - else - this.font.drawWithShadow(matrices, this.font.trimToWidth(this.getSuggestion(), this.getWidth()), x, y, -6250336); - } - - @Override - public void renderBorder(MatrixStack matrices) { - if (isMain && isSearching) { - fill(matrices, this.getBounds().x - 1, this.getBounds().y - 1, this.getBounds().x + this.getBounds().width + 1, this.getBounds().y + this.getBounds().height + 1, -852212); - } else if (isMain && ContainerScreenOverlay.getEntryListWidget().getAllStacks().isEmpty() && !getText().isEmpty()) { - fill(matrices, this.getBounds().x - 1, this.getBounds().y - 1, this.getBounds().x + this.getBounds().width + 1, this.getBounds().y + this.getBounds().height + 1, -43691); - } else { - super.renderBorder(matrices); - return; - } - fill(matrices, this.getBounds().x, this.getBounds().y, this.getBounds().x + this.getBounds().width, this.getBounds().y + this.getBounds().height, -16777216); - } - - public int getManhattanDistance(Point point1, Point point2) { - int e = Math.abs(point1.getX() - point2.getX()); - int f = Math.abs(point1.getY() - point2.getY()); - return e + f; - } - - @Override - public boolean mouseClicked(double double_1, double double_2, int int_1) { - boolean contains = containsMouse(double_1, double_2); - if (isVisible() && contains && int_1 == 1) - setText(""); - if (contains && int_1 == 0 && isMain) - if (lastClickedDetails == null) - lastClickedDetails = new Pair<>(System.currentTimeMillis(), new Point(double_1, double_2)); - else if (System.currentTimeMillis() - lastClickedDetails.getLeft() > 1500) - lastClickedDetails = null; - else if (getManhattanDistance(lastClickedDetails.getRight(), new Point(double_1, double_2)) <= 25) { - lastClickedDetails = null; - isSearching = !isSearching; - minecraft.getSoundManager().play(PositionedSoundInstance.master(SoundEvents.UI_BUTTON_CLICK, 1.0F)); - } else { - lastClickedDetails = new Pair<>(System.currentTimeMillis(), new Point(double_1, double_2)); - } - return super.mouseClicked(double_1, double_2, int_1); - } - - @Override - public boolean keyPressed(int int_1, int int_2, int int_3) { - if (this.isVisible() && this.isFocused() && isMain) - if (int_1 == 257 || int_1 == 335) { - addToHistory(getText()); - setFocused(false); - return true; - } else if (int_1 == 264) { - int i = history.indexOf(getText()) - 1; - if (i < -1 && getText().isEmpty()) - i = history.size() - 1; - else if (i < -1) { - addToHistory(getText()); - i = history.size() - 2; - } - if (i >= 0) { - setText(history.get(i)); - return true; - } - } else if (int_1 == 265) { - int i = history.indexOf(getText()) + 1; - if (i > 0) { - setText(i < history.size() ? history.get(i) : ""); - return true; - } - } - return super.keyPressed(int_1, int_2, int_3); - } - - @Override - public boolean charTyped(char char_1, int int_1) { - if (System.currentTimeMillis() - keybindFocusTime < 1000 && InputUtil.isKeyPressed(MinecraftClient.getInstance().getWindow().getHandle(), keybindFocusKey)) { - keybindFocusTime = -1; - keybindFocusKey = -1; - return true; - } - return super.charTyped(char_1, int_1); - } - - @Override - public boolean containsMouse(double mouseX, double mouseY) { - return (!isMain || ScreenHelper.getLastOverlay().isNotInExclusionZones(mouseX, mouseY)) && super.containsMouse(mouseX, mouseY); - } - - @Override - public void render(MatrixStack matrices, int mouseX, int mouseY, float delta) { - } - -} -- cgit