PonderUI addon accessibility

- PonderUI constructor is now protected to allow addons to make subclasses
- renderWidgets now calls protected sub-methods for different parts of overlay rendering
This commit is contained in:
Grimmauld 2022-08-05 12:13:55 +02:00
parent 9c8df2ff27
commit 3536394bdd

View file

@ -133,7 +133,7 @@ public class PonderUI extends NavigatableSimiScreen {
return ui; return ui;
} }
PonderUI(List<PonderScene> scenes) { protected PonderUI(List<PonderScene> scenes) {
ResourceLocation component = scenes.get(0) ResourceLocation component = scenes.get(0)
.getComponent(); .getComponent();
if (ForgeRegistries.ITEMS.containsKey(component)) if (ForgeRegistries.ITEMS.containsKey(component))
@ -567,65 +567,8 @@ public class PonderUI extends NavigatableSimiScreen {
noWidgetsHovered &= !child.isMouseOver(mouseX, mouseY); noWidgetsHovered &= !child.isMouseOver(mouseX, mouseY);
int tooltipColor = Theme.i(Theme.Key.TEXT_DARKER); int tooltipColor = Theme.i(Theme.Key.TEXT_DARKER);
{ renderChapterTitle(ms, fade, indexDiff, activeScene, tooltipColor);
// Chapter title renderNavigationMenu(ms);
ms.pushPose();
ms.translate(0, 0, 400);
int x = 31 + 20 + 8;
int y = 31;
String title = activeScene.getTitle();
int wordWrappedHeight = font.wordWrapHeight(title, left.x - 51);
int streakHeight = 35 - 9 + wordWrappedHeight;
UIRenderHelper.streak(ms, 0, x - 4, y - 12 + streakHeight / 2, streakHeight, (int) (150 * fade));
UIRenderHelper.streak(ms, 180, x - 4, y - 12 + streakHeight / 2, streakHeight, (int) (30 * fade));
new BoxElement().withBackground(Theme.c(Theme.Key.PONDER_BACKGROUND_FLAT))
.gradientBorder(Theme.p(Theme.Key.PONDER_IDLE))
.at(21, 21, 100)
.withBounds(30, 30)
.render(ms);
GuiGameElement.of(stack)
.scale(2)
.at(x - 39, y - 11)
.render(ms);
font.draw(ms, Lang.translateDirect(PONDERING), x, y - 6, tooltipColor);
y += 8;
x += 0;
ms.translate(x, y, 0);
ms.mulPose(Vector3f.XN.rotationDegrees(indexDiff * -75));
ms.translate(0, 0, 5);
FontHelper.drawSplitString(ms, font, title, 0, 0, left.x - 51, Theme.c(Theme.Key.TEXT)
.scaleAlpha(1 - indexDiff)
.getRGB());
ms.popPose();
if (chapter != null) {
ms.pushPose();
ms.translate(chap.x - 4 - 4, chap.y, 0);
UIRenderHelper.streak(ms, 180, 4, 10, 26, (int) (150 * fade));
drawRightAlignedString(font, ms, Lang.translateDirect(IN_CHAPTER)
.getString(), 0, 0, tooltipColor);
drawRightAlignedString(font, ms, chapter.getTitle(), 0, 12, Theme.i(Theme.Key.TEXT));
ms.popPose();
}
Color c1 = Theme.c(Theme.Key.PONDER_BACK_ARROW)
.setAlpha(0x40);
Color c2 = Theme.c(Theme.Key.PONDER_BACK_ARROW)
.setAlpha(0x20);
Color c3 = Theme.c(Theme.Key.PONDER_BACK_ARROW)
.setAlpha(0x10);
UIRenderHelper.breadcrumbArrow(ms, width / 2 - 20, height - 51, 0, 20, 20, 5, c1, c2);
UIRenderHelper.breadcrumbArrow(ms, width / 2 + 20, height - 51, 0, -20, 20, -5, c1, c2);
UIRenderHelper.breadcrumbArrow(ms, width / 2 - 90, height - 51, 0, 70, 20, 5, c1, c3);
UIRenderHelper.breadcrumbArrow(ms, width / 2 + 90, height - 51, 0, -70, 20, -5, c1, c3);
}
if (identifyMode) { if (identifyMode) {
if (noWidgetsHovered && mouseY < height - 80) { if (noWidgetsHovered && mouseY < height - 80) {
@ -637,17 +580,8 @@ public class PonderUI extends NavigatableSimiScreen {
((MutableComponent) minecraft.options.keyDrop.getTranslatedKeyMessage()) ((MutableComponent) minecraft.options.keyDrop.getTranslatedKeyMessage())
.withStyle(ChatFormatting.WHITE)) .withStyle(ChatFormatting.WHITE))
.withStyle(ChatFormatting.GRAY); .withStyle(ChatFormatting.GRAY);
// renderOrderedTooltip(ms, textRenderer.wrapLines(text, width / 3), 0, 0);
renderComponentTooltip(ms, font.getSplitter() renderComponentTooltip(ms, font.getSplitter()
.splitLines(text, width / 3, Style.EMPTY), 0, 0, font); .splitLines(text, width / 3, Style.EMPTY), 0, 0, font);
/*
* String tooltip = Lang .createTranslationTextComponent(IDENTIFY_MODE,
* client.gameSettings.keyBindDrop.getBoundKeyLocalizedText().applyTextStyle(
* TextFormatting.WHITE)) .applyTextStyle(TextFormatting.GRAY)
* .getFormattedText(); renderTooltip(font.listFormattedStringToWidth(tooltip,
* width / 3), 0, 0);
*/
} else } else
renderTooltip(ms, hoveredTooltipItem, 0, 0); renderTooltip(ms, hoveredTooltipItem, 0, 0);
if (hoveredBlockPos != null && PonderIndex.editingModeActive() && !userViewMode) { if (hoveredBlockPos != null && PonderIndex.editingModeActive() && !userViewMode) {
@ -677,30 +611,12 @@ public class PonderUI extends NavigatableSimiScreen {
else else
slowMode.dim(); slowMode.dim();
{ renderSceneOverlay(ms, partialTicks, lazyIndexValue, indexDiff);
// Scene overlay
float scenePT = skipCooling > 0 ? 0 : partialTicks;
ms.pushPose();
ms.translate(0, 0, 100);
renderOverlay(ms, index, scenePT);
if (indexDiff > 1 / 512f)
renderOverlay(ms, lazyIndexValue < index ? index - 1 : index + 1, scenePT);
ms.popPose();
}
boolean finished = activeScene.isFinished(); boolean finished = activeScene.isFinished();
// Next up: if (finished) {
if (finished && nextScene != null && nextUp.getValue() > 1 / 16f && !nextScene.getId() jumpToNextScene(ms, partialTicks, nextScene);
.equals(Create.asResource("creative_motor_mojang"))) {
ms.pushPose();
ms.translate(right.x + 10, right.y - 6 + nextUp.getValue(partialTicks) * 5, 400);
int boxWidth = (Math.max(font.width(nextScene.getTitle()), font.width(Lang.translateDirect(NEXT_UP))) + 5);
renderSpeechBox(ms, 0, 0, boxWidth, 20, right.isHoveredOrFocused(), Pointing.DOWN, false);
ms.translate(0, -29, 100);
drawCenteredString(ms, font, Lang.translateDirect(NEXT_UP), 0, 0, Theme.i(Theme.Key.TEXT_DARKER));
drawCenteredString(ms, font, nextScene.getTitle(), 0, 10, Theme.i(Theme.Key.TEXT));
ms.popPose();
} }
// Widgets // Widgets
@ -725,6 +641,13 @@ public class PonderUI extends NavigatableSimiScreen {
nextUp.updateChaseTarget(0); nextUp.updateChaseTarget(0);
} }
renderPonderTags(ms, mouseX, mouseY, partialTicks, fade, activeScene);
renderHoverTooltips(ms, tooltipColor);
RenderSystem.enableDepthTest();
}
protected void renderPonderTags(PoseStack ms, int mouseX, int mouseY, float partialTicks, float fade, PonderScene activeScene) {
// Tags // Tags
List<PonderTag> sceneTags = activeScene.getTags(); List<PonderTag> sceneTags = activeScene.getTags();
boolean highlightAll = sceneTags.contains(PonderTag.Highlight.ALL); boolean highlightAll = sceneTags.contains(PonderTag.Highlight.ALL);
@ -765,7 +688,34 @@ public class PonderUI extends NavigatableSimiScreen {
ms.popPose(); ms.popPose();
}); });
}
protected void renderSceneOverlay(PoseStack ms, float partialTicks, float lazyIndexValue, float indexDiff) {
// Scene overlay
float scenePT = skipCooling > 0 ? 0 : partialTicks;
ms.pushPose();
ms.translate(0, 0, 100);
renderOverlay(ms, index, scenePT);
if (indexDiff > 1 / 512f)
renderOverlay(ms, lazyIndexValue < index ? index - 1 : index + 1, scenePT);
ms.popPose();
}
protected void jumpToNextScene(PoseStack ms, float partialTicks, PonderScene nextScene) {
if (nextScene != null && nextUp.getValue() > 1 / 16f && !nextScene.getId()
.equals(Create.asResource("creative_motor_mojang"))) {
ms.pushPose();
ms.translate(right.x + 10, right.y - 6 + nextUp.getValue(partialTicks) * 5, 400);
int boxWidth = (Math.max(font.width(nextScene.getTitle()), font.width(Lang.translateDirect(NEXT_UP))) + 5);
renderSpeechBox(ms, 0, 0, boxWidth, 20, right.isHoveredOrFocused(), Pointing.DOWN, false);
ms.translate(0, -29, 100);
drawCenteredString(ms, font, Lang.translateDirect(NEXT_UP), 0, 0, Theme.i(Theme.Key.TEXT_DARKER));
drawCenteredString(ms, font, nextScene.getTitle(), 0, 10, Theme.i(Theme.Key.TEXT));
ms.popPose();
}
}
protected void renderHoverTooltips(PoseStack ms, int tooltipColor) {
ms.pushPose(); ms.pushPose();
ms.translate(0, 0, 500); ms.translate(0, 0, 500);
int tooltipY = height - 16; int tooltipY = height - 16;
@ -784,8 +734,67 @@ public class PonderUI extends NavigatableSimiScreen {
if (PonderIndex.editingModeActive() && userMode.isHoveredOrFocused()) if (PonderIndex.editingModeActive() && userMode.isHoveredOrFocused())
drawCenteredString(ms, font, "Editor View", userMode.x + 10, tooltipY, tooltipColor); drawCenteredString(ms, font, "Editor View", userMode.x + 10, tooltipY, tooltipColor);
ms.popPose(); ms.popPose();
}
RenderSystem.enableDepthTest(); protected void renderChapterTitle(PoseStack ms, float fade, float indexDiff, PonderScene activeScene, int tooltipColor) {
// Chapter title
ms.pushPose();
ms.translate(0, 0, 400);
int x = 31 + 20 + 8;
int y = 31;
String title = activeScene.getTitle();
int wordWrappedHeight = font.wordWrapHeight(title, left.x - 51);
int streakHeight = 35 - 9 + wordWrappedHeight;
UIRenderHelper.streak(ms, 0, x - 4, y - 12 + streakHeight / 2, streakHeight, (int) (150 * fade));
UIRenderHelper.streak(ms, 180, x - 4, y - 12 + streakHeight / 2, streakHeight, (int) (30 * fade));
new BoxElement().withBackground(Theme.c(Theme.Key.PONDER_BACKGROUND_FLAT))
.gradientBorder(Theme.p(Theme.Key.PONDER_IDLE))
.at(21, 21, 100)
.withBounds(30, 30)
.render(ms);
GuiGameElement.of(stack)
.scale(2)
.at(x - 39f, y - 11f)
.render(ms);
font.draw(ms, Lang.translateDirect(PONDERING), x, y - 6, tooltipColor);
y += 8;
x += 0;
ms.translate(x, y, 0);
ms.mulPose(Vector3f.XN.rotationDegrees(indexDiff * -75));
ms.translate(0, 0, 5);
FontHelper.drawSplitString(ms, font, title, 0, 0, left.x - 51, Theme.c(Theme.Key.TEXT)
.scaleAlpha(1 - indexDiff)
.getRGB());
ms.popPose();
if (chapter != null) {
ms.pushPose();
ms.translate(chap.x - 8, chap.y, 0);
UIRenderHelper.streak(ms, 180, 4, 10, 26, (int) (150 * fade));
drawRightAlignedString(font, ms, Lang.translateDirect(IN_CHAPTER)
.getString(), 0, 0, tooltipColor);
drawRightAlignedString(font, ms, chapter.getTitle(), 0, 12, Theme.i(Theme.Key.TEXT));
ms.popPose();
}
}
protected void renderNavigationMenu(PoseStack ms) {
Color c1 = Theme.c(Theme.Key.PONDER_BACK_ARROW)
.setAlpha(0x40);
Color c2 = Theme.c(Theme.Key.PONDER_BACK_ARROW)
.setAlpha(0x20);
Color c3 = Theme.c(Theme.Key.PONDER_BACK_ARROW)
.setAlpha(0x10);
UIRenderHelper.breadcrumbArrow(ms, width / 2 - 20, height - 51, 0, 20, 20, 5, c1, c2);
UIRenderHelper.breadcrumbArrow(ms, width / 2 + 20, height - 51, 0, -20, 20, -5, c1, c2);
UIRenderHelper.breadcrumbArrow(ms, width / 2 - 90, height - 51, 0, 70, 20, 5, c1, c3);
UIRenderHelper.breadcrumbArrow(ms, width / 2 + 90, height - 51, 0, -70, 20, -5, c1, c3);
} }
private void renderOverlay(PoseStack ms, int i, float partialTicks) { private void renderOverlay(PoseStack ms, int i, float partialTicks) {