diff options
| author | shedaniel <daniel@shedaniel.me> | 2020-07-29 12:25:47 +0800 |
|---|---|---|
| committer | shedaniel <daniel@shedaniel.me> | 2020-07-29 14:25:53 +0800 |
| commit | ba446965dad004cb38679f0f0e1a526151d84213 (patch) | |
| tree | 60fe2736316a63d47cf533a02bf29fbd5045b91c /RoughlyEnoughItems-runtime/src/main/java/me/shedaniel/rei/impl/BaseBoundsHandlerImpl.java | |
| parent | 929ca0ed6de9dd25208304cd0f51a8f2d0f22ceb (diff) | |
| download | RoughlyEnoughItems-ba446965dad004cb38679f0f0e1a526151d84213.tar.gz RoughlyEnoughItems-ba446965dad004cb38679f0f0e1a526151d84213.tar.bz2 RoughlyEnoughItems-ba446965dad004cb38679f0f0e1a526151d84213.zip | |
5.x - 20w30a
Signed-off-by: shedaniel <daniel@shedaniel.me>
Diffstat (limited to 'RoughlyEnoughItems-runtime/src/main/java/me/shedaniel/rei/impl/BaseBoundsHandlerImpl.java')
| -rw-r--r-- | RoughlyEnoughItems-runtime/src/main/java/me/shedaniel/rei/impl/BaseBoundsHandlerImpl.java | 116 |
1 files changed, 116 insertions, 0 deletions
diff --git a/RoughlyEnoughItems-runtime/src/main/java/me/shedaniel/rei/impl/BaseBoundsHandlerImpl.java b/RoughlyEnoughItems-runtime/src/main/java/me/shedaniel/rei/impl/BaseBoundsHandlerImpl.java new file mode 100644 index 000000000..eacc92a96 --- /dev/null +++ b/RoughlyEnoughItems-runtime/src/main/java/me/shedaniel/rei/impl/BaseBoundsHandlerImpl.java @@ -0,0 +1,116 @@ +/* + * 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.impl; + +import com.google.common.collect.Lists; +import me.shedaniel.math.Rectangle; +import me.shedaniel.rei.api.BaseBoundsHandler; +import me.shedaniel.rei.api.DisplayHelper; +import me.shedaniel.rei.gui.config.DisplayPanelLocation; +import net.fabricmc.api.EnvType; +import net.fabricmc.api.Environment; +import net.minecraft.client.MinecraftClient; +import net.minecraft.client.gui.screen.Screen; +import net.minecraft.util.ActionResult; +import net.minecraft.util.Pair; +import org.jetbrains.annotations.ApiStatus; + +import java.util.Comparator; +import java.util.List; +import java.util.function.Supplier; + +@ApiStatus.Internal +@Environment(EnvType.CLIENT) +public class BaseBoundsHandlerImpl implements BaseBoundsHandler { + + private static final Comparator<? super Rectangle> RECTANGLE_COMPARER = Comparator.comparingLong(Rectangle::hashCode); + + private long lastArea = -1; + private List<Pair<Pair<Class<?>, Float>, Supplier<List<Rectangle>>>> list = Lists.newArrayList(); + + @Override + public boolean isHandingScreen(Class<?> screen) { + return Screen.class.isAssignableFrom(screen); + } + + @Override + public float getPriority() { + return -5f; + } + + @Override + public ActionResult isInZone(double mouseX, double mouseY) { + Class<? extends Screen> screenClass = MinecraftClient.getInstance().currentScreen.getClass(); + for (Pair<Pair<Class<?>, Float>, Supplier<List<Rectangle>>> pair : list) { + if (pair.getLeft().getLeft().isAssignableFrom(screenClass)) + for (Rectangle zone : pair.getRight().get()) + if (zone.contains(mouseX, mouseY)) + return ActionResult.FAIL; + } + return ActionResult.PASS; + } + + @Override + public boolean shouldRecalculateArea(DisplayPanelLocation location, Rectangle rectangle) { + long current = currentHashCode(location); + if (lastArea == current) + return false; + lastArea = current; + return true; + } + + private long currentHashCode(DisplayPanelLocation location) { + return areasHashCode(DisplayHelper.getInstance().getOverlayBounds(location, MinecraftClient.getInstance().currentScreen), getExclusionZones(MinecraftClient.getInstance().currentScreen.getClass(), false)); + } + + @Override + public List<Rectangle> getExclusionZones(Class<?> currentScreenClass, boolean sort) { + List<Rectangle> rectangles = Lists.newArrayList(); + for (Pair<Pair<Class<?>, Float>, Supplier<List<Rectangle>>> pair : list) { + if (pair.getLeft().getLeft().isAssignableFrom(currentScreenClass)) + rectangles.addAll(pair.getRight().get()); + } + if (sort) + rectangles.sort(RECTANGLE_COMPARER); + return rectangles; + } + + @Override + public int supplierSize() { + return list.size(); + } + + @Override + public void registerExclusionZones(Class<?> screenClass, Supplier<List<Rectangle>> supplier) { + list.add(new Pair<>(new Pair<>(screenClass, 0f), supplier)); + } + + private long areasHashCode(Rectangle rectangle, List<Rectangle> exclusionZones) { + int hashCode = 31 + (rectangle == null ? 0 : rectangle.hashCode()); + for (Rectangle e : exclusionZones) + hashCode = 31 * hashCode + (e == null ? 0 : e.hashCode()); + return hashCode; + } + +} |
