aboutsummaryrefslogtreecommitdiff
path: root/src/main/java/at/hannibal2/skyhanni/utils/RenderUtils.kt
diff options
context:
space:
mode:
authorhannibal2 <24389977+hannibal00212@users.noreply.github.com>2023-01-20 22:15:08 +0100
committerhannibal2 <24389977+hannibal00212@users.noreply.github.com>2023-01-20 22:15:08 +0100
commita66db31bd1388d411365debf2914aa686c40dae0 (patch)
tree5b9235a5f76f318d1551ba747c47927afdcdc018 /src/main/java/at/hannibal2/skyhanni/utils/RenderUtils.kt
parent9d411375b4b493d797174512297ab57c6df54769 (diff)
downloadskyhanni-a66db31bd1388d411365debf2914aa686c40dae0.tar.gz
skyhanni-a66db31bd1388d411365debf2914aa686c40dae0.tar.bz2
skyhanni-a66db31bd1388d411365debf2914aa686c40dae0.zip
Add items to line renderer. Used for reputationHelper.
Diffstat (limited to 'src/main/java/at/hannibal2/skyhanni/utils/RenderUtils.kt')
-rw-r--r--src/main/java/at/hannibal2/skyhanni/utils/RenderUtils.kt40
1 files changed, 38 insertions, 2 deletions
diff --git a/src/main/java/at/hannibal2/skyhanni/utils/RenderUtils.kt b/src/main/java/at/hannibal2/skyhanni/utils/RenderUtils.kt
index e3052874f..a4e550f65 100644
--- a/src/main/java/at/hannibal2/skyhanni/utils/RenderUtils.kt
+++ b/src/main/java/at/hannibal2/skyhanni/utils/RenderUtils.kt
@@ -2,6 +2,7 @@ package at.hannibal2.skyhanni.utils
import at.hannibal2.skyhanni.config.core.config.Position
import at.hannibal2.skyhanni.config.core.util.render.TextRenderUtils.drawStringScaled
+import at.hannibal2.skyhanni.utils.NEUItems.renderOnScreen
import at.hannibal2.skyhanni.utils.StringUtils.removeColor
import net.minecraft.client.Minecraft
import net.minecraft.client.gui.FontRenderer
@@ -12,6 +13,7 @@ import net.minecraft.client.renderer.Tessellator
import net.minecraft.client.renderer.vertex.DefaultVertexFormats
import net.minecraft.entity.Entity
import net.minecraft.inventory.Slot
+import net.minecraft.item.ItemStack
import net.minecraft.util.AxisAlignedBB
import net.minecraft.util.MathHelper
import net.minecraft.util.ResourceLocation
@@ -424,7 +426,7 @@ object RenderUtils {
return lastValue + (currentValue - lastValue) * multiplier
}
- fun Position.renderString(string: String?, offsetY: Int = 0, center: Boolean = true) {
+ fun Position.renderString(string: String?, extraOffsetX: Int = 0, offsetY: Int = 0, center: Boolean = true) {
val minecraft = Minecraft.getMinecraft()
if (minecraft.gameSettings.keyBindPlayerList.isKeyDown) return
@@ -441,7 +443,7 @@ object RenderUtils {
(200 - renderer.getStringWidth(display.removeColor())) / 2
} else {
0
- }
+ } + extraOffsetX
val x = getAbsX(resolution, 200) + offsetX
val y = getAbsY(resolution, 16) + offsetY
@@ -462,6 +464,40 @@ object RenderUtils {
}
}
+ /**
+ * Accepts a list of lines to print.
+ * Each line is a list of things to print. Can print String or ItemStack objects.
+ */
+ fun Position.renderStringsAndItems(list: List<List<Any>>, extraSpace: Int = 0) {
+ if (list.isEmpty()) return
+
+ var offsetY = 0
+ for (line in list) {
+ renderLine(line, offsetY)
+ offsetY += 10 + extraSpace + 2
+ }
+ }
+
+ private fun Position.renderLine(line: List<Any>, offsetY: Int) {
+ val renderer = Minecraft.getMinecraft().fontRendererObj
+ val resolution = ScaledResolution(Minecraft.getMinecraft())
+ var offsetX = 0
+ for (any in line) {
+ if (any is String) {
+ renderString(any, offsetX, offsetY, center = false)
+ val width = renderer.getStringWidth(any.removeColor())
+ offsetX += width
+ }
+ if (any is ItemStack) {
+ val isX = getAbsX(resolution, 0) + offsetX
+ val isY = getAbsY(resolution, 0) + offsetY
+
+ any.renderOnScreen(isX.toFloat(), isY.toFloat())
+ offsetX += 12
+ }
+ }
+ }
+
// totally not modified Autumn Client's TargetStrafe
fun drawCircle(entity: Entity, partialTicks: Float, rad: Double, color: Color) {
GlStateManager.pushMatrix()