aboutsummaryrefslogtreecommitdiff
path: root/src/main/java/kr/syeyoung/dungeonsguide/config
diff options
context:
space:
mode:
authorsyeyoung <cyong06@naver.com>2020-12-31 12:46:10 +0900
committersyeyoung <cyong06@naver.com>2020-12-31 12:46:10 +0900
commita09e7553a93a177df7a6a3c7db5a1383b08a2416 (patch)
tree6e675c819c06438b8ca4303b9890a3d0261ccb34 /src/main/java/kr/syeyoung/dungeonsguide/config
parent60a6f9ce3bd9a87bc540397740bca13f1dbc4dc8 (diff)
downloadSkyblock-Dungeons-Guide-a09e7553a93a177df7a6a3c7db5a1383b08a2416.tar.gz
Skyblock-Dungeons-Guide-a09e7553a93a177df7a6a3c7db5a1383b08a2416.tar.bz2
Skyblock-Dungeons-Guide-a09e7553a93a177df7a6a3c7db5a1383b08a2416.zip
gui feature, listeners, and editing gui
Diffstat (limited to 'src/main/java/kr/syeyoung/dungeonsguide/config')
-rwxr-xr-xsrc/main/java/kr/syeyoung/dungeonsguide/config/MFeature.java8
-rwxr-xr-xsrc/main/java/kr/syeyoung/dungeonsguide/config/guiconfig/GuiGuiLocationConfig.java25
-rw-r--r--src/main/java/kr/syeyoung/dungeonsguide/config/guiconfig/PanelDelegate.java81
3 files changed, 110 insertions, 4 deletions
diff --git a/src/main/java/kr/syeyoung/dungeonsguide/config/MFeature.java b/src/main/java/kr/syeyoung/dungeonsguide/config/MFeature.java
index 407c33bd..f151b77f 100755
--- a/src/main/java/kr/syeyoung/dungeonsguide/config/MFeature.java
+++ b/src/main/java/kr/syeyoung/dungeonsguide/config/MFeature.java
@@ -1,5 +1,6 @@
package kr.syeyoung.dungeonsguide.config;
+import kr.syeyoung.dungeonsguide.config.guiconfig.GuiGuiLocationConfig;
import kr.syeyoung.dungeonsguide.features.AbstractFeature;
import kr.syeyoung.dungeonsguide.features.GuiFeature;
import kr.syeyoung.dungeonsguide.roomedit.MPanel;
@@ -8,6 +9,7 @@ import kr.syeyoung.dungeonsguide.roomedit.elements.MLabel;
import kr.syeyoung.dungeonsguide.roomedit.elements.MStringSelectionButton;
import lombok.Getter;
import lombok.Setter;
+import net.minecraft.client.Minecraft;
import net.minecraft.client.gui.Gui;
import scala.actors.threadpool.Arrays;
@@ -35,6 +37,12 @@ public class MFeature extends MPanel {
if (abstractFeature instanceof GuiFeature) {
MButton button = new MButton();
button.setText("GUI");
+ button.setOnActionPerformed(new Runnable() {
+ @Override
+ public void run() {
+ Minecraft.getMinecraft().displayGuiScreen(new GuiGuiLocationConfig());
+ }
+ });
addons.add(button);
add(button);
}
diff --git a/src/main/java/kr/syeyoung/dungeonsguide/config/guiconfig/GuiGuiLocationConfig.java b/src/main/java/kr/syeyoung/dungeonsguide/config/guiconfig/GuiGuiLocationConfig.java
index 7d689cdb..75021e66 100755
--- a/src/main/java/kr/syeyoung/dungeonsguide/config/guiconfig/GuiGuiLocationConfig.java
+++ b/src/main/java/kr/syeyoung/dungeonsguide/config/guiconfig/GuiGuiLocationConfig.java
@@ -1,8 +1,11 @@
package kr.syeyoung.dungeonsguide.config.guiconfig;
+import kr.syeyoung.dungeonsguide.config.GuiConfig;
import kr.syeyoung.dungeonsguide.features.AbstractFeature;
import kr.syeyoung.dungeonsguide.features.FeatureRegistry;
+import kr.syeyoung.dungeonsguide.features.GuiFeature;
import kr.syeyoung.dungeonsguide.roomedit.MPanel;
+import kr.syeyoung.dungeonsguide.roomedit.elements.MButton;
import kr.syeyoung.dungeonsguide.roomedit.elements.MTabbedPane;
import net.minecraft.client.Minecraft;
import net.minecraft.client.gui.GuiScreen;
@@ -21,7 +24,27 @@ public class GuiGuiLocationConfig extends GuiScreen {
private MPanel mainPanel = new MPanel();
public GuiGuiLocationConfig() {
-
+ for (AbstractFeature feature : FeatureRegistry.getFeatureList()) {
+ if (feature instanceof GuiFeature) {
+ mainPanel.add(new PanelDelegate((GuiFeature) feature));
+ }
+ }
+ {
+ MButton button = new MButton() {
+ @Override
+ public void resize(int parentWidth, int parentHeight) {
+ setBounds(new Rectangle(parentWidth-100,parentHeight-30,100,30));
+ }
+ };
+ button.setText("back");
+ button.setOnActionPerformed(new Runnable() {
+ @Override
+ public void run() {
+ Minecraft.getMinecraft().displayGuiScreen(new GuiConfig());
+ }
+ });
+ mainPanel.add(button);
+ }
}
@Override
diff --git a/src/main/java/kr/syeyoung/dungeonsguide/config/guiconfig/PanelDelegate.java b/src/main/java/kr/syeyoung/dungeonsguide/config/guiconfig/PanelDelegate.java
index e91f5733..fd8b3f25 100644
--- a/src/main/java/kr/syeyoung/dungeonsguide/config/guiconfig/PanelDelegate.java
+++ b/src/main/java/kr/syeyoung/dungeonsguide/config/guiconfig/PanelDelegate.java
@@ -2,6 +2,8 @@ package kr.syeyoung.dungeonsguide.config.guiconfig;
import kr.syeyoung.dungeonsguide.features.GuiFeature;
import kr.syeyoung.dungeonsguide.roomedit.MPanel;
+import net.minecraft.client.gui.Gui;
+import org.w3c.dom.css.Rect;
import java.awt.*;
@@ -17,22 +19,95 @@ public class PanelDelegate extends MPanel {
}
@Override
- public void render(int absMousex, int absMousey, int relMousex0, int relMousey0, float partialTicks, Rectangle scissor) {
+ public void render(int absMousex, int absMousey, int relMouseX, int relMouseY, float partialTicks, Rectangle scissor) {
guiFeature.drawDemo(partialTicks);
+
+ Gui.drawRect(0,0, 3, 3, 0x55777777);
+ Gui.drawRect(0, getBounds().height - 3, 3, 3, 0x55777777);
+ Gui.drawRect(getBounds().width - 3,0, 3, 3, 0x55777777);
+ Gui.drawRect(getBounds().width - 3,getBounds().height - 3, 3, 3, 0x55777777);
+ if (lastAbsClip.contains(absMousex, absMousey)) {
+ if (relMouseX < 3 && relMouseY < 3) {
+ Gui.drawRect(0,0, 3, 3, 0x55FFFFFF);
+ } else if (relMouseX < 3 && relMouseY > getBounds().height - 3) {
+ Gui.drawRect(0, getBounds().height - 3, 3, 3, 0x55FFFFFF);
+ } else if (relMouseX > getBounds().width - 3 && relMouseY < getBounds().height - 3) {
+ Gui.drawRect(getBounds().width - 3,getBounds().height - 3, 3, 3, 0x55FFFFFF);
+ } else if (relMouseX > getBounds().width - 3 && relMouseY < 3) {
+ Gui.drawRect(getBounds().width - 3,0, 3, 3, 0x55FFFFFF);
+ } else {
+ Gui.drawRect(0,0, getBounds().width, getBounds().height, 0x55FFFFFF);
+ }
+ }
}
+ private int selectedPart = 0;
+
+ private int lastX = 0;
+ private int lastY = 0;
+
+
@Override
public void mouseClicked(int absMouseX, int absMouseY, int relMouseX, int relMouseY, int mouseButton) {
-
+ if (!lastAbsClip.contains(absMouseX, absMouseY)) return;
+ if (relMouseX < 3 && relMouseY < 3) {
+ selectedPart = 0;
+ } else if (relMouseX < 3 && relMouseY > getBounds().height - 3) {
+ selectedPart = 2;
+ } else if (relMouseX > getBounds().width - 3 && relMouseY < getBounds().height - 3) {
+ selectedPart = 3;
+ } else if (relMouseX > getBounds().width - 3 && relMouseY < 3) {
+ selectedPart = 1;
+ } else {
+ selectedPart = -1;
+ }
+ lastX = absMouseX;
+ lastY = absMouseY;
}
@Override
public void mouseReleased(int absMouseX, int absMouseY, int relMouseX, int relMouseY, int state) {
-
+ selectedPart = 0;
}
@Override
public void mouseClickMove(int absMouseX, int absMouseY, int relMouseX, int relMouseY, int clickedMouseButton, long timeSinceLastClick) {
+ int dx = absMouseX - lastX;
+ int dy = absMouseY - lastY;
+ if (selectedPart > 0) {
+ boolean revChangeX = (selectedPart & 0x1) == 0;
+ boolean revChangeY = (selectedPart & 0x2) == 0;
+ Rectangle rectangle = guiFeature.getFeatureRect().getBounds();
+ int prevWidth = rectangle.width;
+ int prevHeight= rectangle.height;
+
+ rectangle.width = prevWidth + dx;
+ rectangle.height = prevHeight + dy;
+
+ if (guiFeature.isKeepRatio()) {
+ double ratio = guiFeature.getDefaultRatio();
+ int width1 = rectangle.width;
+ int height1 = (int) (width1 / ratio);
+
+ int width2 = (int) (rectangle.height * ratio);
+ int height2 = rectangle.height;
+
+ if (width1 * height1 < width2 * height2) {
+ rectangle.width = width1;
+ rectangle.height = height1;
+ } else {
+ rectangle.width = width2;
+ rectangle.height= height2;
+ }
+ }
+ if (revChangeX) rectangle.x -= (rectangle.width - prevWidth);
+ if (revChangeY) rectangle.y -= (rectangle.height - prevHeight);
+ guiFeature.setFeatureRect(rectangle);
+ } else if (selectedPart == -1){
+ Rectangle rectangle = guiFeature.getFeatureRect().getBounds();
+ rectangle.translate(dx, dy);
+ guiFeature.setFeatureRect(rectangle);
+ }
}
}