Updated for 1.20

This commit is contained in:
Yuuki Chan 2023-06-08 14:13:41 +09:00
parent 2b12d2cf70
commit 0065f53bad
13 changed files with 241 additions and 259 deletions

View file

@ -1,6 +1,6 @@
# Better Ping Display - Fabric Edition # Better Ping Display - Fabric Edition
[![](http://cf.way2muchnoise.eu/full_406343_downloads.svg)](https://curseforge.com/minecraft/mc-mods/better-ping-display-fabric) [![](http://cf.way2muchnoise.eu/full_406343_downloads.svg)](https://curseforge.com/minecraft/mc-mods/better-ping-display-fabric)
A [Fabric](https://fabricmc.net/) mod for Minecraft to display each player's ping in the player list as a number. A [Fabric](https://fabricmc.net/) mod for Minecraft to display each player's ping in the player list as a number.
@ -13,12 +13,12 @@ This is a client-side mod. The server doesn't need to have it installed. It work
## Configuration ## Configuration
This mod's config file is `betterpingdisplay.json`. It contains the following options: This mod's config file is `betterpingdisplay.json`. It contains the following options:
| Option | Default Value | Description | | Option | Default Value | Description |
|----------------------|---------------|--------------------------------------------------------------------------------------------------------------------| |---|---|---|
| autoColorPingText | `true` | Whether to color a player's ping based on their latency. E.g, low latency = green, high latency = red | | autoColorPingText | `true` | Whether to color a player's ping based on their latency. E.g, low latency = green, high latency = red |
| renderPingBars | `false` | Whether to also draw the default Minecraft ping bars | | renderPingBars | `false` | Whether to also draw the default Minecraft ping bars |
| pingTextColor | `#A0A0A0` | The ping text color to use. Only works whens `autoColorPingText` is false | | pingTextColor | `#A0A0A0` | The ping text color to use. Only works whens `autoColorPingText` is false |
| pingTextFormatString | `%dms` | The format string for ping text. Must include a `%d`, which will be replaced dynamically by the actual ping value. | | pingTextFormatString | `%dms` | The format string for ping text. Must include a `%d`, which will be replaced dynamically by the actual ping value.
## Supported Minecraft Versions ## Supported Minecraft Versions
* **1.15.x** * **1.15.x**
@ -26,6 +26,7 @@ This mod's config file is `betterpingdisplay.json`. It contains the following op
* **1.17.x** * **1.17.x**
* **1.18.x** * **1.18.x**
* **1.19.x** * **1.19.x**
* **1.20**
## Requirements ## Requirements
* [Fabric](https://fabricmc.net/) * [Fabric](https://fabricmc.net/)

View file

@ -1,5 +1,5 @@
plugins { plugins {
id 'fabric-loom' version '0.12-SNAPSHOT' id 'fabric-loom' version '1.2-SNAPSHOT'
id 'maven-publish' id 'maven-publish'
} }
@ -32,18 +32,10 @@ processResources {
} }
} }
tasks.withType(JavaCompile) { tasks.withType(JavaCompile).configureEach {
options.encoding = "UTF-8" options.encoding = "UTF-8"
} }
// Loom will automatically attach sourcesJar to a RemapSourcesJar task and to the "build" task
// if it is present.
// If you remove this task, sources will not be generated.
task sourcesJar(type: Jar, dependsOn: classes) {
classifier = "sources"
from sourceSets.main.allSource
}
jar { jar {
from "LICENSE" from "LICENSE"
} }
@ -56,9 +48,6 @@ publishing {
artifact(remapJar) { artifact(remapJar) {
builtBy remapJar builtBy remapJar
} }
artifact(sourcesJar) {
builtBy remapSourcesJar
}
} }
} }

View file

@ -3,15 +3,15 @@ org.gradle.jvmargs=-Xmx1G
# Fabric Properties # Fabric Properties
# check these on https://fabricmc.net/use # check these on https://fabricmc.net/use
minecraft_version=1.19.4 minecraft_version=1.20
yarn_mappings=1.19.4+build.1 yarn_mappings=1.20+build.1
loader_version=0.14.17 loader_version=0.14.21
# Mod Properties # Mod Properties
mod_version = 1.1.2 mod_version = 1.1.3
maven_group = com.vladmarica maven_group = com.vladmarica
archives_base_name = BetterPingDisplay-Fabric archives_base_name = BetterPingDisplay-Fabric
# Dependencies # Dependencies
# currently not on the main fabric site, check on the maven: https://maven.fabricmc.net/net/fabricmc/fabric-api/fabric-api # currently not on the main fabric site, check on the maven: https://maven.fabricmc.net/net/fabricmc/fabric-api/fabric-api
fabric_version=0.76.0+1.19.4 fabric_version=0.83.0+1.20

View file

@ -1,5 +1,5 @@
distributionBase=GRADLE_USER_HOME distributionBase=GRADLE_USER_HOME
distributionPath=wrapper/dists distributionPath=wrapper/dists
distributionUrl=https\://services.gradle.org/distributions/gradle-7.3-bin.zip distributionUrl=https\://services.gradle.org/distributions/gradle-8.1.1-bin.zip
zipStoreBase=GRADLE_USER_HOME zipStoreBase=GRADLE_USER_HOME
zipStorePath=wrapper/dists zipStorePath=wrapper/dists

View file

@ -1,52 +1,53 @@
package com.vladmarica.betterpingdisplay; package com.vladmarica.betterpingdisplay;
import com.vladmarica.betterpingdisplay.Config.ConfigData; import com.vladmarica.betterpingdisplay.Config.ConfigData;
import java.io.File;
import java.nio.file.Path;
import net.fabricmc.api.ModInitializer; import net.fabricmc.api.ModInitializer;
import net.fabricmc.loader.api.FabricLoader; import net.fabricmc.loader.api.FabricLoader;
import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.LogManager;
import org.apache.logging.log4j.Logger; import org.apache.logging.log4j.Logger;
import java.io.File;
import java.nio.file.Path;
public class BetterPingDisplayMod implements ModInitializer { public class BetterPingDisplayMod implements ModInitializer {
public static final String MODID = "betterpingdisplay"; public static final String MODID = "betterpingdisplay";
public static final Logger LOGGER = LogManager.getLogger(MODID); public static final Logger LOGGER = LogManager.getLogger(MODID);
private static final String CONFIG_FILE_NAME = MODID + ".json"; private static final String CONFIG_FILE_NAME = MODID + ".json";
private static BetterPingDisplayMod INSTANCE; private static BetterPingDisplayMod INSTANCE;
private Config config = new Config(); private Config config = new Config();
@Override @Override
public void onInitialize() { public void onInitialize() {
INSTANCE = this; INSTANCE = this;
Path configFilePath = FabricLoader.getInstance().getConfigDir().resolve(CONFIG_FILE_NAME); Path configFilePath = FabricLoader.getInstance().getConfigDir().resolve(CONFIG_FILE_NAME);
File configFile = configFilePath.toFile(); File configFile = configFilePath.toFile();
if (configFile.exists()) { if (configFile.exists()) {
try { try {
ConfigData data = Config.loadConfigFile(configFile); ConfigData data = Config.loadConfigFile(configFile);
config = new Config(data); config = new Config(data);
Config.writeConfigFile(configFile, data); Config.writeConfigFile(configFile, data);
} catch (Exception ex) { } catch (Exception ex) {
LOGGER.error("Failed to load config file, using default. Error: {}", ex.getMessage()); LOGGER.error("Failed to load config file, using default. Error: {}", ex.getMessage());
} }
} else { } else {
try { try {
LOGGER.warn("Could not find config file, creating a default one"); LOGGER.warn("Could not find config file, creating a default one");
Config.writeConfigFile(configFile, new ConfigData()); Config.writeConfigFile(configFile, new ConfigData());
} catch (Exception ex) { } catch (Exception ex) {
LOGGER.error("Failed to write default config file. Error: {}", ex.getMessage()); LOGGER.error("Failed to write default config file. Error: {}", ex.getMessage());
} }
} }
LOGGER.info("BetterPingDisplay mod loaded"); LOGGER.info("BetterPingDisplay mod loaded");
} }
public Config getConfig() { public Config getConfig() {
return config; return config;
} }
public static BetterPingDisplayMod instance() { public static BetterPingDisplayMod instance() {
return INSTANCE; return INSTANCE;
} }
} }

View file

@ -3,103 +3,96 @@ package com.vladmarica.betterpingdisplay;
import com.google.gson.Gson; import com.google.gson.Gson;
import com.google.gson.GsonBuilder; import com.google.gson.GsonBuilder;
import com.google.gson.annotations.Expose; import com.google.gson.annotations.Expose;
import java.io.File;
import java.io.FileReader; import java.io.*;
import java.io.FileWriter;
import java.io.IOException;
import java.io.Serializable;
public class Config { public class Config {
private static final int DEFAULT_PING_TEXT_COLOR = 0xA0A0A0; private static final int DEFAULT_PING_TEXT_COLOR = 0xA0A0A0;
private static final String DEFAULT_PING_TEXT_FORMAT = "%dms"; private static final String DEFAULT_PING_TEXT_FORMAT = "%dms";
private final boolean autoColorPingText; private final boolean autoColorPingText;
private final boolean renderPingBars; private final boolean renderPingBars;
private int textColor = DEFAULT_PING_TEXT_COLOR; private int textColor = DEFAULT_PING_TEXT_COLOR;
private String textFormatString = DEFAULT_PING_TEXT_FORMAT; private String textFormatString = DEFAULT_PING_TEXT_FORMAT;
public Config(ConfigData configFileFormat) { public Config(ConfigData configFileFormat) {
if (configFileFormat.pingTextColor.startsWith("#")) { if (configFileFormat.pingTextColor.startsWith("#")) {
try { try {
textColor = Integer.parseInt(configFileFormat.pingTextColor.substring(1), 16); textColor = Integer.parseInt(configFileFormat.pingTextColor.substring(1), 16);
} } catch (NumberFormatException ex) {
catch (NumberFormatException ex) { BetterPingDisplayMod.LOGGER.error("Config option 'pingTextColor' is invalid - it must be a hex color code");
BetterPingDisplayMod.LOGGER.error("Config option 'pingTextColor' is invalid - it must be a hex color code"); }
} } else {
} BetterPingDisplayMod.LOGGER.error("Config option 'pingTextColor' is invalid - it must be a hex color code");
else { }
BetterPingDisplayMod.LOGGER.error("Config option 'pingTextColor' is invalid - it must be a hex color code");
if (configFileFormat.pingTextFormatString.contains("%d")) {
textFormatString = configFileFormat.pingTextFormatString;
} else {
BetterPingDisplayMod.LOGGER.error("Config option 'pingTextFormatString' is invalid - it needs to contain %d");
}
autoColorPingText = configFileFormat.autoColorPingText;
renderPingBars = configFileFormat.renderPingBars;
} }
if (configFileFormat.pingTextFormatString.contains("%d")) { public Config() {
textFormatString = configFileFormat.pingTextFormatString; this(new ConfigData());
}
else {
BetterPingDisplayMod.LOGGER.error("Config option 'pingTextFormatString' is invalid - it needs to contain %d");
} }
autoColorPingText = configFileFormat.autoColorPingText; public int getTextColor() {
renderPingBars = configFileFormat.renderPingBars; return this.textColor;
}
public Config() {
this(new ConfigData());
}
public int getTextColor() {
return this.textColor;
}
public String getTextFormatString() {
return this.textFormatString;
}
public boolean shouldAutoColorPingText() {
return this.autoColorPingText;
}
public boolean shouldRenderPingBars() {
return this.renderPingBars;
}
public static ConfigData loadConfigFile(File configFile) throws IOException {
FileReader reader = null;
try {
Gson gson = new Gson();
reader = new FileReader(configFile);
return gson.fromJson(reader, ConfigData.class);
} }
finally {
if (reader != null) { public String getTextFormatString() {
reader.close(); return this.textFormatString;
}
} }
}
public static void writeConfigFile(File configFile, ConfigData data) throws IOException { public boolean shouldAutoColorPingText() {
FileWriter writer = null; return this.autoColorPingText;
try {
Gson gson = new GsonBuilder().setPrettyPrinting().create();
writer = new FileWriter(configFile);
writer.write(gson.toJson(data));
} finally {
if (writer != null) {
writer.close();
}
} }
}
public static class ConfigData implements Serializable { public boolean shouldRenderPingBars() {
@Expose return this.renderPingBars;
private boolean autoColorPingText = true; }
@Expose public static ConfigData loadConfigFile(File configFile) throws IOException {
private boolean renderPingBars = false; FileReader reader = null;
try {
Gson gson = new Gson();
reader = new FileReader(configFile);
return gson.fromJson(reader, ConfigData.class);
} finally {
if (reader != null) {
reader.close();
}
}
}
@Expose public static void writeConfigFile(File configFile, ConfigData data) throws IOException {
private String pingTextColor = "#A0A0A0"; FileWriter writer = null;
try {
Gson gson = new GsonBuilder().setPrettyPrinting().create();
writer = new FileWriter(configFile);
writer.write(gson.toJson(data));
} finally {
if (writer != null) {
writer.close();
}
}
}
@Expose public static class ConfigData implements Serializable {
private String pingTextFormatString = "%dms"; @Expose
} private boolean autoColorPingText = true;
@Expose
private boolean renderPingBars = false;
@Expose
private String pingTextColor = "#A0A0A0";
@Expose
private String pingTextFormatString = "%dms";
}
} }

View file

@ -3,36 +3,37 @@ package com.vladmarica.betterpingdisplay.hud;
import com.google.common.annotations.VisibleForTesting; import com.google.common.annotations.VisibleForTesting;
public final class ColorUtil { public final class ColorUtil {
public static int interpolate(int colorStart, int colorEnd, float offset) { public static int interpolate(int colorStart, int colorEnd, float offset) {
if (offset < 0 || offset > 1) { if (offset < 0 || offset > 1) {
throw new IllegalArgumentException("Offset must be between 0.0 and 1.0"); throw new IllegalArgumentException("Offset must be between 0.0 and 1.0");
}
int redDiff = getRed(colorEnd) - getRed(colorStart);
int greenDiff = getGreen(colorEnd) - getGreen(colorStart);
int blueDiff = getBlue(colorEnd) - getBlue(colorStart);
int newRed = Math.round(getRed(colorStart) + (redDiff * offset));
int newGreen = Math.round(getGreen(colorStart) + (greenDiff * offset));
int newBlue = Math.round(getBlue(colorStart) + (blueDiff * offset));
return (newRed << 16) | (newGreen << 8) | newBlue;
} }
int redDiff = getRed(colorEnd) - getRed(colorStart); @VisibleForTesting
int greenDiff = getGreen(colorEnd) - getGreen(colorStart); static int getRed(int color) {
int blueDiff = getBlue(colorEnd) - getBlue(colorStart); return (color >> 16) & 0xFF;
}
int newRed = Math.round(getRed(colorStart) + (redDiff * offset)); @VisibleForTesting
int newGreen = Math.round(getGreen(colorStart) + (greenDiff * offset)); static int getGreen(int color) {
int newBlue = Math.round(getBlue(colorStart) + (blueDiff * offset)); return (color >> 8) & 0xFF;
}
return (newRed << 16) | (newGreen << 8) | newBlue; @VisibleForTesting
} static int getBlue(int color) {
return color & 0xFF;
}
@VisibleForTesting private ColorUtil() {
static int getRed(int color) { }
return (color >> 16) & 0xFF;
}
@VisibleForTesting
static int getGreen(int color) {
return (color >> 8) & 0xFF;
}
@VisibleForTesting
static int getBlue(int color) {
return color & 0xFF;
}
private ColorUtil() {}
} }

View file

@ -5,38 +5,36 @@ import com.vladmarica.betterpingdisplay.BetterPingDisplayMod;
import com.vladmarica.betterpingdisplay.Config; import com.vladmarica.betterpingdisplay.Config;
import com.vladmarica.betterpingdisplay.mixin.PlayerListHudInvoker; import com.vladmarica.betterpingdisplay.mixin.PlayerListHudInvoker;
import net.minecraft.client.MinecraftClient; import net.minecraft.client.MinecraftClient;
import net.minecraft.client.font.TextRenderer; import net.minecraft.client.gui.DrawContext;
import net.minecraft.client.gui.hud.PlayerListHud; import net.minecraft.client.gui.hud.PlayerListHud;
import net.minecraft.client.network.PlayerListEntry; import net.minecraft.client.network.PlayerListEntry;
import net.minecraft.client.util.math.MatrixStack;
public final class CustomPlayerListHud { public final class CustomPlayerListHud {
private static final int PING_TEXT_RENDER_OFFSET = -13; private static final int PING_TEXT_RENDER_OFFSET = -13;
private static final int PING_BARS_WIDTH = 11; private static final int PING_BARS_WIDTH = 11;
private static final Config config = BetterPingDisplayMod.instance().getConfig(); private static final Config config = BetterPingDisplayMod.instance().getConfig();
public static void renderPingDisplay( public static void renderPingDisplay(
MinecraftClient client, PlayerListHud hud, MatrixStack matrixStack, int width, int x, int y, PlayerListEntry player) { MinecraftClient client, PlayerListHud hud, DrawContext context, int width, int x, int y, PlayerListEntry player) {
TextRenderer textRenderer = client.textRenderer; String pingString = String.format(config.getTextFormatString(), player.getLatency());
int pingStringWidth = client.textRenderer.getWidth(pingString);
int pingTextColor = config.shouldAutoColorPingText()
? PingColors.getColor(player.getLatency()) : config.getTextColor();
int textX = width + x - pingStringWidth + PING_TEXT_RENDER_OFFSET;
String pingString = String.format(config.getTextFormatString(), player.getLatency()); if (!config.shouldRenderPingBars()) {
int pingStringWidth = textRenderer.getWidth(pingString); textX += PING_BARS_WIDTH;
int pingTextColor = config.shouldAutoColorPingText() ? PingColors.getColor(player.getLatency()) : config.getTextColor(); }
int textX = width + x - pingStringWidth + PING_TEXT_RENDER_OFFSET;
if (!config.shouldRenderPingBars()) { // Draw the ping text for the given player
textX += PING_BARS_WIDTH; context.drawTextWithShadow(client.textRenderer, pingString, textX, y, pingTextColor);
if (config.shouldRenderPingBars()) {
((PlayerListHudInvoker) hud).invokeRenderLatencyIcon(context, width, x, y, player);
} else {
// If we don't render ping bars, we need to reset the render system color so the rest
// of the player list renders properly
RenderSystem.setShaderColor(1.0F, 1.0F, 1.0F, 1.0F);
}
} }
// Draw the ping text for the given player
textRenderer.drawWithShadow(matrixStack, pingString, (float) textX, (float) y, pingTextColor);
if (config.shouldRenderPingBars()) {
((PlayerListHudInvoker) hud).invokeRenderLatencyIcon(matrixStack, width, x, y, player);
} else {
// If we don't render ping bars, we need to reset the render system color so the rest
// of the player list renders properly
RenderSystem.setShaderColor(1.0F, 1.0F, 1.0F, 1.0F);
}
}
} }

View file

@ -3,37 +3,38 @@ package com.vladmarica.betterpingdisplay.hud;
import net.minecraft.util.math.MathHelper; import net.minecraft.util.math.MathHelper;
public final class PingColors { public final class PingColors {
public static final int PING_START = 0; public static final int PING_START = 0;
public static final int PING_MID = 150; public static final int PING_MID = 150;
public static final int PING_END = 300; public static final int PING_END = 300;
public static final int COLOR_GREY = 0x535353; public static final int COLOR_GREY = 0x535353;
public static final int COLOR_START = 0x00E676; public static final int COLOR_START = 0x00E676;
public static final int COLOR_MID = 0xD6CD30; public static final int COLOR_MID = 0xD6CD30;
public static final int COLOR_END = 0xE53935; public static final int COLOR_END = 0xE53935;
public static int getColor(int ping) { public static int getColor(int ping) {
if (ping < PING_START) { if (ping < PING_START) {
return COLOR_GREY; return COLOR_GREY;
}
if (ping < PING_MID) {
return ColorUtil.interpolate(
COLOR_START,
COLOR_MID,
computeOffset(PING_START, PING_MID, ping));
}
return ColorUtil.interpolate(
COLOR_MID,
COLOR_END,
computeOffset(PING_MID, PING_END, Math.min(ping, PING_END)));
} }
if (ping < PING_MID) { private static float computeOffset(int start, int end, int value) {
return ColorUtil.interpolate( float offset = (value - start) / (float) (end - start);
COLOR_START, return MathHelper.clamp(offset, 0.0F, 1.0F);
COLOR_MID,
computeOffset(PING_START, PING_MID, ping));
} }
return ColorUtil.interpolate( private PingColors() {
COLOR_MID, }
COLOR_END,
computeOffset(PING_MID, PING_END, Math.min(ping, PING_END)));
}
private static float computeOffset(int start, int end, int value) {
float offset = (value - start) / (float) ( end - start);
return MathHelper.clamp(offset, 0.0F, 1.0F);
}
private PingColors() {}
} }

View file

@ -1,13 +1,13 @@
package com.vladmarica.betterpingdisplay.mixin; package com.vladmarica.betterpingdisplay.mixin;
import net.minecraft.client.gui.DrawContext;
import net.minecraft.client.gui.hud.PlayerListHud; import net.minecraft.client.gui.hud.PlayerListHud;
import net.minecraft.client.network.PlayerListEntry; import net.minecraft.client.network.PlayerListEntry;
import net.minecraft.client.util.math.MatrixStack;
import org.spongepowered.asm.mixin.Mixin; import org.spongepowered.asm.mixin.Mixin;
import org.spongepowered.asm.mixin.gen.Invoker; import org.spongepowered.asm.mixin.gen.Invoker;
@Mixin(PlayerListHud.class) @Mixin(PlayerListHud.class)
public interface PlayerListHudInvoker { public interface PlayerListHudInvoker {
@Invoker("renderLatencyIcon") @Invoker("renderLatencyIcon")
void invokeRenderLatencyIcon(MatrixStack matrices, int width, int x, int y, PlayerListEntry entry); void invokeRenderLatencyIcon(DrawContext context, int width, int x, int y, PlayerListEntry entry);
} }

View file

@ -2,11 +2,9 @@ package com.vladmarica.betterpingdisplay.mixin;
import com.vladmarica.betterpingdisplay.hud.CustomPlayerListHud; import com.vladmarica.betterpingdisplay.hud.CustomPlayerListHud;
import net.minecraft.client.MinecraftClient; import net.minecraft.client.MinecraftClient;
import net.minecraft.client.gui.DrawContext;
import net.minecraft.client.gui.hud.PlayerListHud; import net.minecraft.client.gui.hud.PlayerListHud;
import net.minecraft.client.network.PlayerListEntry; import net.minecraft.client.network.PlayerListEntry;
import net.minecraft.client.util.math.MatrixStack;
import net.minecraft.scoreboard.Scoreboard;
import net.minecraft.scoreboard.ScoreboardObjective;
import org.jetbrains.annotations.NotNull; import org.jetbrains.annotations.NotNull;
import org.spongepowered.asm.mixin.Final; import org.spongepowered.asm.mixin.Final;
import org.spongepowered.asm.mixin.Mixin; import org.spongepowered.asm.mixin.Mixin;
@ -19,32 +17,32 @@ import org.spongepowered.asm.mixin.injection.Redirect;
@Mixin(PlayerListHud.class) @Mixin(PlayerListHud.class)
public abstract class PlayerListHudMixin { public abstract class PlayerListHudMixin {
@Unique @Unique
@Final @Final
private static final int PLAYER_SLOT_EXTRA_WIDTH = 45; private static final int PLAYER_SLOT_EXTRA_WIDTH = 45;
@Shadow @Shadow
@Final @Final
private MinecraftClient client; private MinecraftClient client;
/** /**
* Increases the int constant {@code 13} in the {@link PlayerListHud#render} method by * Increases the int constant {@code 13} in the {@link PlayerListHud#render} method by
* {@value #PLAYER_SLOT_EXTRA_WIDTH}. This constant is used to define the width of the "slots" in the player list. * {@value #PLAYER_SLOT_EXTRA_WIDTH}. This constant is used to define the width of the "slots" in the player list.
* In order to fit the ping text, this needs to be increased. * In order to fit the ping text, this needs to be increased.
*/ */
@ModifyConstant(method = "render", constant = @Constant(intValue = 13)) @ModifyConstant(method = "render", constant = @Constant(intValue = 13))
private int modifySlotWidthConstant(int original) { private int modifySlotWidthConstant(int original) {
return original + PLAYER_SLOT_EXTRA_WIDTH; return original + PLAYER_SLOT_EXTRA_WIDTH;
} }
/** /**
* Redirects the call to {@code renderLatencyIcon} in {@link PlayerListHud#render} to instead call * Redirects the call to {@code renderLatencyIcon} in {@link PlayerListHud#render} to instead call
* {@link CustomPlayerListHud#renderPingDisplay}. * {@link CustomPlayerListHud#renderPingDisplay}.
*/ */
@Redirect(method = "render", @Redirect(method = "render",
at = @At(value = "INVOKE", target = "net/minecraft/client/gui/hud/PlayerListHud.renderLatencyIcon(Lnet/minecraft/client/util/math/MatrixStack;IIILnet/minecraft/client/network/PlayerListEntry;)V")) at = @At(value = "INVOKE", target = "net/minecraft/client/gui/hud/PlayerListHud.renderLatencyIcon(Lnet/minecraft/client/gui/DrawContext;IIILnet/minecraft/client/network/PlayerListEntry;)V"))
private void redirectRenderLatencyIconCall( private void redirectRenderLatencyIconCall(
PlayerListHud instance, MatrixStack matrices, int width, int x, int y, @NotNull PlayerListEntry entry) { PlayerListHud instance, DrawContext context, int width, int x, int y, @NotNull PlayerListEntry entry) {
CustomPlayerListHud.renderPingDisplay(client, instance, matrices, width, x, y, entry); CustomPlayerListHud.renderPingDisplay(client, instance, context, width, x, y, entry);
} }
} }

View file

@ -1,7 +1,7 @@
{ {
"schemaVersion": 1, "schemaVersion": 1,
"id": "betterpingdisplay", "id": "betterpingdisplay",
"version": "1.1.1", "version": "1.1.3",
"name": "Better Ping Display", "name": "Better Ping Display",
"description": "Shows the actual ping number instead of just bars in the player list!", "description": "Shows the actual ping number instead of just bars in the player list!",

View file

@ -46,4 +46,4 @@ public class ColorUtilTest {
assertThrows(IllegalArgumentException.class, () -> ColorUtil.interpolate(0, 1, -0.1F)); assertThrows(IllegalArgumentException.class, () -> ColorUtil.interpolate(0, 1, -0.1F));
assertThrows(IllegalArgumentException.class, () -> ColorUtil.interpolate(0, 1, 1.1F)); assertThrows(IllegalArgumentException.class, () -> ColorUtil.interpolate(0, 1, 1.1F));
} }
} }