diff options
author | Kevinthegreat <92656833+kevinthegreat1@users.noreply.github.com> | 2023-05-22 20:30:12 -0400 |
---|---|---|
committer | Kevinthegreat <92656833+kevinthegreat1@users.noreply.github.com> | 2023-05-26 16:34:47 -0400 |
commit | 049f988c904e7bee85e4d0a03e2dbbcf0047d27e (patch) | |
tree | a530446b7a7f74219a1649c76d63148b785ffead /src/main/java/me/xmrvizzy/skyblocker/utils/MessageScheduler.java | |
parent | d467fab0a81541d5518728edf1028fa2f2dd3e54 (diff) | |
download | Skyblocker-049f988c904e7bee85e4d0a03e2dbbcf0047d27e.tar.gz Skyblocker-049f988c904e7bee85e4d0a03e2dbbcf0047d27e.tar.bz2 Skyblocker-049f988c904e7bee85e4d0a03e2dbbcf0047d27e.zip |
Add Livid Color
Diffstat (limited to 'src/main/java/me/xmrvizzy/skyblocker/utils/MessageScheduler.java')
-rw-r--r-- | src/main/java/me/xmrvizzy/skyblocker/utils/MessageScheduler.java | 43 |
1 files changed, 43 insertions, 0 deletions
diff --git a/src/main/java/me/xmrvizzy/skyblocker/utils/MessageScheduler.java b/src/main/java/me/xmrvizzy/skyblocker/utils/MessageScheduler.java new file mode 100644 index 00000000..85cc963d --- /dev/null +++ b/src/main/java/me/xmrvizzy/skyblocker/utils/MessageScheduler.java @@ -0,0 +1,43 @@ +package me.xmrvizzy.skyblocker.utils; + +import net.minecraft.client.MinecraftClient; + +/** + * A scheduler for sending chat messages or commands. Use the instance in {@link me.xmrvizzy.skyblocker.SkyblockerMod#messageScheduler SkyblockerMod.messageScheduler}. Do not instantiate this class. + */ +@SuppressWarnings("deprecation") +public class MessageScheduler extends Scheduler { + private long lastMessage = 0; + + public void sendMessageAfterCooldown(String message) { + if (lastMessage + 200 < System.currentTimeMillis()) { + sendMessage(message); + lastMessage = System.currentTimeMillis(); + } else { + tasks.add(new ScheduledTask(() -> sendMessage(message), 0)); + } + } + + private void sendMessage(String message) { + if (MinecraftClient.getInstance().player != null) { + MinecraftClient.getInstance().inGameHud.getChatHud().addToMessageHistory(message); + if (message.startsWith("/")) { + MinecraftClient.getInstance().player.networkHandler.sendCommand(message.substring(1)); + } else { + MinecraftClient.getInstance().player.networkHandler.sendChatMessage(message); + } + } + } + + public void queueMessage(String message, int delay) { + tasks.add(new ScheduledTask(() -> sendMessage(message), delay)); + } + + @Override + protected void runTask(Runnable task) { + if (lastMessage + 200 < System.currentTimeMillis()) { + task.run(); + lastMessage = System.currentTimeMillis(); + } + } +} |