From 490a2e3fdd124562ed09f048beec5178555a36a4 Mon Sep 17 00:00:00 2001 From: shedaniel Date: Fri, 21 Feb 2020 22:12:48 +0800 Subject: 4.0.4 Signed-off-by: shedaniel --- .../me/shedaniel/rei/impl/DisplayHelperImpl.java | 25 +++++++++++++--------- 1 file changed, 15 insertions(+), 10 deletions(-) (limited to 'src/main/java/me/shedaniel/rei/impl/DisplayHelperImpl.java') diff --git a/src/main/java/me/shedaniel/rei/impl/DisplayHelperImpl.java b/src/main/java/me/shedaniel/rei/impl/DisplayHelperImpl.java index 77fa4fe80..fd73aa6bd 100644 --- a/src/main/java/me/shedaniel/rei/impl/DisplayHelperImpl.java +++ b/src/main/java/me/shedaniel/rei/impl/DisplayHelperImpl.java @@ -10,8 +10,11 @@ import com.google.common.collect.Maps; import me.shedaniel.math.api.Rectangle; import me.shedaniel.rei.api.BaseBoundsHandler; import me.shedaniel.rei.api.DisplayHelper; +import me.shedaniel.rei.api.OverlayDecider; +import me.shedaniel.rei.utils.CollectionUtils; import org.jetbrains.annotations.ApiStatus; +import java.util.Collections; import java.util.Comparator; import java.util.List; import java.util.Map; @@ -20,7 +23,7 @@ import java.util.stream.Collectors; @ApiStatus.Internal public class DisplayHelperImpl implements DisplayHelper { - private static final Comparator> BOUNDS_HANDLER_COMPARATOR; + private static final Comparator BOUNDS_HANDLER_COMPARATOR; private static final DisplayBoundsHandler EMPTY = new DisplayBoundsHandler() { @Override public Class getBaseSupportedClass() { @@ -44,29 +47,30 @@ public class DisplayHelperImpl implements DisplayHelper { }; static { - Comparator> comparator = Comparator.comparingDouble(DisplayBoundsHandler::getPriority); + Comparator comparator = Comparator.comparingDouble(OverlayDecider::getPriority); BOUNDS_HANDLER_COMPARATOR = comparator.reversed(); } - private List> screenDisplayBoundsHandlers = Lists.newArrayList(); + private List screenDisplayBoundsHandlers = Lists.newArrayList(); private Map, DisplayBoundsHandler> handlerCache = Maps.newHashMap(); private Map, List>> handlerSortedCache = Maps.newHashMap(); private BaseBoundsHandler baseBoundsHandler; private Class tempScreen; + @SuppressWarnings("rawtypes") @Override public List> getSortedBoundsHandlers(Class screenClass) { List> possibleCached = handlerSortedCache.get(screenClass); if (possibleCached != null) return possibleCached; tempScreen = screenClass; - handlerSortedCache.put(screenClass, screenDisplayBoundsHandlers.stream().filter(this::filterResponsible).sorted(BOUNDS_HANDLER_COMPARATOR).collect(Collectors.toList())); + handlerSortedCache.put(screenClass, (List) CollectionUtils.castAndMap(CollectionUtils.filter(screenDisplayBoundsHandlers, this::filterResponsible), DisplayBoundsHandler.class)); return handlerSortedCache.get(screenClass); } @Override - public List> getAllBoundsHandlers() { - return screenDisplayBoundsHandlers; + public List getAllOverlayDeciders() { + return Collections.unmodifiableList(screenDisplayBoundsHandlers); } @Override @@ -79,13 +83,14 @@ public class DisplayHelperImpl implements DisplayHelper { return handlerCache.get(screenClass); } - private boolean filterResponsible(DisplayBoundsHandler handler) { - return handler.getBaseSupportedClass().isAssignableFrom(tempScreen); + private boolean filterResponsible(OverlayDecider handler) { + return handler.isHandingScreen(tempScreen); } @Override - public void registerBoundsHandler(DisplayBoundsHandler handler) { - screenDisplayBoundsHandlers.add(handler); + public void registerHandler(OverlayDecider decider) { + screenDisplayBoundsHandlers.add(decider); + screenDisplayBoundsHandlers.sort(BOUNDS_HANDLER_COMPARATOR); } @Override -- cgit