From 8a56e51889b7947ebecf7780308b762c65731273 Mon Sep 17 00:00:00 2001 From: LostLuma Date: Sat, 17 Feb 2024 19:48:30 +0100 Subject: [PATCH] 1.17.0 NOTE: HUD overlay and debug overlay info doesn't render on Forge. --- gradle/libs.versions.toml | 22 +++++----- .../dynamic_fps/impl/compat/ClothConfig.java | 14 +++--- .../java/dynamic_fps/impl/mixin/GuiMixin.java | 16 ------- .../impl/mixin/MinecraftMixin.java | 2 +- .../impl/mixin/ToastComponentMixin.java | 14 +++--- .../dynamic_fps/impl/service/Services.java | 9 ++-- .../impl/util/HudInfoRenderer.java | 23 ++++------ .../dynamic_fps/impl/util/Localization.java | 4 +- .../java/dynamic_fps/impl/util/Logging.java | 6 +-- .../dynamic_fps/impl/util/OptionsHolder.java | 41 +++++++++--------- .../impl/fabric/mixin/GuiMixin.java | 27 ++++++++++++ .../main/resources/dynamic_fps.mixins.json | 1 + .../fabric/src/main/resources/fabric.mod.json | 7 +-- platforms/forge/build.gradle | 2 + .../impl/forge/DynamicFPSForgeMod.java | 21 +++++---- .../impl/forge/mixin/GameRendererMixin.java | 39 +++++++++++++++++ .../src/main/resources/META-INF/mods.toml | 5 +-- .../main/resources/dynamic_fps.mixins.json | 4 +- .../forge/src/main/resources/dynamic_fps.png | Bin 0 -> 6871 bytes .../impl/quilt/mixin/GuiMixin.java | 27 ++++++++++++ .../main/resources/dynamic_fps.mixins.json | 1 + .../quilt/src/main/resources/quilt.mod.json | 4 +- settings.gradle | 4 +- 23 files changed, 186 insertions(+), 107 deletions(-) create mode 100644 platforms/fabric/src/main/java/net/lostluma/dynamic_fps/impl/fabric/mixin/GuiMixin.java create mode 100644 platforms/forge/src/main/java/net/lostluma/dynamic_fps/impl/forge/mixin/GameRendererMixin.java create mode 100644 platforms/forge/src/main/resources/dynamic_fps.png create mode 100644 platforms/quilt/src/main/java/net/lostluma/dynamic_fps/impl/quilt/mixin/GuiMixin.java diff --git a/gradle/libs.versions.toml b/gradle/libs.versions.toml index d6fea4e4..bd4febdf 100644 --- a/gradle/libs.versions.toml +++ b/gradle/libs.versions.toml @@ -1,22 +1,22 @@ [versions] -minecraft = "1.20.4" +minecraft = "1.17.1" # Platform libraries fabric_loader = "0.15.6" -fabric_api = "0.96.1+1.20.4" +fabric_api = "0.46.1+1.17" -forge = "1.20.4-49.0.30" +forge = "1.17.1-37.1.1" -neoforge = "20.4.160-beta" +# neoforge = "20.4.160-beta" -quilt_loader = "0.23.1" -quilt_standard_libraries = "7.0.0-alpha.10+1.20.2" +# quilt_loader = "0.23.1" +# quilt_standard_libraries = "1.1.0-beta.26+1.18.2" # Third-party libraries -modmenu = "9.0.0" -cloth_config = "13.0.121" +modmenu = "2.0.17" +cloth_config = "5.3.63" mixinextras = "0.3.5" @@ -30,10 +30,10 @@ fabric_loader = { module = "net.fabricmc:fabric-loader", version.ref = "fabric_l forge = { module = "net.minecraftforge:forge", version.ref = "forge" } -neoforge = { module = "net.neoforged:neoforge", version.ref = "neoforge" } +# neoforge = { module = "net.neoforged:neoforge", version.ref = "neoforge" } -quilt_loader = { module = "org.quiltmc:quilt-loader", version.ref = "quilt_loader" } -qsl_lifecycle_events = { module = "org.quiltmc.qsl.core:lifecycle_events", version.ref = "quilt_standard_libraries" } +# quilt_loader = { module = "org.quiltmc:quilt-loader", version.ref = "quilt_loader" } +# qsl_lifecycle_events = { module = "org.quiltmc.qsl.core:lifecycle_events", version.ref = "quilt_standard_libraries" } # Third-party libraries diff --git a/platforms/common/src/main/java/dynamic_fps/impl/compat/ClothConfig.java b/platforms/common/src/main/java/dynamic_fps/impl/compat/ClothConfig.java index b4a71277..32b24f9a 100644 --- a/platforms/common/src/main/java/dynamic_fps/impl/compat/ClothConfig.java +++ b/platforms/common/src/main/java/dynamic_fps/impl/compat/ClothConfig.java @@ -12,6 +12,8 @@ import net.minecraft.client.gui.screens.Screen; import net.minecraft.network.chat.CommonComponents; import net.minecraft.network.chat.Component; +import net.minecraft.network.chat.TextComponent; +import net.minecraft.network.chat.TranslatableComponent; import net.minecraft.sounds.SoundSource; import java.util.Locale; @@ -43,7 +45,7 @@ public static Screen genConfigScreen(Screen parent) { ); general.addEntry( - entryBuilder.startTextDescription(CommonComponents.SPACE).build() + entryBuilder.startTextDescription(new TextComponent(" ")).build() ); general.addEntry( @@ -101,7 +103,7 @@ public static Screen genConfigScreen(Screen parent) { volumes.add( entryBuilder.startIntSlider( - Component.translatable("soundCategory." + name), + new TranslatableComponent("soundCategory." + name), (int) (config.rawVolumeMultiplier(source) * 100), 0, 100 ) @@ -123,7 +125,7 @@ public static Screen genConfigScreen(Screen parent) { .setDefaultValue(standard.graphicsState()) .setSaveConsumer(config::setGraphicsState) .setEnumNameProvider(ClothConfig::graphicsStateMessage) - .setTooltipSupplier(ClothConfig::graphicsStateTooltip) + .setTooltipSupplier((selected) -> ClothConfig.graphicsStateTooltip((GraphicsState) selected)) // what .build() ); @@ -173,14 +175,14 @@ private static int fromConfigFpsTarget(int value) { private static Component fpsTargetMessage(int value) { if (toConfigFpsTarget(value) != -1) { - return Component.translatable("options.framerate", value); + return new TranslatableComponent("options.framerate", value); } else { - return Component.translatable("options.framerateLimit.max"); + return new TranslatableComponent("options.framerateLimit.max"); } } private static Component volumeMultiplierMessage(int value) { - return Component.literal(Integer.toString(value) + "%"); + return new TranslatableComponent(Integer.toString(value) + "%"); } private static Component graphicsStateMessage(Enum graphicsState) { diff --git a/platforms/common/src/main/java/dynamic_fps/impl/mixin/GuiMixin.java b/platforms/common/src/main/java/dynamic_fps/impl/mixin/GuiMixin.java index dd877a20..66af3434 100644 --- a/platforms/common/src/main/java/dynamic_fps/impl/mixin/GuiMixin.java +++ b/platforms/common/src/main/java/dynamic_fps/impl/mixin/GuiMixin.java @@ -1,6 +1,5 @@ package dynamic_fps.impl.mixin; -import dynamic_fps.impl.util.HudInfoRenderer; import org.spongepowered.asm.mixin.Mixin; import org.spongepowered.asm.mixin.injection.At; import org.spongepowered.asm.mixin.injection.Inject; @@ -8,7 +7,6 @@ import dynamic_fps.impl.DynamicFPSMod; import net.minecraft.client.gui.Gui; -import net.minecraft.client.gui.GuiGraphics; @Mixin(Gui.class) public class GuiMixin { @@ -21,18 +19,4 @@ private void shouldRender(CallbackInfo callbackInfo) { callbackInfo.cancel(); } } - - /** - * Render info on whether Dynamic FPS is disabled or always reducing the user's FPS. - */ - @Inject( - method = "render", - at = @At( - value = "INVOKE", - target = "Lnet/minecraft/client/gui/Gui;renderSavingIndicator(Lnet/minecraft/client/gui/GuiGraphics;)V" - ) - ) - private void render(GuiGraphics guiGraphics, float f, CallbackInfo callbackInfo) { - HudInfoRenderer.renderInfo(guiGraphics); - } } diff --git a/platforms/common/src/main/java/dynamic_fps/impl/mixin/MinecraftMixin.java b/platforms/common/src/main/java/dynamic_fps/impl/mixin/MinecraftMixin.java index e314d8d2..e8573934 100644 --- a/platforms/common/src/main/java/dynamic_fps/impl/mixin/MinecraftMixin.java +++ b/platforms/common/src/main/java/dynamic_fps/impl/mixin/MinecraftMixin.java @@ -52,7 +52,7 @@ private void getFramerateLimit(CallbackInfoReturnable callbackInfo) { callbackInfo.setReturnValue(limit); } } else if (DynamicFPSMod.uncapMenuFrameRate()) { - if (self.options.enableVsync().get()) { + if (self.options.enableVsync) { // VSync will regulate to a non-infinite value callbackInfo.setReturnValue(NO_FRAME_RATE_LIMIT); } else { diff --git a/platforms/common/src/main/java/dynamic_fps/impl/mixin/ToastComponentMixin.java b/platforms/common/src/main/java/dynamic_fps/impl/mixin/ToastComponentMixin.java index 52368925..03f2694b 100644 --- a/platforms/common/src/main/java/dynamic_fps/impl/mixin/ToastComponentMixin.java +++ b/platforms/common/src/main/java/dynamic_fps/impl/mixin/ToastComponentMixin.java @@ -1,19 +1,23 @@ package dynamic_fps.impl.mixin; +import java.util.Deque; + import org.spongepowered.asm.mixin.Mixin; import org.spongepowered.asm.mixin.injection.At; -import org.spongepowered.asm.mixin.injection.Inject; -import org.spongepowered.asm.mixin.injection.callback.CallbackInfoReturnable; +import org.spongepowered.asm.mixin.injection.Redirect; import dynamic_fps.impl.DynamicFPSMod; +import net.minecraft.client.gui.components.toasts.Toast; import net.minecraft.client.gui.components.toasts.ToastComponent; @Mixin(ToastComponent.class) public class ToastComponentMixin { - @Inject(method = "freeSlots", at = @At("HEAD"), cancellable = true) - private void hasFreeSlots(CallbackInfoReturnable callbackInfo) { + @Redirect(method = "render", at = @At(value = "INVOKE", target = "Ljava/util/Deque;isEmpty()Z")) + private boolean onQueueIsEmpty(Deque queued) { if (!DynamicFPSMod.shouldShowToasts()) { - callbackInfo.setReturnValue(0); + return true; + } else { + return queued.isEmpty(); } } } diff --git a/platforms/common/src/main/java/dynamic_fps/impl/service/Services.java b/platforms/common/src/main/java/dynamic_fps/impl/service/Services.java index 2b8e5bc5..76c5095c 100644 --- a/platforms/common/src/main/java/dynamic_fps/impl/service/Services.java +++ b/platforms/common/src/main/java/dynamic_fps/impl/service/Services.java @@ -1,5 +1,6 @@ package dynamic_fps.impl.service; +import java.util.NoSuchElementException; import java.util.Optional; import java.util.ServiceLoader; @@ -8,11 +9,9 @@ class Services { static ModCompat MOD_COMPAT = loadService(ModCompat.class); static T loadService(Class type) { - Optional optional = ServiceLoader.load(type).findFirst(); - - if (optional.isPresent()) { - return optional.get(); - } else { + try { + return ServiceLoader.load(type).iterator().next(); + } catch (NoSuchElementException e) { throw new RuntimeException("Failed to load Dynamic FPS " + type.getSimpleName() + " service!"); } } diff --git a/platforms/common/src/main/java/dynamic_fps/impl/util/HudInfoRenderer.java b/platforms/common/src/main/java/dynamic_fps/impl/util/HudInfoRenderer.java index 1114cba3..7ed00452 100644 --- a/platforms/common/src/main/java/dynamic_fps/impl/util/HudInfoRenderer.java +++ b/platforms/common/src/main/java/dynamic_fps/impl/util/HudInfoRenderer.java @@ -2,44 +2,37 @@ import net.minecraft.client.Minecraft; import net.minecraft.client.gui.Font; -import net.minecraft.client.gui.GuiGraphics; -import net.minecraft.client.gui.Font.DisplayMode; import net.minecraft.network.chat.Component; import static dynamic_fps.impl.util.Localization.localized; -import org.joml.Matrix4f; +import com.mojang.blaze3d.vertex.PoseStack; import dynamic_fps.impl.DynamicFPSMod; public final class HudInfoRenderer { private static final Minecraft minecraft = Minecraft.getInstance(); - public static void renderInfo(GuiGraphics guiGraphics) { + public static void renderInfo(PoseStack poseStack) { if (DynamicFPSMod.disabledByUser()) { - drawCenteredText(guiGraphics, localized("gui", "hud.disabled"), 32); + drawCenteredText(poseStack, localized("gui", "hud.disabled"), 32); } else if (DynamicFPSMod.isForcingLowFPS()) { - drawCenteredText(guiGraphics, localized("gui", "hud.reducing"), 32); + drawCenteredText(poseStack, localized("gui", "hud.reducing"), 32); } } - private static void drawCenteredText(GuiGraphics guiGraphics, Component component, float y) { + private static void drawCenteredText(PoseStack poseStack, Component component, float y) { Font fontRenderer = minecraft.gui.getFont(); int stringWidth = fontRenderer.width(component); int windowWidth = minecraft.getWindow().getGuiScaledWidth(); - fontRenderer.drawInBatch( + fontRenderer.drawShadow( + poseStack, component, (windowWidth - stringWidth) / 2f, y, - 0xFFFFFFFF, - true, - new Matrix4f(), - guiGraphics.bufferSource(), - DisplayMode.NORMAL, - 0, - 255 + 0xFFFFFFFF ); } } diff --git a/platforms/common/src/main/java/dynamic_fps/impl/util/Localization.java b/platforms/common/src/main/java/dynamic_fps/impl/util/Localization.java index bd3d95e0..0fd1579e 100644 --- a/platforms/common/src/main/java/dynamic_fps/impl/util/Localization.java +++ b/platforms/common/src/main/java/dynamic_fps/impl/util/Localization.java @@ -1,8 +1,8 @@ package dynamic_fps.impl.util; import dynamic_fps.impl.Constants; -import net.minecraft.network.chat.Component; import net.minecraft.network.chat.MutableComponent; +import net.minecraft.network.chat.TranslatableComponent; public final class Localization { /** e.g. keyString("title", "config") -> "title.dynamic_fps.config") */ @@ -11,7 +11,7 @@ public static String translationKey(String domain, String path) { } public static MutableComponent localized(String domain, String path, Object... args) { - return Component.translatable(translationKey(domain, path), args); + return new TranslatableComponent(translationKey(domain, path), args); } private Localization() {} diff --git a/platforms/common/src/main/java/dynamic_fps/impl/util/Logging.java b/platforms/common/src/main/java/dynamic_fps/impl/util/Logging.java index f510adfb..a0911c62 100644 --- a/platforms/common/src/main/java/dynamic_fps/impl/util/Logging.java +++ b/platforms/common/src/main/java/dynamic_fps/impl/util/Logging.java @@ -1,11 +1,11 @@ package dynamic_fps.impl.util; import dynamic_fps.impl.Constants; -import org.slf4j.Logger; -import org.slf4j.LoggerFactory; +import org.apache.logging.log4j.LogManager; +import org.apache.logging.log4j.Logger; public class Logging { - private static final Logger logger = LoggerFactory.getLogger(Constants.MOD_ID); + private static final Logger logger = LogManager.getLogger(Constants.MOD_ID); public static Logger getLogger() { return logger; diff --git a/platforms/common/src/main/java/dynamic_fps/impl/util/OptionsHolder.java b/platforms/common/src/main/java/dynamic_fps/impl/util/OptionsHolder.java index f22862e3..3c9799bc 100644 --- a/platforms/common/src/main/java/dynamic_fps/impl/util/OptionsHolder.java +++ b/platforms/common/src/main/java/dynamic_fps/impl/util/OptionsHolder.java @@ -1,6 +1,7 @@ package dynamic_fps.impl.util; import dynamic_fps.impl.GraphicsState; +import net.minecraft.client.AmbientOcclusionStatus; import net.minecraft.client.CloudStatus; import net.minecraft.client.GraphicsStatus; import net.minecraft.client.Options; @@ -14,10 +15,10 @@ public class OptionsHolder { private static CloudStatus cloudStatus; private static GraphicsStatus graphicsStatus; - private static boolean ambientOcclusion; + private static AmbientOcclusionStatus ambientOcclusion; private static ParticleStatus particlesStatus; private static boolean entityShadows; - private static double entityDistance; + private static float entityDistance; /* * Create an in-memory copy of current vanilla graphics options. @@ -25,12 +26,12 @@ public class OptionsHolder { * This MUST be called while graphics options have not been changed yet. */ public static void copyOptions(Options options) { - cloudStatus = options.getCloudsType(); - graphicsStatus = options.graphicsMode().get(); - ambientOcclusion = options.ambientOcclusion().get(); - particlesStatus = options.particles().get(); - entityShadows = options.entityShadows().get(); - entityDistance = options.entityDistanceScaling().get(); + cloudStatus = options.renderClouds; + graphicsStatus = options.graphicsMode; + ambientOcclusion = options.ambientOcclusion; + particlesStatus = options.particles; + entityShadows = options.entityShadows; + entityDistance = options.entityDistanceScaling; } /* @@ -38,21 +39,21 @@ public static void copyOptions(Options options) { */ public static void applyOptions(Options options, GraphicsState state) { if (state == GraphicsState.DEFAULT) { - options.cloudStatus().set(cloudStatus); - options.graphicsMode().set(graphicsStatus); - options.ambientOcclusion().set(ambientOcclusion); - options.particles().set(particlesStatus); - options.entityShadows().set(entityShadows); - options.entityDistanceScaling().set(entityDistance); + options.renderClouds = cloudStatus; + options.graphicsMode = graphicsStatus; + options.ambientOcclusion = ambientOcclusion; + options.particles = particlesStatus; + options.entityShadows = entityShadows; + options.entityDistanceScaling = entityDistance; } else { // state == GraphicsState.REDUCED - options.cloudStatus().set(CloudStatus.OFF); - options.particles().set(ParticleStatus.MINIMAL); - options.entityShadows().set(false); - options.entityDistanceScaling().set(0.5); + options.renderClouds = CloudStatus.OFF; + options.particles = ParticleStatus.MINIMAL; + options.entityShadows = false; + options.entityDistanceScaling = 0.5f; if (state == GraphicsState.MINIMAL) { - options.graphicsMode().set(GraphicsStatus.FAST); - options.ambientOcclusion().set(false); + options.graphicsMode = GraphicsStatus.FAST; + options.ambientOcclusion = AmbientOcclusionStatus.OFF; } } } diff --git a/platforms/fabric/src/main/java/net/lostluma/dynamic_fps/impl/fabric/mixin/GuiMixin.java b/platforms/fabric/src/main/java/net/lostluma/dynamic_fps/impl/fabric/mixin/GuiMixin.java new file mode 100644 index 00000000..b0e54663 --- /dev/null +++ b/platforms/fabric/src/main/java/net/lostluma/dynamic_fps/impl/fabric/mixin/GuiMixin.java @@ -0,0 +1,27 @@ +package net.lostluma.dynamic_fps.impl.fabric.mixin; + +import com.llamalad7.mixinextras.sugar.Local; +import com.mojang.blaze3d.vertex.PoseStack; +import dynamic_fps.impl.util.HudInfoRenderer; +import net.minecraft.client.gui.Gui; +import org.spongepowered.asm.mixin.Mixin; +import org.spongepowered.asm.mixin.injection.At; +import org.spongepowered.asm.mixin.injection.Inject; +import org.spongepowered.asm.mixin.injection.callback.CallbackInfo; + +@Mixin(Gui.class) +public class GuiMixin { + /** + * Render info on whether Dynamic FPS is disabled or always reducing the user's FPS. + */ + @Inject( + method = "render", + at = @At( + value = "INVOKE", + target = "Lnet/minecraft/client/gui/Gui;renderHotbar(FLcom/mojang/blaze3d/vertex/PoseStack;)V" + ) + ) + private void render(CallbackInfo callbackInfo, @Local PoseStack poseStack) { + HudInfoRenderer.renderInfo(poseStack); + } +} diff --git a/platforms/fabric/src/main/resources/dynamic_fps.mixins.json b/platforms/fabric/src/main/resources/dynamic_fps.mixins.json index 0801d7a2..f9a16703 100644 --- a/platforms/fabric/src/main/resources/dynamic_fps.mixins.json +++ b/platforms/fabric/src/main/resources/dynamic_fps.mixins.json @@ -4,6 +4,7 @@ "compatibilityLevel": "JAVA_17", "minVersion": "0.8", "client": [ + "GuiMixin", "OptionsMixin" ], "mixins": [], diff --git a/platforms/fabric/src/main/resources/fabric.mod.json b/platforms/fabric/src/main/resources/fabric.mod.json index ee6e2c0a..fa80ad68 100644 --- a/platforms/fabric/src/main/resources/fabric.mod.json +++ b/platforms/fabric/src/main/resources/fabric.mod.json @@ -27,7 +27,10 @@ }, "depends": { "fabricloader": ">=0.15.0", - "minecraft": ">=1.20.0", + "minecraft": [ + "=1.17.0", + "=1.17.1" + ], "mixinextras": ">=0.3.2", "fabric-resource-loader-v0": "*", "fabric-lifecycle-events-v1": "*" @@ -58,7 +61,6 @@ "net.minecraft.class_426", "net.minecraft.class_4288", "net.minecraft.class_6777", - "net.minecraft.class_443", "net.minecraft.class_446", "net.minecraft.class_445", "net.minecraft.class_6599" @@ -75,7 +77,6 @@ "net.minecraft.class_426": "net.minecraft.client.gui.screens.LanguageSelectScreen", "net.minecraft.class_4288": "net.minecraft.client.gui.screens.MouseSettingsScreen", "net.minecraft.class_6777": "net.minecraft.client.gui.screens.OnlineOptionsScreen", - "net.minecraft.class_443": "net.minecraft.client.gui.screens.SoundOptionsScreen", "net.minecraft.class_446": "net.minecraft.client.gui.screens.VideoSettingsScreen", "net.minecraft.class_445": "net.minecraft.client.gui.screens.WinScreen", "net.minecraft.class_6599": "net.minecraft.client.gui.screens.controls.KeyBindsScreen" diff --git a/platforms/forge/build.gradle b/platforms/forge/build.gradle index c7381cd6..6b0d3254 100644 --- a/platforms/forge/build.gradle +++ b/platforms/forge/build.gradle @@ -52,6 +52,8 @@ shadowJar { exclude "fabric.mod.json" exclude "architectury.common.json" + exclude "assets/dynamic_fps/icon.png" + configurations = [project.configurations.shadowCommon] } diff --git a/platforms/forge/src/main/java/net/lostluma/dynamic_fps/impl/forge/DynamicFPSForgeMod.java b/platforms/forge/src/main/java/net/lostluma/dynamic_fps/impl/forge/DynamicFPSForgeMod.java index d1a2f8bf..92d94c34 100644 --- a/platforms/forge/src/main/java/net/lostluma/dynamic_fps/impl/forge/DynamicFPSForgeMod.java +++ b/platforms/forge/src/main/java/net/lostluma/dynamic_fps/impl/forge/DynamicFPSForgeMod.java @@ -4,17 +4,16 @@ import dynamic_fps.impl.DynamicFPSMod; import dynamic_fps.impl.compat.ClothConfig; import dynamic_fps.impl.service.Platform; -import dynamic_fps.impl.util.HudInfoRenderer; import dynamic_fps.impl.util.KeyMappingHandler; -import net.minecraftforge.client.ConfigScreenHandler; -import net.minecraftforge.client.event.RegisterKeyMappingsEvent; -import net.minecraftforge.client.event.RenderGuiOverlayEvent; import net.minecraftforge.common.MinecraftForge; import net.minecraftforge.event.TickEvent; import net.minecraftforge.fml.ModLoadingContext; import net.minecraftforge.fml.common.Mod; +import net.minecraftforge.fml.event.lifecycle.FMLClientSetupEvent; import net.minecraftforge.fml.javafmlmod.FMLJavaModLoadingContext; import net.minecraftforge.fml.loading.FMLLoader; +import net.minecraftforge.fmlclient.ConfigGuiHandler; +import net.minecraftforge.fmlclient.registry.ClientRegistry; import java.util.ArrayList; import java.util.List; @@ -23,7 +22,7 @@ public class DynamicFPSForgeMod { private static final List TICK_EVENT_LISTENERS = new ArrayList<>(); - public DynamicFPSForgeMod() { + public DynamicFPSForgeMod() { if (FMLLoader.getDist().isDedicatedServer()) { return; } @@ -31,19 +30,19 @@ public DynamicFPSForgeMod() { DynamicFPSMod.init(); ModLoadingContext.get().registerExtensionPoint( - ConfigScreenHandler.ConfigScreenFactory.class, - () -> new ConfigScreenHandler.ConfigScreenFactory( + ConfigGuiHandler.ConfigGuiFactory.class, + () -> new ConfigGuiHandler.ConfigGuiFactory( (minecraft, screen) -> ClothConfig.genConfigScreen(screen) ) - ); + ); MinecraftForge.EVENT_BUS.addListener(this::onClientTick); FMLJavaModLoadingContext.get().getModEventBus().addListener(this::registerKeyMappings); - } + } - public void registerKeyMappings(RegisterKeyMappingsEvent event) { + public void registerKeyMappings(FMLClientSetupEvent event) { for (KeyMappingHandler handler : KeyMappingHandler.getHandlers()) { - event.register(handler.keyMapping()); + ClientRegistry.registerKeyBinding(handler.keyMapping()); } } diff --git a/platforms/forge/src/main/java/net/lostluma/dynamic_fps/impl/forge/mixin/GameRendererMixin.java b/platforms/forge/src/main/java/net/lostluma/dynamic_fps/impl/forge/mixin/GameRendererMixin.java new file mode 100644 index 00000000..3422af32 --- /dev/null +++ b/platforms/forge/src/main/java/net/lostluma/dynamic_fps/impl/forge/mixin/GameRendererMixin.java @@ -0,0 +1,39 @@ +package net.lostluma.dynamic_fps.impl.forge.mixin; + +import dynamic_fps.impl.DynamicFPSMod; +import net.minecraft.Util; +import net.minecraft.client.Minecraft; +import net.minecraft.client.renderer.GameRenderer; +import org.spongepowered.asm.mixin.Final; +import org.spongepowered.asm.mixin.Mixin; +import org.spongepowered.asm.mixin.Shadow; +import org.spongepowered.asm.mixin.injection.At; +import org.spongepowered.asm.mixin.injection.Inject; +import org.spongepowered.asm.mixin.injection.callback.CallbackInfo; + +@Mixin(GameRenderer.class) +public class GameRendererMixin { + @Shadow + @Final + private Minecraft minecraft; + + @Shadow + private long lastActiveTime; + + // Duplicate of common mixin w/o mixinextras and injected earlier + // Since the original just does not activate at all on Forge ...? + // We have to add the pause on lost focus feature ourselves sadly + @Inject(method = "render", at = @At("HEAD"), cancellable = true) + private void skipRendering(CallbackInfo callbackInfo) { + if (!DynamicFPSMod.checkForRender()) { + callbackInfo.cancel(); + + // Copy of vanilla code + if (this.minecraft.isWindowActive() || !this.minecraft.options.pauseOnLostFocus || this.minecraft.options.touchscreen && this.minecraft.mouseHandler.isRightPressed()) { + this.lastActiveTime = Util.getMillis(); + } else if (Util.getMillis() - this.lastActiveTime > 500L) { + this.minecraft.pauseGame(false); + } + } + } +} diff --git a/platforms/forge/src/main/resources/META-INF/mods.toml b/platforms/forge/src/main/resources/META-INF/mods.toml index fd16cdc9..06968c26 100644 --- a/platforms/forge/src/main/resources/META-INF/mods.toml +++ b/platforms/forge/src/main/resources/META-INF/mods.toml @@ -5,12 +5,11 @@ issueTrackerURL = "https://github.com/juliand665/Dynamic-FPS/issues" [[mods]] modId = "dynamic_fps" -namespace = "net.lostluma" version = "${version}" displayName = "Dynamic FPS" authors = "juliand665 & LostLuma" description = "Dynamically adjusts FPS so Minecraft doesn't hog resources in the background." -logoFile = "assets/dynamic_fps/icon.png" +logoFile = "dynamic_fps.png" displayTest = "IGNORE_ALL_VERSION" updateJSONURL = "https://api.lostluma.net/updates/dynamic-fps?platform=forge" @@ -26,7 +25,7 @@ file="META-INF/accesstransformer.cfg" [[dependencies.dynamic_fps]] modId = "minecraft" mandatory = true -versionRange = "[1.20.0,)" +versionRange = "[1.17.0,1.17.1]" ordering = "NONE" side = "CLIENT" diff --git a/platforms/forge/src/main/resources/dynamic_fps.mixins.json b/platforms/forge/src/main/resources/dynamic_fps.mixins.json index 36a7f8d0..1a57c636 100644 --- a/platforms/forge/src/main/resources/dynamic_fps.mixins.json +++ b/platforms/forge/src/main/resources/dynamic_fps.mixins.json @@ -3,7 +3,9 @@ "package": "net.lostluma.dynamic_fps.impl.forge.mixin", "compatibilityLevel": "JAVA_17", "minVersion": "0.8", - "client": [], + "client": [ + "GameRendererMixin" + ], "mixins": [], "server": [], "injectors": { diff --git a/platforms/forge/src/main/resources/dynamic_fps.png b/platforms/forge/src/main/resources/dynamic_fps.png new file mode 100644 index 0000000000000000000000000000000000000000..f282051920dd8187815d2c7347e9db3d1766fc9a GIT binary patch literal 6871 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 RG-v<-002ovPDHLkV1jdx=ym`A literal 0 HcmV?d00001 diff --git a/platforms/quilt/src/main/java/net/lostluma/dynamic_fps/impl/quilt/mixin/GuiMixin.java b/platforms/quilt/src/main/java/net/lostluma/dynamic_fps/impl/quilt/mixin/GuiMixin.java new file mode 100644 index 00000000..aecc8c76 --- /dev/null +++ b/platforms/quilt/src/main/java/net/lostluma/dynamic_fps/impl/quilt/mixin/GuiMixin.java @@ -0,0 +1,27 @@ +package net.lostluma.dynamic_fps.impl.quilt.mixin; + +import com.llamalad7.mixinextras.sugar.Local; +import com.mojang.blaze3d.vertex.PoseStack; +import dynamic_fps.impl.util.HudInfoRenderer; +import net.minecraft.client.gui.Gui; +import org.spongepowered.asm.mixin.Mixin; +import org.spongepowered.asm.mixin.injection.At; +import org.spongepowered.asm.mixin.injection.Inject; +import org.spongepowered.asm.mixin.injection.callback.CallbackInfo; + +@Mixin(Gui.class) +public class GuiMixin { + /** + * Render info on whether Dynamic FPS is disabled or always reducing the user's FPS. + */ + @Inject( + method = "render", + at = @At( + value = "INVOKE", + target = "Lnet/minecraft/client/gui/Gui;renderSavingIndicator(Lcom/mojang/blaze3d/vertex/PoseStack;)V" + ) + ) + private void render(CallbackInfo callbackInfo, @Local PoseStack poseStack) { + HudInfoRenderer.renderInfo(poseStack); + } +} diff --git a/platforms/quilt/src/main/resources/dynamic_fps.mixins.json b/platforms/quilt/src/main/resources/dynamic_fps.mixins.json index b3d28cf8..603b6b5c 100644 --- a/platforms/quilt/src/main/resources/dynamic_fps.mixins.json +++ b/platforms/quilt/src/main/resources/dynamic_fps.mixins.json @@ -4,6 +4,7 @@ "compatibilityLevel": "JAVA_17", "minVersion": "0.8", "client": [ + "GuiMixin", "OptionsMixin" ], "mixins": [], diff --git a/platforms/quilt/src/main/resources/quilt.mod.json b/platforms/quilt/src/main/resources/quilt.mod.json index e9f6eb80..965c1533 100644 --- a/platforms/quilt/src/main/resources/quilt.mod.json +++ b/platforms/quilt/src/main/resources/quilt.mod.json @@ -40,7 +40,7 @@ }, { "id": "minecraft", - "versions": ">=1.20.0" + "versions": "=1.18.2" }, { "id": "mixinextras", @@ -89,7 +89,6 @@ "net.minecraft.class_426", "net.minecraft.class_4288", "net.minecraft.class_6777", - "net.minecraft.class_443", "net.minecraft.class_446", "net.minecraft.class_445", "net.minecraft.class_6599" @@ -106,7 +105,6 @@ "net.minecraft.class_426": "net.minecraft.client.gui.screens.LanguageSelectScreen", "net.minecraft.class_4288": "net.minecraft.client.gui.screens.MouseSettingsScreen", "net.minecraft.class_6777": "net.minecraft.client.gui.screens.OnlineOptionsScreen", - "net.minecraft.class_443": "net.minecraft.client.gui.screens.SoundOptionsScreen", "net.minecraft.class_446": "net.minecraft.client.gui.screens.VideoSettingsScreen", "net.minecraft.class_445": "net.minecraft.client.gui.screens.WinScreen", "net.minecraft.class_6599": "net.minecraft.client.gui.screens.controls.KeyBindsScreen" diff --git a/settings.gradle b/settings.gradle index 46efda2c..50d9539e 100644 --- a/settings.gradle +++ b/settings.gradle @@ -12,5 +12,5 @@ rootProject.name = "dynamic-fps" include(":platforms:common") include(":platforms:fabric") include(":platforms:forge") -include(":platforms:neoforge") -include(":platforms:quilt") +// include(":platforms:neoforge") +// include(":platforms:quilt")