123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191 |
- /*
- * Copyright (c) 2018, 2019, 2020 shedaniel
- * Licensed under the MIT License (the "License").
- */
- package me.shedaniel.rei.gui.widget;
- import com.mojang.blaze3d.systems.RenderSystem;
- import me.shedaniel.math.api.Point;
- import me.shedaniel.math.api.Rectangle;
- import me.shedaniel.rei.impl.ScreenHelper;
- import net.minecraft.client.gui.Element;
- import net.minecraft.client.sound.PositionedSoundInstance;
- import net.minecraft.sound.SoundEvents;
- import net.minecraft.text.LiteralText;
- import net.minecraft.text.Text;
- import net.minecraft.util.Identifier;
- import net.minecraft.util.math.MathHelper;
- import java.util.Collections;
- import java.util.List;
- import java.util.Objects;
- import java.util.Optional;
- import java.util.function.Consumer;
- import java.util.function.Supplier;
- public abstract class ButtonWidget extends WidgetWithBounds {
-
- protected static final Identifier BUTTON_LOCATION = new Identifier("roughlyenoughitems", "textures/gui/button.png");
- protected static final Identifier BUTTON_LOCATION_DARK = new Identifier("roughlyenoughitems", "textures/gui/button_dark.png");
- public boolean enabled = true;
- public boolean focused = false;
- private boolean canChangeFocuses = true;
- private String text;
- private Rectangle bounds;
- private Supplier<String> tooltipSupplier;
-
- protected ButtonWidget(Rectangle rectangle, Text text) {
- this.bounds = Objects.requireNonNull(rectangle);
- this.text = Objects.requireNonNull(text).asFormattedString();
- }
-
- public static ButtonWidget create(Rectangle point, String text, Consumer<ButtonWidget> onClick) {
- return create(point, new LiteralText(text), onClick);
- }
-
- public static ButtonWidget create(Rectangle point, Text text, Consumer<ButtonWidget> onClick) {
- ButtonWidget[] widget = {null};
- widget[0] = new ButtonWidget(point, text) {
- @Override
- public void onPressed() {
- onClick.accept(widget[0]);
- }
- };
- return widget[0];
- }
-
- public ButtonWidget tooltip(Supplier<String> tooltipSupplier) {
- this.tooltipSupplier = tooltipSupplier;
- return this;
- }
-
- public ButtonWidget enabled(boolean enabled) {
- this.enabled = enabled;
- return this;
- }
-
- public ButtonWidget canChangeFocuses(boolean canChangeFocuses) {
- this.canChangeFocuses = canChangeFocuses;
- return this;
- }
-
- public boolean canChangeFocuses() {
- return canChangeFocuses;
- }
-
- public Rectangle getBounds() {
- return bounds;
- }
-
- public String getText() {
- return text;
- }
-
- public void setText(String text) {
- this.text = text;
- }
-
- protected int getTextureId(boolean boolean_1) {
- int int_1 = 1;
- if (!this.enabled) {
- int_1 = 0;
- } else if (boolean_1) {
- int_1 = 4; // 2 is the old blue highlight, 3 is the 1.15 outline, 4 is the 1.15 online + light hover
- }
-
- return int_1;
- }
-
- protected void renderBackground(int x, int y, int width, int height, int textureOffset) {
- minecraft.getTextureManager().bindTexture(ScreenHelper.isDarkModeEnabled() ? BUTTON_LOCATION_DARK : BUTTON_LOCATION);
- RenderSystem.color4f(1.0F, 1.0F, 1.0F, 1.0F);
- RenderSystem.enableBlend();
- RenderSystem.blendFuncSeparate(770, 771, 1, 0);
- RenderSystem.blendFunc(770, 771);
- //Four Corners
- blit(x, y, getBlitOffset(), 0, textureOffset * 80, 4, 4, 512, 256);
- blit(x + width - 4, y, getBlitOffset(), 252, textureOffset * 80, 4, 4, 512, 256);
- blit(x, y + height - 4, getBlitOffset(), 0, textureOffset * 80 + 76, 4, 4, 512, 256);
- blit(x + width - 4, y + height - 4, getBlitOffset(), 252, textureOffset * 80 + 76, 4, 4, 512, 256);
-
- //Sides
- blit(x + 4, y, getBlitOffset(), 4, textureOffset * 80, MathHelper.ceil((width - 8) / 2f), 4, 512, 256);
- blit(x + 4, y + height - 4, getBlitOffset(), 4, textureOffset * 80 + 76, MathHelper.ceil((width - 8) / 2f), 4, 512, 256);
- blit(x + 4 + MathHelper.ceil((width - 8) / 2f), y + height - 4, getBlitOffset(), 252 - MathHelper.floor((width - 8) / 2f), textureOffset * 80 + 76, MathHelper.floor((width - 8) / 2f), 4, 512, 256);
- blit(x + 4 + MathHelper.ceil((width - 8) / 2f), y, getBlitOffset(), 252 - MathHelper.floor((width - 8) / 2f), textureOffset * 80, MathHelper.floor((width - 8) / 2f), 4, 512, 256);
- for (int i = y + 4; i < y + height - 4; i += 76) {
- blit(x, i, getBlitOffset(), 0, 4 + textureOffset * 80, MathHelper.ceil(width / 2f), MathHelper.clamp(y + height - 4 - i, 0, 76), 512, 256);
- blit(x + MathHelper.ceil(width / 2f), i, getBlitOffset(), 256 - MathHelper.floor(width / 2f), 4 + textureOffset * 80, MathHelper.floor(width / 2f), MathHelper.clamp(y + height - 4 - i, 0, 76), 512, 256);
- }
- }
-
- @Override
- public void render(int mouseX, int mouseY, float delta) {
- int x = bounds.x, y = bounds.y, width = bounds.width, height = bounds.height;
- renderBackground(x, y, width, height, this.getTextureId(isHovered(mouseX, mouseY)));
-
- int color = 14737632;
- if (!this.enabled) {
- color = 10526880;
- } else if (isHovered(mouseX, mouseY)) {
- color = 16777120;
- }
-
- this.drawCenteredString(font, getText(), x + width / 2, y + (height - 8) / 2, color);
-
- if (getTooltips().isPresent())
- if (!focused && containsMouse(mouseX, mouseY))
- ScreenHelper.getLastOverlay().addTooltip(QueuedTooltip.create(getTooltips().get().split("\n")));
- else if (focused)
- ScreenHelper.getLastOverlay().addTooltip(QueuedTooltip.create(new Point(x + width / 2, y + height / 2), getTooltips().get().split("\n")));
- }
-
- public boolean isHovered(int mouseX, int mouseY) {
- return isMouseOver(mouseX, mouseY) || focused;
- }
-
- @Override
- public boolean changeFocus(boolean boolean_1) {
- if (!enabled || !canChangeFocuses)
- return false;
- this.focused = !this.focused;
- return true;
- }
-
- @Override
- public List<? extends Element> children() {
- return Collections.emptyList();
- }
-
- @Override
- public boolean mouseClicked(double mouseX, double mouseY, int button) {
- if (isMouseOver(mouseX, mouseY) && enabled && button == 0) {
- minecraft.getSoundManager().play(PositionedSoundInstance.master(SoundEvents.UI_BUTTON_CLICK, 1.0F));
- onPressed();
- return true;
- }
- return false;
- }
-
- @Override
- public boolean keyPressed(int int_1, int int_2, int int_3) {
- if (this.enabled && focused) {
- if (int_1 != 257 && int_1 != 32 && int_1 != 335) {
- return false;
- } else {
- minecraft.getSoundManager().play(PositionedSoundInstance.master(SoundEvents.UI_BUTTON_CLICK, 1.0F));
- this.onPressed();
- return true;
- }
- }
- return false;
- }
-
- public abstract void onPressed();
-
- public Optional<String> getTooltips() {
- return Optional.ofNullable(tooltipSupplier).map(Supplier::get);
- }
-
- }
|