package cc.polyfrost.oneconfig.utils.gui; import cc.polyfrost.oneconfig.events.EventManager; import cc.polyfrost.oneconfig.events.event.RenderEvent; import cc.polyfrost.oneconfig.events.event.Stage; import cc.polyfrost.oneconfig.utils.TickDelay; import gg.essential.universal.UMinecraft; import gg.essential.universal.UScreen; import me.kbrewster.eventbus.Subscribe; import net.minecraft.client.gui.GuiScreen; /** * A class containing utility methods for working with GuiScreens. */ public final class GuiUtils { private static long time = -1L; private static long deltaTime = 17L; static { EventManager.INSTANCE.register(new GuiUtils()); } /** * Displays a screen after a tick, preventing mouse sync issues. * * @param screen the screen to display. */ public static void displayScreen(GuiScreen screen) { new TickDelay(() -> UScreen.displayScreen(screen), 1); } /** * Close the current open GUI screen. */ public static void closeScreen() { UScreen.displayScreen(null); } /** * Gets the delta time (in milliseconds) between frames. *

* Not to be confused with Minecraft deltaTicks / renderPartialTicks, which can be gotten via * {@link cc.polyfrost.oneconfig.events.event.TimerUpdateEvent} *

* * @return the delta time. */ public static float getDeltaTime() { return deltaTime; } @Subscribe private void onRenderEvent(RenderEvent event) { if (event.stage == Stage.START) { if (time == -1) time = UMinecraft.getTime(); else { long currentTime = UMinecraft.getTime(); deltaTime = currentTime - time; time = currentTime; } } } }