diff options
-rw-r--r-- | src/main/java/at/hannibal2/skyhanni/config/core/config/Position.java | 20 | ||||
-rw-r--r-- | src/main/java/at/hannibal2/skyhanni/config/core/config/gui/GuiPositionEditor.kt | 26 |
2 files changed, 30 insertions, 16 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 9213408e4..1e58bfa9f 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 @@ -60,10 +60,6 @@ public class Position { return position; } -// public boolean isCenterX() { -// return ; -// } - public int getRawX() { return x; } @@ -107,7 +103,7 @@ public class Position { return ret; } - public int moveX(int deltaX) { + public int moveX(int deltaX, int objWidth) { int screenWidth = new ScaledResolution(Minecraft.getMinecraft()).getScaledWidth(); boolean wasPositiveX = this.x >= 0; this.x += deltaX; @@ -132,10 +128,16 @@ public class Position { } } + if (this.x >= 0 && this.x + objWidth / 2 > screenWidth / 2) { + this.x -= screenWidth - objWidth; + } + if (this.x < 0 && this.x + objWidth / 2 <= -screenWidth / 2) { + this.x += screenWidth - objWidth; + } return deltaX; } - public int moveY(int deltaY) { + public int moveY(int deltaY, int objHeight) { int screenHeight = new ScaledResolution(Minecraft.getMinecraft()).getScaledHeight(); boolean wasPositiveY = this.y >= 0; this.y += deltaY; @@ -160,6 +162,12 @@ public class Position { } } + if (this.y >= 0 && this.y - objHeight / 2 > screenHeight / 2) { + this.y -= screenHeight - objHeight; + } + if (this.y < 0 && this.y - objHeight / 2 <= -screenHeight / 2) { + this.y += screenHeight - objHeight; + } return deltaY; } } 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 44672ff46..8bcce9055 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 @@ -90,15 +90,17 @@ class GuiPositionEditor( mouseX = Mouse.getX() * width / Minecraft.getMinecraft().displayWidth mouseY = height - Mouse.getY() * height / Minecraft.getMinecraft().displayHeight - 1 for (position in positions) { + var elementWidth = position.getDummySize(true).x + var elementHeight = position.getDummySize(true).y if (position.clicked) { - grabbedX += position.moveX(mouseX - grabbedX) - grabbedY += position.moveY(mouseY - grabbedY) + grabbedX += position.moveX(mouseX - grabbedX, elementWidth) + grabbedY += position.moveY(mouseY - grabbedY, elementHeight) } val x = position.getAbsX() val y = position.getAbsY() - val elementWidth = position.getDummySize().x - val elementHeight = position.getDummySize().y + elementWidth = position.getDummySize().x + elementHeight = position.getDummySize().y drawRect(x - border, y - border, x + elementWidth + border * 2, y + elementHeight + border * 2, -0x7fbfbfc0) } @@ -182,14 +184,16 @@ class GuiPositionEditor( } 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) + position.moveY(dist, elementHeight) } else if (keyCode == Keyboard.KEY_UP) { - position.moveY(-dist) + position.moveY(-dist, elementHeight) } else if (keyCode == Keyboard.KEY_LEFT) { - position.moveX(-dist) + position.moveX(-dist, elementWidth,) } else if (keyCode == Keyboard.KEY_RIGHT) { - position.moveX(dist) + position.moveX(dist, elementWidth) } } } @@ -212,8 +216,10 @@ class GuiPositionEditor( if (position.clicked) { mouseX = Mouse.getX() * width / Minecraft.getMinecraft().displayWidth mouseY = height - Mouse.getY() * height / Minecraft.getMinecraft().displayHeight - 1 - grabbedX += position.moveX(mouseX - grabbedX) - grabbedY += position.moveY(mouseY - grabbedY) + 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) } } |