Skip to content

Commit

Permalink
fix: dynamically determine tooltip Z-level based on active panels
Browse files Browse the repository at this point in the history
  • Loading branch information
desht committed Jun 27, 2024
1 parent c95f8dc commit 9ea4fa2
Show file tree
Hide file tree
Showing 4 changed files with 16 additions and 14 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -349,6 +349,10 @@ private Panel getDoubleClickTarget() {
return modalPanels.isEmpty() ? this : modalPanels.peekFirst();
}

public int getMaxZLevel() {
return modalPanels.stream().map(ModalPanel::getExtraZlevel).max(Integer::compare).orElse(0);
}

@Override
public boolean mousePressed(MouseButton button) {
if (button == MouseButton.BACK) {
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -137,15 +137,16 @@ protected void renderLabels(GuiGraphics graphics, int mouseX, int mouseY) {

wrappedGui.addMouseOverText(tooltipList);

int zLevel = wrappedGui.getMaxZLevel() + 100;

graphics.pose().pushPose();
if (!tooltipList.shouldRender()) {
wrappedGui.getIngredientUnderMouse().ifPresent(underMouse -> {
if (underMouse.tooltip()) {
var ingredient = underMouse.ingredient();
if (ingredient instanceof ItemStack stack && !stack.isEmpty()) {
graphics.pose().pushPose();
graphics.pose().translate(0, 0, tooltipList.zOffsetItemTooltip);
graphics.pose().translate(0, 0, zLevel);
graphics.renderTooltip(theme.getFont(), (ItemStack) ingredient, mouseX, mouseY);
graphics.pose().popPose();
}
}
});
Expand All @@ -154,12 +155,12 @@ protected void renderLabels(GuiGraphics graphics, int mouseX, int mouseY) {
.reduce((c1, c2) -> c1.copy().append("\n").append(c2))
.orElse(Component.empty())
);
graphics.pose().translate(0, 0, 600);
graphics.pose().translate(0, 0, zLevel);
graphics.setColor(1f, 1f, 1f, 0.8f);
graphics.renderTooltip(theme.getFont(), lines, DefaultTooltipPositioner.INSTANCE, mouseX, Math.max(mouseY, 18));
graphics.setColor(1f, 1f, 1f, 1f);
graphics.pose().translate(0, 0, -600);
}
graphics.pose().popPose();

tooltipList.reset();

Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -119,25 +119,26 @@ public void render(GuiGraphics graphics, int mouseX, int mouseY, float partialTi

wrappedGui.addMouseOverText(tooltipList);

int zLevel = wrappedGui.getMaxZLevel() + 100;

graphics.pose().pushPose();
if (!tooltipList.shouldRender()) {
wrappedGui.getIngredientUnderMouse().ifPresent(underMouse -> {
if (underMouse.tooltip()) {
var ingredient = underMouse.ingredient();
if (ingredient instanceof ItemStack stack && !stack.isEmpty()) {
graphics.pose().pushPose();
graphics.pose().translate(0, 0, tooltipList.zOffsetItemTooltip);
graphics.pose().translate(0, 0, zLevel);
graphics.renderTooltip(theme.getFont(), (ItemStack) ingredient, mouseX, mouseY);
graphics.pose().popPose();
}
}
});
} else {
graphics.pose().translate(0, 0, 600);
graphics.pose().translate(0, 0, zLevel);
graphics.setColor(1f, 1f, 1f, 0.8f);
graphics.renderTooltip(theme.getFont(), tooltipList.getLines(), Optional.empty(), mouseX, Math.max(mouseY, 18));
graphics.setColor(1f, 1f, 1f, 1f);
graphics.pose().translate(0, 0, -600);
}
graphics.pose().popPose();

tooltipList.reset();
}
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -9,8 +9,6 @@

public class TooltipList {
private final List<Component> lines = new ArrayList<>();
public int zOffset = 950;
public int zOffsetItemTooltip = 0;
public int backgroundColor = 0xC0100010;
public int borderColorStart = 0x505000FF;
public int borderColorEnd = (borderColorStart & 0xFEFEFE) >> 1 | borderColorStart & 0xFF000000;
Expand All @@ -24,8 +22,6 @@ public boolean shouldRender() {

public void reset() {
lines.clear();
zOffset = 950;
zOffsetItemTooltip = 0;
backgroundColor = 0xC0100010;
borderColorStart = 0x505000FF;
borderColorEnd = (borderColorStart & 0xFEFEFE) >> 1 | borderColorStart & 0xFF000000;
Expand Down

0 comments on commit 9ea4fa2

Please sign in to comment.