From 08d80d588a36598114087a79917e36e9d2cc97c3 Mon Sep 17 00:00:00 2001 From: shedaniel Date: Tue, 24 Dec 2019 11:31:40 +0800 Subject: Finishing workstation usage and close #220 --- .../me/shedaniel/rei/gui/widget/EntryWidget.java | 58 +++++++++++----------- 1 file changed, 29 insertions(+), 29 deletions(-) (limited to 'src/main/java/me/shedaniel/rei/gui/widget/EntryWidget.java') diff --git a/src/main/java/me/shedaniel/rei/gui/widget/EntryWidget.java b/src/main/java/me/shedaniel/rei/gui/widget/EntryWidget.java index 6adecb987..efec1fa66 100644 --- a/src/main/java/me/shedaniel/rei/gui/widget/EntryWidget.java +++ b/src/main/java/me/shedaniel/rei/gui/widget/EntryWidget.java @@ -21,77 +21,77 @@ import java.util.Collections; import java.util.List; public class EntryWidget extends WidgetWithBounds { - + protected static final Identifier RECIPE_GUI = new Identifier("roughlyenoughitems", "textures/gui/recipecontainer.png"); protected static final Identifier RECIPE_GUI_DARK = new Identifier("roughlyenoughitems", "textures/gui/recipecontainer_dark.png"); - + protected boolean highlight = true; protected boolean tooltips = true; protected boolean background = true; protected boolean interactable = true; private Rectangle bounds; private List entryStacks; - + protected EntryWidget(int x, int y) { this.bounds = new Rectangle(x - 1, y - 1, 18, 18); this.entryStacks = new ArrayList<>(); } - + public static EntryWidget create(int x, int y) { return new EntryWidget(x, y); } - + public EntryWidget disableInteractions() { return interactable(false); } - + public EntryWidget interactable(boolean b) { interactable = b; return this; } - + public EntryWidget noHighlight() { return highlight(false); } - + public EntryWidget highlight(boolean b) { highlight = b; return this; } - + public EntryWidget noTooltips() { return tooltips(false); } - + public EntryWidget tooltips(boolean b) { tooltips = b; return this; } - + public EntryWidget noBackground() { return background(false); } - + public EntryWidget background(boolean b) { background = b; return this; } - + public EntryWidget clearStacks() { entryStacks.clear(); return this; } - + public EntryWidget entry(EntryStack stack) { entryStacks.add(stack); return this; } - + public EntryWidget entries(Collection stacks) { entryStacks.addAll(stacks); return this; } - + protected EntryStack getCurrentEntry() { if (entryStacks.isEmpty()) return EntryStack.empty(); @@ -99,27 +99,27 @@ public class EntryWidget extends WidgetWithBounds { return entryStacks.get(0); return entryStacks.get(MathHelper.floor((System.currentTimeMillis() / 500 % (double) entryStacks.size()) / 1f)); } - + public List entries() { return entryStacks; } - + @Override public Rectangle getBounds() { return bounds; } - + protected Rectangle getInnerBounds() { return new Rectangle(bounds.x + 1, bounds.y + 1, bounds.width - 2, bounds.height - 2); } - + @Override public void render(int mouseX, int mouseY, float delta) { if (background) { drawBackground(mouseX, mouseY, delta); } drawCurrentEntry(mouseX, mouseY, delta); - + boolean highlighted = containsMouse(mouseX, mouseY); if (tooltips && highlighted) { queueTooltip(mouseX, mouseY, delta); @@ -128,29 +128,29 @@ public class EntryWidget extends WidgetWithBounds { drawHighlighted(mouseX, mouseY, delta); } } - + protected void drawBackground(int mouseX, int mouseY, float delta) { minecraft.getTextureManager().bindTexture(ScreenHelper.isDarkModeEnabled() ? RECIPE_GUI_DARK : RECIPE_GUI); blit(bounds.x, bounds.y, 0, 222, bounds.width, bounds.height); } - + protected void drawCurrentEntry(int mouseX, int mouseY, float delta) { EntryStack entry = getCurrentEntry(); entry.setZ(100); entry.render(getInnerBounds(), mouseX, mouseY, delta); } - + protected void queueTooltip(int mouseX, int mouseY, float delta) { QueuedTooltip tooltip = getCurrentTooltip(mouseX, mouseY); if (tooltip != null) { ScreenHelper.getLastOverlay().addTooltip(tooltip); } } - + public QueuedTooltip getCurrentTooltip(int mouseX, int mouseY) { return getCurrentEntry().getTooltip(mouseX, mouseY); } - + protected void drawHighlighted(int mouseX, int mouseY, float delta) { RenderSystem.disableDepthTest(); RenderSystem.colorMask(true, true, true, false); @@ -162,12 +162,12 @@ public class EntryWidget extends WidgetWithBounds { RenderSystem.colorMask(true, true, true, true); RenderSystem.enableDepthTest(); } - + @Override public List children() { return Collections.emptyList(); } - + @Override public boolean mouseClicked(double mouseX, double mouseY, int button) { if (!interactable) @@ -179,7 +179,7 @@ public class EntryWidget extends WidgetWithBounds { return ClientHelper.getInstance().executeUsageKeyBind(getCurrentEntry()); return false; } - + @Override public boolean keyPressed(int int_1, int int_2, int int_3) { if (!interactable) -- cgit