blob: 8507deb6e53c4d44bcc49982ebcc8939861a2289 (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
|
package at.hannibal2.skyhanni.features.misc
import at.hannibal2.skyhanni.SkyHanniMod
import at.hannibal2.skyhanni.events.GuiRenderItemEvent
import at.hannibal2.skyhanni.events.LorenzToolTipEvent
import at.hannibal2.skyhanni.utils.ItemUtils
import at.hannibal2.skyhanni.utils.LorenzUtils
import at.hannibal2.skyhanni.utils.SkyBlockItemModifierUtils.getAppliedPocketSackInASack
import at.hannibal2.skyhanni.utils.StringUtils.matchMatcher
import net.minecraft.client.renderer.GlStateManager
import net.minecraftforge.fml.common.eventhandler.SubscribeEvent
class PocketSackInASackDisplay {
private val config get() = SkyHanniMod.feature.misc.pocketSackInASack
private val valPattern = "§5§o§7This sack is stitched with (?<number>.*)§7.".toPattern()
@SubscribeEvent
fun onRenderItemOverlayPost(event: GuiRenderItemEvent.RenderOverlayEvent.GuiRenderItemPost) {
val stack = event.stack ?: return
if (!LorenzUtils.inSkyBlock || stack.stackSize != 1) return
if (!config.showOverlay) return
val pocketSackInASackApplied = stack.getAppliedPocketSackInASack() ?: return
val stackTip = "§a$pocketSackInASackApplied"
GlStateManager.disableLighting()
GlStateManager.disableDepth()
GlStateManager.disableBlend()
val fontRenderer = event.fontRenderer
val x = event.x + 13 - fontRenderer.getStringWidth(stackTip)
val y = event.y + 1
val scale = 0.9
GlStateManager.pushMatrix()
GlStateManager.translate(x.toFloat(), y.toFloat(), 0f)
GlStateManager.scale(scale, scale, scale)
fontRenderer.drawStringWithShadow(stackTip, 0f, 0f, 16777215)
val reverseScale = 1 / 0.7
GlStateManager.scale(reverseScale, reverseScale, reverseScale)
GlStateManager.popMatrix()
GlStateManager.enableLighting()
GlStateManager.enableDepth()
}
@SubscribeEvent
fun onTooltip(event: LorenzToolTipEvent) {
if (!LorenzUtils.inSkyBlock) return
if (!config.replaceLore) return
if (!ItemUtils.isSack(event.itemStack.displayName)) return
val it = event.toolTip.listIterator()
for (line in it) {
valPattern.matchMatcher(line) {
val replace = when (group("number")) {
"a" -> "§c1"
"two" -> "§62"
"three" -> "§a3"
else -> "0"
}
it.set(line.replace(Regex("\\b${group("number")}\\b"), "$replace§7/§b3"))
}
}
}
}
|