From 650b77cff32dd45585fb363c3daa6d21e8e601b9 Mon Sep 17 00:00:00 2001 From: Anthony Hilyard Date: Thu, 30 Dec 2021 14:00:33 -0800 Subject: Ported 1.0.32 to 1.18.1. Added tooltip index to tooltip events, fixed text color alpha limitation. --- .../iceberg/mixin/TextColorMixin.java | 36 ++++++++++++++++++++++ 1 file changed, 36 insertions(+) create mode 100644 src/main/java/com/anthonyhilyard/iceberg/mixin/TextColorMixin.java (limited to 'src/main/java/com/anthonyhilyard/iceberg/mixin') diff --git a/src/main/java/com/anthonyhilyard/iceberg/mixin/TextColorMixin.java b/src/main/java/com/anthonyhilyard/iceberg/mixin/TextColorMixin.java new file mode 100644 index 0000000..2bd40ba --- /dev/null +++ b/src/main/java/com/anthonyhilyard/iceberg/mixin/TextColorMixin.java @@ -0,0 +1,36 @@ +package com.anthonyhilyard.iceberg.mixin; + +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 net.minecraft.network.chat.TextColor; + +@Mixin(TextColor.class) +public class TextColorMixin +{ + /** + * Fix an issue in TextColor parsing that makes it so only alpha values up to 0x7F are supported. + */ + @Inject(method = "parseColor", at = @At("HEAD"), cancellable = true) + private static boolean parseColor(String colorString, CallbackInfoReturnable info) + { + if (!colorString.startsWith("#")) + { + return false; + } + + try + { + int i = Integer.parseUnsignedInt(colorString.substring(1), 16); + info.setReturnValue(TextColor.fromRgb(i)); + return true; + } + catch (NumberFormatException numberformatexception) + { + info.setReturnValue(null); + return true; + } + } +} -- cgit