aboutsummaryrefslogtreecommitdiff
path: root/src/main/java/kr/syeyoung/dungeonsguide/roomedit/valueedit/ValueEditOffsetPoint.java
diff options
context:
space:
mode:
Diffstat (limited to 'src/main/java/kr/syeyoung/dungeonsguide/roomedit/valueedit/ValueEditOffsetPoint.java')
-rw-r--r--src/main/java/kr/syeyoung/dungeonsguide/roomedit/valueedit/ValueEditOffsetPoint.java130
1 files changed, 130 insertions, 0 deletions
diff --git a/src/main/java/kr/syeyoung/dungeonsguide/roomedit/valueedit/ValueEditOffsetPoint.java b/src/main/java/kr/syeyoung/dungeonsguide/roomedit/valueedit/ValueEditOffsetPoint.java
new file mode 100644
index 00000000..c91e0bea
--- /dev/null
+++ b/src/main/java/kr/syeyoung/dungeonsguide/roomedit/valueedit/ValueEditOffsetPoint.java
@@ -0,0 +1,130 @@
+package kr.syeyoung.dungeonsguide.roomedit.valueedit;
+
+import kr.syeyoung.dungeonsguide.dungeon.data.OffsetPoint;
+import kr.syeyoung.dungeonsguide.roomedit.EditingContext;
+import kr.syeyoung.dungeonsguide.roomedit.MPanel;
+import kr.syeyoung.dungeonsguide.roomedit.Parameter;
+import kr.syeyoung.dungeonsguide.roomedit.elements.*;
+import kr.syeyoung.dungeonsguide.utils.RenderUtils;
+import net.minecraft.block.Block;
+import net.minecraft.client.Minecraft;
+import scala.actors.threadpool.Arrays;
+
+import java.awt.*;
+
+public class ValueEditOffsetPoint extends MPanel implements ValueEdit<String> {
+ private Parameter parameter;
+
+
+ public ValueEditOffsetPoint(final Parameter parameter2) {
+ this.parameter = parameter2;
+ {
+ MLabel label = new MLabel() {
+ @Override
+ public String getText() {
+ return parameter.getPreviousData().toString();
+ }
+ };
+ MLabelAndElement mLabelAndElement = new MLabelAndElement("Prev",label);
+ mLabelAndElement.setBounds(new Rectangle(0,0,bounds.width,20));
+ add(mLabelAndElement);
+ }
+ OffsetPoint newData = (OffsetPoint) parameter.getNewData();
+ {
+ final MIntegerSelectionButton textField = new MIntegerSelectionButton(newData.getX());
+ textField.setOnUpdate(new Runnable() {
+ @Override
+ public void run() {
+ ((OffsetPoint) parameter.getNewData()).setX(textField.getData());
+ }
+ });
+ MLabelAndElement mLabelAndElement = new MLabelAndElement("x",textField);
+ mLabelAndElement.setBounds(new Rectangle(0,20,bounds.width,20));
+ add(mLabelAndElement);
+ }
+ {
+ final MIntegerSelectionButton textField = new MIntegerSelectionButton(newData.getY());
+ textField.setOnUpdate(new Runnable() {
+ @Override
+ public void run() {
+ ((OffsetPoint) parameter.getNewData()).setY(textField.getData());
+ }
+ });
+ MLabelAndElement mLabelAndElement = new MLabelAndElement("y",textField);
+ mLabelAndElement.setBounds(new Rectangle(0,40,bounds.width,20));
+ add(mLabelAndElement);
+ }
+ {
+ final MIntegerSelectionButton textField = new MIntegerSelectionButton(newData.getZ());
+ textField.setOnUpdate(new Runnable() {
+ @Override
+ public void run() {
+ ((OffsetPoint) parameter.getNewData()).setX(textField.getData());
+ }
+ });
+ MLabelAndElement mLabelAndElement = new MLabelAndElement("z",textField);
+ mLabelAndElement.setBounds(new Rectangle(0,60,bounds.width,20));
+ add(mLabelAndElement);
+ }
+ {
+ final MLabel setToHEre = new MLabel() {
+ @Override
+ public String getText() {
+ OffsetPoint offsetPoint = (OffsetPoint) parameter.getNewData();
+ return Block.getIdFromBlock(offsetPoint.getBlock(EditingContext.getEditingContext().getRoom())) +
+ ":" + offsetPoint.getData(EditingContext.getEditingContext().getRoom());
+ }
+ };
+ MLabelAndElement mLabelAndElement = new MLabelAndElement("newPt",setToHEre);
+ mLabelAndElement.setBounds(new Rectangle(0,80,bounds.width,20));
+ add(mLabelAndElement);
+ }
+ }
+
+ @Override
+ public void render(int absMousex, int absMousey, int relMousex0, int relMousey0, float partialTicks, Rectangle scissor) {
+ RenderUtils.highlightBlock2(((OffsetPoint)parameter.getPreviousData()).getBlockPos(EditingContext.getEditingContext().getRoom()), new Color(255,0,0,150), partialTicks);
+ RenderUtils.highlightBlock2(((OffsetPoint)parameter.getNewData()).getBlockPos(EditingContext.getEditingContext().getRoom()), new Color(0,255,0,150), partialTicks);
+ }
+
+ @Override
+ public void onBoundsUpdate() {
+ for (MPanel panel :getChildComponents()){
+ panel.setSize(new Dimension(bounds.width, 20));
+ }
+ }
+
+ @Override
+ public void setParameter(Parameter parameter) {
+ this.parameter = parameter;
+ }
+
+ @Override
+ public void resize(int parentWidth, int parentHeight) {
+ this.setBounds(new Rectangle(0,0,parentWidth, parentHeight));
+ }
+
+ public static class Generator implements ValueEditCreator<ValueEditOffsetPoint> {
+
+ @Override
+ public ValueEditOffsetPoint createValueEdit(Parameter parameter) {
+ return new ValueEditOffsetPoint(parameter);
+ }
+
+ @Override
+ public Object createDefaultValue(Parameter parameter) {
+ return new OffsetPoint(EditingContext.getEditingContext().getRoom(), Minecraft.getMinecraft().thePlayer.getPosition());
+ }
+
+ @Override
+ public Object cloneObj(Object object) {
+ try {
+ return ((OffsetPoint)object).clone();
+ } catch (CloneNotSupportedException e) {
+ e.printStackTrace();
+ }
+ assert false;
+ return null;
+ }
+ }
+}