From 550fe32e612801daa99493aa0bade083f3330133 Mon Sep 17 00:00:00 2001 From: shedaniel Date: Wed, 18 Mar 2020 00:35:36 +0800 Subject: 4.0.14: Better widgets system Signed-off-by: shedaniel --- .../me/shedaniel/rei/api/widgets/BaseWidget.java | 30 ++++++++++++++++++++++ 1 file changed, 30 insertions(+) create mode 100644 src/main/java/me/shedaniel/rei/api/widgets/BaseWidget.java (limited to 'src/main/java/me/shedaniel/rei/api/widgets/BaseWidget.java') diff --git a/src/main/java/me/shedaniel/rei/api/widgets/BaseWidget.java b/src/main/java/me/shedaniel/rei/api/widgets/BaseWidget.java new file mode 100644 index 000000000..fe6212473 --- /dev/null +++ b/src/main/java/me/shedaniel/rei/api/widgets/BaseWidget.java @@ -0,0 +1,30 @@ +package me.shedaniel.rei.api.widgets; + +import me.shedaniel.math.Point; +import me.shedaniel.rei.gui.widget.WidgetWithBounds; +import org.jetbrains.annotations.NotNull; +import org.jetbrains.annotations.Nullable; + +import java.util.function.BiPredicate; + +public abstract class BaseWidget> extends WidgetWithBounds { + @Nullable + private BiPredicate containsMousePredicate; + + public final void setContainsMousePredicate(@Nullable BiPredicate predicate) { + this.containsMousePredicate = predicate; + } + + @NotNull + public final T containsMousePredicate(@Nullable BiPredicate predicate) { + setContainsMousePredicate(predicate); + return (T) this; + } + + @Override + public boolean containsMouse(double mouseX, double mouseY) { + if (containsMousePredicate != null) + return containsMousePredicate.test((T) this, new Point(mouseX, mouseY)); + return super.containsMouse(mouseX, mouseY); + } +} -- cgit