Skip to content

Commit

Permalink
Minecraft 1.19.4 backport
Browse files Browse the repository at this point in the history
  • Loading branch information
LostLuma committed Jun 24, 2024
1 parent df610e4 commit 3e376e1
Show file tree
Hide file tree
Showing 43 changed files with 510 additions and 100 deletions.
4 changes: 2 additions & 2 deletions build.gradle
Original file line number Diff line number Diff line change
Expand Up @@ -54,15 +54,15 @@ subprojects {
withSourcesJar()

toolchain {
languageVersion = JavaLanguageVersion.of(21)
languageVersion = JavaLanguageVersion.of(17)
}
}

tasks.withType(JavaCompile).configureEach {
it.options.encoding = "UTF-8"

javaCompiler = javaToolchains.compilerFor {
languageVersion = JavaLanguageVersion.of(21)
languageVersion = JavaLanguageVersion.of(17)
}
}
}
4 changes: 2 additions & 2 deletions gradle.properties
Original file line number Diff line number Diff line change
Expand Up @@ -4,10 +4,10 @@ org.gradle.jvmargs = -Xmx3G

# Mod Properties
mod_version = 3.5.0
minecraft_version_min = 1.21.0
minecraft_version_min = 1.19.4

maven_group = juliand665
archives_base_name = dynamic-fps

enabled_platforms=fabric,neoforge
enabled_platforms=fabric,forge,quilt
# enabled_platforms=fabric,forge,neoforge,quilt
14 changes: 7 additions & 7 deletions gradle/libs.versions.toml
Original file line number Diff line number Diff line change
@@ -1,26 +1,26 @@
[versions]
minecraft = "1.21"
minecraft = "1.19.4"

# Platform libraries

fabric_loader = "0.15.10"
fabric_api = "0.100.1+1.21"
fabric_api = "0.75.3+1.19.4"

forge = "1.20.4-49.0.30"
forge = "1.19.4-45.2.8"

neoforge = "21.0.0-beta"
neoforge = "20.4.237"

quilt_loader = "0.25.0"
quilt_standard_libraries = "8.0.0-alpha.12+1.20.4"
quilt_standard_libraries = "5.0.0-beta.11+1.19.4"

# Regular libraries

battery = "1.0.0"

# Modding libraries

modmenu = "11.0.0-beta.1"
cloth_config = "15.0.127"
modmenu = "6.1.0"
cloth_config = "10.1.117"

mixinextras = "0.3.5"

Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -14,12 +14,14 @@
import dynamic_fps.impl.util.FallbackConfigScreen;
import dynamic_fps.impl.util.Logging;
import dynamic_fps.impl.feature.state.OptionHolder;
import dynamic_fps.impl.util.ModCompatHelper;
import dynamic_fps.impl.util.ResourceLocations;
import dynamic_fps.impl.util.Version;
import dynamic_fps.impl.feature.volume.SmoothVolumeHandler;
import dynamic_fps.impl.util.duck.DuckLoadingOverlay;
import dynamic_fps.impl.feature.state.WindowObserver;
import dynamic_fps.impl.service.Platform;
import dynamic_fps.impl.util.duck.DuckScreen;
import net.lostluma.battery.api.State;
import net.minecraft.Util;
import net.minecraft.client.Minecraft;
Expand Down Expand Up @@ -170,7 +172,7 @@ public static boolean shouldShowToasts() {
}

public static boolean shouldShowLevels() {
return isDisabled() || !isLevelCoveredByOverlay();
return isDisabled() || !(isLevelCoveredByScreen() || isLevelCoveredByOverlay());
}

public static void onBatteryChargeChanged(int before, int after) {
Expand All @@ -192,11 +194,17 @@ public static void onBatteryStatusChanged(State before, State after) {
private static void doInit() {
// NOTE: Init battery tracker first here
// Since the idle handler queries it for info
ModCompatHelper.init();

BatteryTracker.init();
IdleHandler.init();
SmoothVolumeHandler.init();
}

private static boolean isLevelCoveredByScreen() {
return minecraft.screen != null && ((DuckScreen) minecraft.screen).dynamic_fps$rendersBackground();
}

private static void showNotification(String titleTranslationKey, String iconPath) {
if (!DynamicFPSConfig.INSTANCE.batteryTracker().notifications()) {
return;
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -85,7 +85,7 @@ private static JsonObject removeUnchangedFields(JsonObject config, JsonObject pa
removeUnchangedFields((JsonObject) value, (JsonObject) other);
}

if (value.equals(other) || (value.isJsonObject() && value.getAsJsonObject().isEmpty())) {
if (value.equals(other) || (value.isJsonObject() && value.getAsJsonObject().size() == 0)) {
config.remove(name);
}
});
Expand Down
Original file line number Diff line number Diff line change
@@ -1,28 +1,28 @@
package dynamic_fps.impl.config.option;

import net.minecraft.client.gui.GuiGraphics;
import com.mojang.blaze3d.platform.Window;

/**
* Screen corner to render the battery indicator in.
*/
public enum BatteryIndicatorPlacement {
TOP_LEFT(graphics -> new int[] {4, 4}),
TOP_RIGHT(graphics -> new int[] {graphics.guiWidth() - 47, 4}),
BOTTOM_LEFT(graphics -> new int[] {4, graphics.guiHeight() - 20}),
BOTTOM_RIGHT(graphics -> new int[] {graphics.guiWidth() - 47, graphics.guiHeight() - 20});
TOP_LEFT(window -> new int[] {4, 4}),
TOP_RIGHT(window -> new int[] {window.getGuiScaledWidth() - 47, 4}),
BOTTOM_LEFT(window -> new int[] {4, window.getGuiScaledHeight() - 20}),
BOTTOM_RIGHT(window -> new int[] {window.getGuiScaledWidth() - 47, window.getGuiScaledHeight() - 20});

private final DynamicPlacement placement;

BatteryIndicatorPlacement(DynamicPlacement placement) {
this.placement = placement;
}

public int[] get(GuiGraphics graphics) {
return this.placement.get(graphics);
public int[] get(Window window) {
return this.placement.get(window);
}

@FunctionalInterface
private interface DynamicPlacement {
int[] get(GuiGraphics graphics);
int[] get(Window window);
}
}
Original file line number Diff line number Diff line change
@@ -1,8 +1,10 @@
package dynamic_fps.impl.feature.battery;

import com.mojang.blaze3d.systems.RenderSystem;
import com.mojang.blaze3d.vertex.PoseStack;
import dynamic_fps.impl.util.ResourceLocations;
import net.minecraft.client.Minecraft;
import net.minecraft.client.gui.GuiGraphics;
import net.minecraft.client.gui.GuiComponent;
import net.minecraft.client.gui.components.toasts.Toast;
import net.minecraft.client.gui.components.toasts.ToastComponent;
import net.minecraft.network.chat.Component;
Expand Down Expand Up @@ -43,7 +45,7 @@ public static void queueToast(Component title, ResourceLocation icon) {
}

@Override
public @NotNull Visibility render(GuiGraphics graphics, ToastComponent toastComponent, long currentTime) {
public @NotNull Visibility render(PoseStack poseStack, ToastComponent toastComponent, long currentTime) {
if (this.firstRender == 0) {
if (this == queuedToast) {
queuedToast = null;
Expand All @@ -54,14 +56,17 @@ public static void queueToast(Component title, ResourceLocation icon) {
this.description = localized("toast", "battery_charge", BatteryTracker.charge());
}

RenderSystem.setShaderTexture(0, BACKGROUND_IMAGE);
// resource, x, y, z, ?, ?, width, height, width, height
graphics.blit(BACKGROUND_IMAGE, 0, 0, 0, 0.0f, 0.0f, this.width(), this.height(), this.width(), this.height());
GuiComponent.blit(poseStack, 0, 0, 0, 0.0f, 0.0f, this.width(), this.height(), this.width(), this.height());

graphics.blit(MOD_ICON, 2, 2, 0, 0.0f, 0.0f, 8, 8, 8, 8);
graphics.blit(this.icon, 8, 8, 0, 0.0f, 0.0f, 16, 16, 16, 16);
RenderSystem.setShaderTexture(0, MOD_ICON);
GuiComponent.blit(poseStack, 2, 2, 0, 0.0f, 0.0f, 8, 8, 8, 8);
RenderSystem.setShaderTexture(0, this.icon);
GuiComponent.blit(poseStack, 8, 8, 0, 0.0f, 0.0f, 16, 16, 16, 16);

graphics.drawString(toastComponent.getMinecraft().font, this.title, 30, 7, 0x5f3315, false);
graphics.drawString(toastComponent.getMinecraft().font, this.description, 30, 18, -16777216, false);
GuiComponent.drawString(poseStack, toastComponent.getMinecraft().font, this.title, 30, 7, 0x5f3315);
GuiComponent.drawString(poseStack, toastComponent.getMinecraft().font, this.description, 30, 18, -16777216);

return currentTime - this.firstRender >= 5000.0 * toastComponent.getNotificationDisplayTimeMultiplier() ? Toast.Visibility.HIDE : Toast.Visibility.SHOW;
}
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -58,7 +58,7 @@ public static void init() {
}
} else {
manager = temp; // Keep around to allow updating batteries
Thread.ofVirtual().name("refresh-battery").start(BatteryTracker::updateBatteries);
new Thread(BatteryTracker::updateBatteries, "refresh-battery").start();
}
}

Expand Down Expand Up @@ -127,7 +127,7 @@ private static void updateBatteries() {
updateState();

try {
Thread.sleep(updateInterval);
Thread.sleep(updateInterval.toMillis());
} catch (InterruptedException e) {
active = false;
Thread.currentThread().interrupt();
Expand Down
Original file line number Diff line number Diff line change
@@ -0,0 +1,50 @@
package dynamic_fps.impl.mixin;

import dynamic_fps.impl.service.ModCompat;
import org.spongepowered.asm.mixin.Mixin;
import org.spongepowered.asm.mixin.Unique;
import org.spongepowered.asm.mixin.injection.At;
import org.spongepowered.asm.mixin.injection.Inject;
import org.spongepowered.asm.mixin.injection.callback.CallbackInfo;

import dynamic_fps.impl.util.duck.DuckScreen;
import net.minecraft.client.gui.screens.Screen;

@Mixin(Screen.class)
public class ScreenMixin implements DuckScreen {
@Unique
private boolean dynamic_fps$canOptimize = false;

@Unique
private boolean dynamic_fps$hasOptedOut = false;

@Override
public boolean dynamic_fps$rendersBackground() {
return dynamic_fps$canOptimize;
}

@Override
public void dynamic_fps$setRendersBackground() {
this.dynamic_fps$canOptimize = true;
}

@Inject(method = "init", at = @At("HEAD"))
private void onInit(CallbackInfo callbackInfo) {
String name = this.getClass().getName();

this.dynamic_fps$hasOptedOut = ModCompat.getInstance().isScreenOptedOut(name);

// Allow other mods to opt out on behalf of vanilla screens
// That Dynamic FPS forced to opt in via its own mod metadata.
if (!this.dynamic_fps$hasOptedOut) {
this.dynamic_fps$canOptimize = ModCompat.getInstance().isScreenOptedIn(name);
}
}

@Inject(method = "renderDirtBackground", at = @At("HEAD"))
private void onRenderDirtBackground(CallbackInfo callbackInfo) {
if (!this.dynamic_fps$hasOptedOut) {
this.dynamic_fps$canOptimize = true; // Signal to apply optimizations on next frame
}
}
}
Original file line number Diff line number Diff line change
@@ -0,0 +1,17 @@
package dynamic_fps.impl.mixin;

import dynamic_fps.impl.util.duck.DuckScreen;
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;

import net.minecraft.client.gui.screens.achievement.StatsScreen;

@Mixin(StatsScreen.class)
public class StatsScreenMixin {
@Inject(method = "onStatsUpdated", at = @At("HEAD"))
private void onStatsUpdated(CallbackInfo callbackInfo) {
((DuckScreen) this).dynamic_fps$setRendersBackground();
}
}
Original file line number Diff line number Diff line change
@@ -1,10 +1,23 @@
package dynamic_fps.impl.service;

import java.util.Set;

public interface ModCompat {
boolean isDisabled();

boolean disableOverlayOptimization();

Set<String> getOptedInScreens();
Set<String> getOptedOutScreens();

default boolean isScreenOptedIn(String className) {
return getOptedInScreens().contains(className);
}

default boolean isScreenOptedOut(String className) {
return getOptedOutScreens().contains(className);
}

static ModCompat getInstance() {
return Services.MOD_COMPAT;
}
Expand Down
Original file line number Diff line number Diff line change
@@ -1,7 +1,7 @@
package dynamic_fps.impl.util;

import com.mojang.blaze3d.vertex.PoseStack;
import net.minecraft.client.Minecraft;
import net.minecraft.client.gui.GuiGraphics;
import net.minecraft.client.gui.components.Button;
import net.minecraft.client.gui.screens.Screen;
import net.minecraft.network.chat.CommonComponents;
Expand Down Expand Up @@ -32,14 +32,15 @@ protected void init() {
}

@Override
public void render(GuiGraphics guiGraphics, int mouseX, int mouseY, float partialTicks) {
super.render(guiGraphics, mouseX, mouseY, partialTicks);
public void render(PoseStack poseStack, int mouseX, int mouseY, float partialTicks) {
this.renderDirtBackground(poseStack);
super.render(poseStack, mouseX, mouseY, partialTicks);

int width = guiGraphics.guiWidth() / 2;
int height = guiGraphics.guiHeight() / 3;
int width = this.width / 2;
int height = this.height / 3;

guiGraphics.drawCenteredString(this.font, WARNING_0.getVisualOrderText(), width, height, 0xFFFFFF);
guiGraphics.drawCenteredString(this.font, WARNING_1.getVisualOrderText(), width, height + 10, 0xFFFFFF);
drawCenteredString(poseStack, this.font, WARNING_0.getVisualOrderText(), width, height, 0xFFFFFF);
drawCenteredString(poseStack, this.font, WARNING_1.getVisualOrderText(), width, height + 10, 0xFFFFFF);
}

@Override
Expand Down
Loading

0 comments on commit 3e376e1

Please sign in to comment.