aboutsummaryrefslogtreecommitdiff
path: root/src/main
diff options
context:
space:
mode:
Diffstat (limited to 'src/main')
-rw-r--r--src/main/java/at/hannibal2/skyhanni/config/core/config/Position.java6
-rw-r--r--src/main/java/at/hannibal2/skyhanni/config/core/config/gui/GuiPositionEditor.kt140
-rw-r--r--src/main/java/at/hannibal2/skyhanni/config/features/GUI.java8
-rw-r--r--src/main/java/at/hannibal2/skyhanni/data/GuiEditManager.kt9
4 files changed, 53 insertions, 110 deletions
diff --git a/src/main/java/at/hannibal2/skyhanni/config/core/config/Position.java b/src/main/java/at/hannibal2/skyhanni/config/core/config/Position.java
index 1e58bfa9f..ec1f4fbfc 100644
--- a/src/main/java/at/hannibal2/skyhanni/config/core/config/Position.java
+++ b/src/main/java/at/hannibal2/skyhanni/config/core/config/Position.java
@@ -54,12 +54,6 @@ public class Position {
this.centerY = other.centerY;
}
- public Position clone() {
- Position position = new Position(x, y, centerX, centerY);
- position.internalName = internalName;
- return position;
- }
-
public int getRawX() {
return x;
}
diff --git a/src/main/java/at/hannibal2/skyhanni/config/core/config/gui/GuiPositionEditor.kt b/src/main/java/at/hannibal2/skyhanni/config/core/config/gui/GuiPositionEditor.kt
index 8bcce9055..581198168 100644
--- a/src/main/java/at/hannibal2/skyhanni/config/core/config/gui/GuiPositionEditor.kt
+++ b/src/main/java/at/hannibal2/skyhanni/config/core/config/gui/GuiPositionEditor.kt
@@ -18,7 +18,6 @@
*/
package at.hannibal2.skyhanni.config.core.config.gui
-import at.hannibal2.skyhanni.SkyHanniMod
import at.hannibal2.skyhanni.config.core.config.Position
import at.hannibal2.skyhanni.data.GuiEditManager.Companion.getAbsX
import at.hannibal2.skyhanni.data.GuiEditManager.Companion.getAbsY
@@ -32,27 +31,10 @@ import org.lwjgl.input.Keyboard
import org.lwjgl.input.Mouse
import java.io.IOException
-class GuiPositionEditor(
- overlayPositions: LinkedHashMap<Position, Position>,
-) : GuiScreen() {
- private val positions: ArrayList<Position>
- private val originalPositions: ArrayList<Position>
+class GuiPositionEditor(private val positions: List<Position>, private val border: Int) : GuiScreen() {
private var grabbedX = 0
private var grabbedY = 0
private var clickedPos = -1
- private val border = 2
-
- init {
- val pos = ArrayList<Position>()
- val ogPos = ArrayList<Position>()
- for (i in 0 until overlayPositions.size) {
- val overlay = ArrayList(overlayPositions.keys)[i]
- pos.add(overlayPositions[overlay]!!)
- ogPos.add(pos[i].clone())
- }
- positions = pos
- originalPositions = ogPos
- }
override fun onGuiClosed() {
super.onGuiClosed()
@@ -60,36 +42,22 @@ class GuiPositionEditor(
}
override fun drawScreen(unusedX: Int, unusedY: Int, partialTicks: Float) {
- var hoveredPos = -1
-
- var mouseX = Mouse.getX() * width / Minecraft.getMinecraft().displayWidth
- var mouseY = height - Mouse.getY() * height / Minecraft.getMinecraft().displayHeight - 1
- for (i in positions.indices.reversed()) {
- val position = positions[i]
- val elementWidth = position.getDummySize().x
- val elementHeight = position.getDummySize().y
- val x = position.getAbsX()
- val y = position.getAbsY()
- if (inXY(mouseX, x, mouseY, y, elementWidth, elementHeight)) {
- hoveredPos = i
- break
- }
- }
-
+ super.drawScreen(unusedX, unusedY, partialTicks)
drawDefaultBackground()
- val scaledResolution = ScaledResolution(Minecraft.getMinecraft())
+
Utils.drawStringCentered(
- "§cSkyHanni Position Editor", Minecraft.getMinecraft().fontRendererObj,
- (scaledResolution.scaledWidth / 2).toFloat(), 8f, true, 0xffffff
+ "§cSkyHanni Position Editor",
+ Minecraft.getMinecraft().fontRendererObj, (getScaledWidth() / 2).toFloat(), 8f, true, 0xffffff
)
- super.drawScreen(mouseX, mouseY, partialTicks)
+ var hoveredPos = -1
+
GlStateManager.pushMatrix()
- width = scaledResolution.scaledWidth
- height = scaledResolution.scaledHeight
- mouseX = Mouse.getX() * width / Minecraft.getMinecraft().displayWidth
- mouseY = height - Mouse.getY() * height / Minecraft.getMinecraft().displayHeight - 1
- for (position in positions) {
+ width = getScaledWidth()
+ height = getScaledHeight()
+ val mouseX = Mouse.getX() * width / Minecraft.getMinecraft().displayWidth
+ val mouseY = height - Mouse.getY() * height / Minecraft.getMinecraft().displayHeight - 1
+ for ((index, position) in positions.withIndex()) {
var elementWidth = position.getDummySize(true).x
var elementHeight = position.getDummySize(true).y
if (position.clicked) {
@@ -103,8 +71,10 @@ class GuiPositionEditor(
elementHeight = position.getDummySize().y
drawRect(x - border, y - border, x + elementWidth + border * 2, y + elementHeight + border * 2, -0x7fbfbfc0)
+ if (inXY(mouseX, x, mouseY, y, elementWidth, elementHeight)) {
+ hoveredPos = index
+ }
}
-
GlStateManager.popMatrix()
var displayPos = -1
@@ -120,20 +90,24 @@ class GuiPositionEditor(
if (displayPos != -1) {
val pos = positions[displayPos]
Utils.drawStringCentered(
- "§b" + pos.internalName, Minecraft.getMinecraft().fontRendererObj,
- (scaledResolution.scaledWidth / 2).toFloat(), 18f, true, 0xffffff
+ "§b" + pos.internalName,
+ Minecraft.getMinecraft().fontRendererObj, (getScaledWidth() / 2).toFloat(), 18f, true, 0xffffff
)
val location = "§7x: §e${pos.rawX}§7, y: §e${pos.rawY}"
Utils.drawStringCentered(
- location, Minecraft.getMinecraft().fontRendererObj,
- (scaledResolution.scaledWidth / 2).toFloat(), 28f, true, 0xffffff
+ location,
+ Minecraft.getMinecraft().fontRendererObj, (getScaledWidth() / 2).toFloat(), 28f, true, 0xffffff
)
}
}
+ private fun getScaledHeight() = ScaledResolution(Minecraft.getMinecraft()).scaledHeight
+ private fun getScaledWidth() = ScaledResolution(Minecraft.getMinecraft()).scaledWidth
+
@Throws(IOException::class)
override fun mouseClicked(originalX: Int, priginalY: Int, mouseButton: Int) {
super.mouseClicked(originalX, priginalY, mouseButton)
+
if (mouseButton != 0) return
val mouseX = Mouse.getX() * width / Minecraft.getMinecraft().displayWidth
@@ -168,40 +142,30 @@ class GuiPositionEditor(
@Throws(IOException::class)
override fun keyTyped(typedChar: Char, keyCode: Int) {
- if (clickedPos != -1) {
- val position = positions[clickedPos]
- if (keyCode == SkyHanniMod.feature.gui.keyBindReset) {
-
- position.set(originalPositions[positions.indexOf(position)])
-
- // TODO option to reset everything
-// val ii = 0
-// for (pos in positions) {
-// pos.set(originalPositions[ii])
-// }
-
-
- } else if (!position.clicked) {
- val shiftHeld = Keyboard.isKeyDown(Keyboard.KEY_LSHIFT) || Keyboard.isKeyDown(Keyboard.KEY_RSHIFT)
- val dist = if (shiftHeld) 10 else 1
- val elementWidth = position.getDummySize(true).x
- val elementHeight = position.getDummySize(true).y
- if (keyCode == Keyboard.KEY_DOWN) {
- position.moveY(dist, elementHeight)
- } else if (keyCode == Keyboard.KEY_UP) {
- position.moveY(-dist, elementHeight)
- } else if (keyCode == Keyboard.KEY_LEFT) {
- position.moveX(-dist, elementWidth,)
- } else if (keyCode == Keyboard.KEY_RIGHT) {
- position.moveX(dist, elementWidth)
- }
- }
- }
super.keyTyped(typedChar, keyCode)
+
+ if (clickedPos == -1) return
+ val position = positions[clickedPos]
+ if (position.clicked) return
+
+ val shiftHeld = Keyboard.isKeyDown(Keyboard.KEY_LSHIFT) || Keyboard.isKeyDown(Keyboard.KEY_RSHIFT)
+ val dist = if (shiftHeld) 10 else 1
+ val elementWidth = position.getDummySize(true).x
+ val elementHeight = position.getDummySize(true).y
+ if (keyCode == Keyboard.KEY_DOWN) {
+ position.moveY(dist, elementHeight)
+ } else if (keyCode == Keyboard.KEY_UP) {
+ position.moveY(-dist, elementHeight)
+ } else if (keyCode == Keyboard.KEY_LEFT) {
+ position.moveX(-dist, elementWidth)
+ } else if (keyCode == Keyboard.KEY_RIGHT) {
+ position.moveX(dist, elementWidth)
+ }
}
override fun mouseReleased(mouseX: Int, mouseY: Int, state: Int) {
super.mouseReleased(mouseX, mouseY, state)
+
for (position in positions) {
position.clicked = false
}
@@ -210,18 +174,16 @@ class GuiPositionEditor(
override fun mouseClickMove(originalX: Int, priginalY: Int, clickedMouseButton: Int, timeSinceLastClick: Long) {
super.mouseClickMove(originalX, priginalY, clickedMouseButton, timeSinceLastClick)
- var mouseX: Int
- var mouseY: Int
for (position in positions) {
- if (position.clicked) {
- mouseX = Mouse.getX() * width / Minecraft.getMinecraft().displayWidth
- mouseY = height - Mouse.getY() * height / Minecraft.getMinecraft().displayHeight - 1
- val elementWidth = position.getDummySize(true).x
- val elementHeight = position.getDummySize(true).y
- grabbedX += position.moveX(mouseX - grabbedX, elementWidth)
- grabbedY += position.moveY(mouseY - grabbedY, elementHeight)
- Utils.pushGuiScale(-1)
- }
+ if (!position.clicked) continue
+
+ val mouseX = Mouse.getX() * width / Minecraft.getMinecraft().displayWidth
+ val mouseY = height - Mouse.getY() * height / Minecraft.getMinecraft().displayHeight - 1
+ val elementWidth = position.getDummySize(true).x
+ val elementHeight = position.getDummySize(true).y
+ grabbedX += position.moveX(mouseX - grabbedX, elementWidth)
+ grabbedY += position.moveY(mouseY - grabbedY, elementHeight)
+ Utils.pushGuiScale(-1)
}
}
} \ No newline at end of file
diff --git a/src/main/java/at/hannibal2/skyhanni/config/features/GUI.java b/src/main/java/at/hannibal2/skyhanni/config/features/GUI.java
index c752e92cf..5d223fb96 100644
--- a/src/main/java/at/hannibal2/skyhanni/config/features/GUI.java
+++ b/src/main/java/at/hannibal2/skyhanni/config/features/GUI.java
@@ -26,12 +26,4 @@ public class GUI {
)
@ConfigEditorKeybind(defaultKey = Keyboard.KEY_NONE)
public int keyBindOpen = Keyboard.KEY_NONE;
-
- @Expose
- @ConfigOption(
- name = "Hotkey Reset",
- desc = "Press this key in the GUI Editor to reset the current element."
- )
- @ConfigEditorKeybind(defaultKey = Keyboard.KEY_R)
- public int keyBindReset = Keyboard.KEY_R;
}
diff --git a/src/main/java/at/hannibal2/skyhanni/data/GuiEditManager.kt b/src/main/java/at/hannibal2/skyhanni/data/GuiEditManager.kt
index 4480d0f24..b833462ef 100644
--- a/src/main/java/at/hannibal2/skyhanni/data/GuiEditManager.kt
+++ b/src/main/java/at/hannibal2/skyhanni/data/GuiEditManager.kt
@@ -61,12 +61,7 @@ class GuiEditManager {
@JvmStatic
fun openGuiEditor() {
- val help = LinkedHashMap<Position, Position>()
- for (position in latestPositions.values) {
- help[position] = position
- }
-
- SkyHanniMod.screenToOpen = GuiPositionEditor(help)
+ SkyHanniMod.screenToOpen = GuiPositionEditor(latestPositions.values.toList(), 2)
}
@JvmStatic
@@ -89,7 +84,7 @@ class GuiEditManager {
fun Position.getDummySize(random: Boolean = false): Vector2i {
if (random) {
- return Vector2i(15, 15)
+ return Vector2i(5, 5)
} else {
val (x, y) = currentBorderSize[internalName] ?: return Vector2i(1, 1)
return Vector2i(x, y)