From d3da6122bb4dcb114e200bc267c56f903f582cd0 Mon Sep 17 00:00:00 2001 From: LostLuma Date: Sun, 27 Oct 2024 18:15:15 +0100 Subject: [PATCH] Add error toast with hints --- .../impl/feature/battery/BaseToast.java | 75 +++++++++++++++++++ .../impl/feature/battery/BatteryToast.java | 60 ++------------- .../impl/feature/battery/BatteryTracker.java | 13 ++++ .../impl/feature/battery/ErrorToast.java | 22 ++++++ .../assets/dynamic_fps/lang/en_us.json | 4 + 5 files changed, 121 insertions(+), 53 deletions(-) create mode 100644 platforms/common/src/main/java/dynamic_fps/impl/feature/battery/BaseToast.java create mode 100644 platforms/common/src/main/java/dynamic_fps/impl/feature/battery/ErrorToast.java diff --git a/platforms/common/src/main/java/dynamic_fps/impl/feature/battery/BaseToast.java b/platforms/common/src/main/java/dynamic_fps/impl/feature/battery/BaseToast.java new file mode 100644 index 00000000..a37d9e1e --- /dev/null +++ b/platforms/common/src/main/java/dynamic_fps/impl/feature/battery/BaseToast.java @@ -0,0 +1,75 @@ +package dynamic_fps.impl.feature.battery; + +import dynamic_fps.impl.util.ResourceLocations; +import net.minecraft.client.Minecraft; +import net.minecraft.client.gui.Font; +import net.minecraft.client.gui.GuiGraphics; +import net.minecraft.client.gui.components.toasts.Toast; +import net.minecraft.client.gui.components.toasts.ToastManager; +import net.minecraft.client.renderer.RenderType; +import net.minecraft.network.chat.Component; +import net.minecraft.resources.ResourceLocation; +import org.jetbrains.annotations.NotNull; +import org.jetbrains.annotations.Nullable; + +public class BaseToast implements Toast { + private long firstRender; + private Visibility visibility; + + protected Component title; + protected Component description; + protected @Nullable ResourceLocation icon; + + private static final ResourceLocation MOD_ICON = ResourceLocations.of("dynamic_fps", "textures/battery/toast/background_icon.png"); + private static final ResourceLocation BACKGROUND_IMAGE = ResourceLocations.of("dynamic_fps", "textures/battery/toast/background.png"); + + protected BaseToast(Component title, Component description, @Nullable ResourceLocation icon) { + this.title = title; + this.description = description; + + this.icon = icon; + + this.visibility = Visibility.SHOW; + } + + @Override + public @NotNull Visibility getWantedVisibility() { + return this.visibility; + } + + @Override + public void update(ToastManager toastManager, long currentTime) { + if (this.firstRender == 0) { + return; + } + + if (currentTime - this.firstRender >= 5000.0 * toastManager.getNotificationDisplayTimeMultiplier()) { + this.visibility = Visibility.HIDE; + } + } + + @Override + public void render(GuiGraphics graphics, Font font, long currentTime) { + if (this.firstRender == 0) { + this.onFirstRender(); + this.firstRender = currentTime; + } + + // type, resource, x, y, ?, ?, width, height, width, height + graphics.blit(RenderType::guiTextured, BACKGROUND_IMAGE, 0, 0, 0.0f, 0, this.width(), this.height(), this.width(), this.height()); + + int x = 8; + + if (this.icon != null) { + x += 22; + + graphics.blit(RenderType::guiTextured, MOD_ICON, 2, 2, 0.0f, 0, 8, 8, 8, 8); + graphics.blit(RenderType::guiTextured, this.icon, 8, 8, 0.0f, 0, 16, 16, 16, 16); + } + + graphics.drawString(Minecraft.getInstance().font, this.title, x, 7, 0x5f3315, false); + graphics.drawString(Minecraft.getInstance().font, this.description, x, 18, -16777216, false); + } + + public void onFirstRender() {} +} diff --git a/platforms/common/src/main/java/dynamic_fps/impl/feature/battery/BatteryToast.java b/platforms/common/src/main/java/dynamic_fps/impl/feature/battery/BatteryToast.java index 6e7bd494..4d2427cf 100644 --- a/platforms/common/src/main/java/dynamic_fps/impl/feature/battery/BatteryToast.java +++ b/platforms/common/src/main/java/dynamic_fps/impl/feature/battery/BatteryToast.java @@ -1,35 +1,16 @@ package dynamic_fps.impl.feature.battery; -import dynamic_fps.impl.util.ResourceLocations; import net.minecraft.client.Minecraft; -import net.minecraft.client.gui.Font; -import net.minecraft.client.gui.GuiGraphics; -import net.minecraft.client.gui.components.toasts.Toast; -import net.minecraft.client.gui.components.toasts.ToastManager; -import net.minecraft.client.renderer.RenderType; import net.minecraft.network.chat.Component; import net.minecraft.resources.ResourceLocation; -import org.jetbrains.annotations.NotNull; import static dynamic_fps.impl.util.Localization.localized; -public class BatteryToast implements Toast { - private long firstRender; - - private Component title; - private Component description; - private ResourceLocation icon; - private Visibility visibility; - +public class BatteryToast extends BaseToast { private static BatteryToast queuedToast; - private static final ResourceLocation MOD_ICON = ResourceLocations.of("dynamic_fps", "textures/battery/toast/background_icon.png"); - private static final ResourceLocation BACKGROUND_IMAGE = ResourceLocations.of("dynamic_fps", "textures/battery/toast/background.png"); - private BatteryToast(Component title, ResourceLocation icon) { - this.title = title; - this.icon = icon; - this.visibility = Visibility.SHOW; + super(title, Component.empty(), icon); } /** @@ -47,39 +28,12 @@ public static void queueToast(Component title, ResourceLocation icon) { } @Override - public @NotNull Visibility getWantedVisibility() { - return this.visibility; - } - - @Override - public void update(ToastManager toastManager, long currentTime) { - if (this.firstRender == 0) { - return; - } - - if (currentTime - this.firstRender >= 5000.0 * toastManager.getNotificationDisplayTimeMultiplier()) { - this.visibility = Visibility.HIDE; - } - } - - @Override - public void render(GuiGraphics graphics, Font font, long currentTime) { - if (this.firstRender == 0) { - if (this == queuedToast) { - queuedToast = null; - } - - this.firstRender = currentTime; - // Initialize when first rendering so the battery percentage is mostly up-to-date - this.description = localized("toast", "battery_charge", BatteryTracker.charge()); + public void onFirstRender() { + if (this == queuedToast) { + queuedToast = null; } - // resource, x, y, z, ?, ?, width, height, width, height - graphics.blit(RenderType::guiTextured, BACKGROUND_IMAGE, 0, 0, 0.0f, 0, this.width(), this.height(), this.width(), this.height()); - - graphics.blit(RenderType::guiTextured, MOD_ICON, 2, 2, 0.0f, 0, 8, 8, 8, 8); - graphics.blit(RenderType::guiTextured, this.icon, 8, 8, 0.0f, 0, 16, 16, 16, 16); - graphics.drawString(Minecraft.getInstance().font, this.title, 30, 7, 0x5f3315, false); - graphics.drawString(Minecraft.getInstance().font, this.description, 30, 18, -16777216, false); + // Initialize when first rendering so the battery percentage is mostly up-to-date + this.description = localized("toast", "battery_charge", BatteryTracker.charge()); } } diff --git a/platforms/common/src/main/java/dynamic_fps/impl/feature/battery/BatteryTracker.java b/platforms/common/src/main/java/dynamic_fps/impl/feature/battery/BatteryTracker.java index 52d7c40a..52c89be3 100644 --- a/platforms/common/src/main/java/dynamic_fps/impl/feature/battery/BatteryTracker.java +++ b/platforms/common/src/main/java/dynamic_fps/impl/feature/battery/BatteryTracker.java @@ -10,6 +10,7 @@ import net.lostluma.battery.api.exception.LibraryLoadError; import net.lostluma.battery.api.util.LibraryUtil; import net.minecraft.client.Minecraft; +import net.minecraft.network.chat.Component; import org.jetbrains.annotations.Nullable; import java.io.IOException; @@ -18,6 +19,8 @@ import java.util.Collection; import java.util.Collections; +import static dynamic_fps.impl.util.Localization.localized; + public class BatteryTracker { private static boolean readInitialData = false; @@ -166,6 +169,16 @@ private static Manager createManager() { } catch (LibraryLoadError e) { // No native backend library is available for this OS or platform Logging.getLogger().warn("Battery tracker feature unavailable!"); + + String path; + + if (DynamicFPSConfig.INSTANCE.downloadNatives()) { + path = "no_support"; + } else { + path = "no_library"; + } + + ErrorToast.queueToast(localized("toast", path)); } return result; diff --git a/platforms/common/src/main/java/dynamic_fps/impl/feature/battery/ErrorToast.java b/platforms/common/src/main/java/dynamic_fps/impl/feature/battery/ErrorToast.java new file mode 100644 index 00000000..a827e2a2 --- /dev/null +++ b/platforms/common/src/main/java/dynamic_fps/impl/feature/battery/ErrorToast.java @@ -0,0 +1,22 @@ +package dynamic_fps.impl.feature.battery; + +import net.minecraft.client.Minecraft; +import net.minecraft.network.chat.Component; + +import static dynamic_fps.impl.util.Localization.localized; + +public class ErrorToast extends BaseToast { + private static final Component TITLE = localized("toast", "error"); + + private ErrorToast(Component description) { + super(TITLE, description, null); + } + + /** + * Queue some information to be shown as a toast. + */ + public static void queueToast(Component description) { + ErrorToast toast = new ErrorToast(description); + Minecraft.getInstance().getToastManager().addToast(toast); + } +} diff --git a/platforms/common/src/main/resources/assets/dynamic_fps/lang/en_us.json b/platforms/common/src/main/resources/assets/dynamic_fps/lang/en_us.json index 4ba7252e..9592d94e 100644 --- a/platforms/common/src/main/resources/assets/dynamic_fps/lang/en_us.json +++ b/platforms/common/src/main/resources/assets/dynamic_fps/lang/en_us.json @@ -86,6 +86,10 @@ "gui.dynamic_fps.hud.reducing": "Dynamic FPS: Forcing Reduced FPS", "gui.dynamic_fps.hud.disabled": "Dynamic FPS Disabled", + "toast.dynamic_fps.error": "Dynamic FPS Battery Error", + "toast.dynamic_fps.no_support": "Computer is not supported", + "toast.dynamic_fps.no_library": "Library download disabled", + "toast.dynamic_fps.battery_charging": "Charging!", "toast.dynamic_fps.battery_draining": "Discharging!", "toast.dynamic_fps.battery_critical": "Battery Low!",