From cc37505fe018eacbfa34b080a9ae94afa3b0aadf Mon Sep 17 00:00:00 2001 From: DarkGuardsman Date: Thu, 24 Oct 2013 18:27:01 -0400 Subject: [PATCH] Worked on rendering arrows in the GUI --- resources/assets/al/textures/gui/PROCESS.png | Bin 1368 -> 1756 bytes .../dark/api/al/coding/ILogicTask.java | 8 +- src/minecraft/dark/api/al/coding/ITask.java | 4 +- .../assembly/client/gui/GuiEncoderCoder.java | 2 +- .../dark/assembly/client/gui/GuiTaskList.java | 183 +++++++++++++++--- .../common/armbot/command/TaskEnd.java | 18 ++ .../common/armbot/command/TaskGOTO.java | 34 ++++ .../common/armbot/command/TaskIF.java | 37 ++++ .../common/armbot/command/TaskStart.java | 22 +++ 9 files changed, 282 insertions(+), 26 deletions(-) create mode 100644 src/minecraft/dark/assembly/common/armbot/command/TaskEnd.java create mode 100644 src/minecraft/dark/assembly/common/armbot/command/TaskStart.java diff --git a/resources/assets/al/textures/gui/PROCESS.png b/resources/assets/al/textures/gui/PROCESS.png index 1db3b767cd87f3fbc78bb5582de645c3e450f4c3..06afe5f21ea01418b31c1076697b73c3de27458b 100644 GIT binary patch literal 1756 zcmcJQi&GO<6vodkAz2>LM1n*fLP2Ek0r&>3Bv3FW4iFKwD$t15BF;#7jffByDhdN) zwW$wCO&p2f7?s*usYr?90E!|S1*Ic|hDWJLfT4tuKzeuj2iQ8(+1WXFzTfUS_ulX9 z-6Cv#;|Ar3=J_L=qSXdR_#N9p0G&}1{Ug4)m46r6dUQr9cciw9#A*- z-Qrm;NMxi7Bf=SPY`L7p^A`o#EJQEv7lwtzWOlxL6Oq~};vRc8%=ztkNsi6C;`4Lc z4^_xD#cp2Xx@$(o?nQkIzA;_A$L*6x3!TKGhl1%HK?5<5ybrFD@+%23ZiXUC9vBK3eMT7^0H2LEMe`K^6a8|b2lLVT3J(BPJPqL-L zc!aGNuQA+cnwD9nOr}$YK#b;W8Cw8&b*OJ&n_a=sZZ6%jf=wo}GlP};x%8%7n#WFB zi91F(V+H}_Z_rM%NfkRlM)OGgfLysPNFC$1y#FOnP&+W2HIEkwAyIf^)VqVeYX6h6 zxQ?yUhM#WC$aa<7mfsu{Y9~{0B5TgS$^6eee#tK{*VhrfiY?uy#*+|sf-mx2KY#Wb z`UM{S|qjtqSvf-zju3qkQ_Xr-Vv7Dz!Ky6PB$3Km&LRgplFYdxXG zu&ToduA{385FBEWXBv5fQ}Hyt)$MIf%4m^kYC8FD>>=2ufSqoX(Hes9>wPG$W1N@3 zrJELLa+s=@#HY%qEA792i{JOb5|`nPvt8&aHNoYfbaOo==IT9=R7#FEpjs4U&{dZa zL=$mFP?`X(CFJO5XqH|GI$G*ZW=cvl3KvOqgN$}$i z9@tPn5uKpxVBu9}T6MO(d+dE)i;+d(F&y%eKesdEdqQh7qgX#PnEt~=hPC7pC=Oqd zvPlOkY5!z6MB4M2$f_#+D&V80NfliwGguVK%zOvbMEn})9hwJ6gRw%OF}35rR}lO* z2a?d1Vu632?l%5$$M1yUTsY(_Aq;4GJ2uI*669WlhaNlTgZ63U#^}@Tn@jNO z-H_V4-?d5SIZ`f|QU7WThhS;>iQKHcPvSbbugYscq zM~-=!-r_tx^fq@qpvzQuWKKIxB_Hdf1-R_HFun8jBATwll0Kf+5Kz%%=;=DTDhfNp z{=BSlEzePNt8e5hC)bRq`<<}FYvhex-mcP)$)0RWZ9wzb*1yVvmnPckhLReFLtZV1 z7UBh$9DIOh_xJ6}JK%nHw4oF`cT#itHsQi^<&b66u7^TWA#$w<3tWL*n|fp{d0Uvw z_Ve0f77HOhTym9lcWoT%fVrg6vwD@`xG3H#FiU|tLkaypdDr3@BVDq@B~V|ay*e<_ z(w%H>ON5`ZBD9kipMfT4t^SmI>#f%rn8-J|ZgcZwPbik@Lv@F}Hkqp417;5D4!|-U zQFz~5$2gxhF;B)q&S@(@;)AD-iH|ubK5)EzIOU50-YkyhjCZ^KOY|QCVR&TN^-xLv E-*X3tK>z>% literal 1368 zcmeAS@N?(olHy`uVBq!ia0y~yU<5K5893O0R7}x|G!U;i$lZxy-8q?;Kn_c~qpu?a z!^VE@KZ&eBK4*bPWHAE+-w_aIoT|+y4HRTc@^*J&_z!{$_AZ|c6k#v%^mS#w%O%Kf zs9|w6wH|2D2~QWtkczmscYXaHdoj2Le)@K_r}pBTZb|OPiBjGiABClo!hgUbaI*j2M@*RHCXUB2%>7Vge}Tw;~`tENEnJYz*g#gE?^LD#QepUqn&`Tx`BTc0c+ z2K}qv`JCtV5AoA~KS`viF{D@7{+r5SV9jW8xcYH?CxfwYgMN(}NJyLU#}P}gkWd4E zP5K{g!2~m=4}JBL|GijdbTaJuIQipxmxf4=1KRryLF$g!Tj$3cT$IaVa7{nF>6-hd(F?0tiCH(18 z5^Xqo52(g%68C|m^&ArRi#^#AHkPvV%oj{$-f%+;XwHgh+vmzY+WtxX@vbM*9X<0W zF7;c}i=ga}l2UG7`aZ1>47HBZ9 zlVW_Ft_BKkpd*Z>8GjroR|cx_V6ZF90~!;_c|d$$7f{9+7;)}E$E2wPqf(mj@pBHA z2h!Joj&fIIxWA?6-}(9W$IdHqFtl(|56zvI*S_P}RPWM*-{;P2OSTkvs!Bb>sp!s8 iqXsSnQetEO^1twza$#!urq{q?j=|H_&t;ucLK6T^X|iSj diff --git a/src/minecraft/dark/api/al/coding/ILogicTask.java b/src/minecraft/dark/api/al/coding/ILogicTask.java index 05e4207a1..8e6f7da6b 100644 --- a/src/minecraft/dark/api/al/coding/ILogicTask.java +++ b/src/minecraft/dark/api/al/coding/ILogicTask.java @@ -1,10 +1,14 @@ package dark.api.al.coding; +import java.util.List; + +import universalelectricity.core.vector.Vector2; + /** Task in which it doesn't go right to the next task in the row. In this case the task will store * the entry point, and exit points. As well handle anything in between. Examples are IF statements * and loops. Do your logic in the refresh method as it should be called each time a new task is * selected. - * + * * @author DarkGuardsman */ public interface ILogicTask extends ITask { @@ -13,6 +17,8 @@ public interface ILogicTask extends ITask * back to this task. */ public ITask getExitPoint(); + public List getExits(); + /** Mainly used by the encoder to understand the limit on connections */ public int getMaxExitPoints(); diff --git a/src/minecraft/dark/api/al/coding/ITask.java b/src/minecraft/dark/api/al/coding/ITask.java index e612ec6ab..f8d5f763e 100644 --- a/src/minecraft/dark/api/al/coding/ITask.java +++ b/src/minecraft/dark/api/al/coding/ITask.java @@ -74,7 +74,9 @@ public interface ITask extends Cloneable DATA("Data"), DEFINEDPROCESS("Defined Process"), PROCESS("Process"), - DECISION("Decision"); + DECISION("Decision"), + START("Start"), + END("End"); public String name; private TaskType(String name) diff --git a/src/minecraft/dark/assembly/client/gui/GuiEncoderCoder.java b/src/minecraft/dark/assembly/client/gui/GuiEncoderCoder.java index 8cc2b4238..c8d4929e8 100644 --- a/src/minecraft/dark/assembly/client/gui/GuiEncoderCoder.java +++ b/src/minecraft/dark/assembly/client/gui/GuiEncoderCoder.java @@ -34,7 +34,7 @@ public class GuiEncoderCoder extends GuiEncoderBase int containerWidth = (this.width - this.xSize) / 2; int containerHeight = (this.height - this.ySize) / 2; this.drawTexturedModalRect(containerWidth, containerHeight, 0, 0, this.xSize, this.ySize); - taskListGui.drawConsole(this.mc, (this.width - this.xSize) / 2 + 20, (this.height - this.ySize) / 2 + 40); + taskListGui.drawConsole(this.mc, (this.width - this.xSize) / 2 + 15, (this.height - this.ySize) / 2 + 20); } } diff --git a/src/minecraft/dark/assembly/client/gui/GuiTaskList.java b/src/minecraft/dark/assembly/client/gui/GuiTaskList.java index 633e52e4b..e5b21ccc4 100644 --- a/src/minecraft/dark/assembly/client/gui/GuiTaskList.java +++ b/src/minecraft/dark/assembly/client/gui/GuiTaskList.java @@ -1,22 +1,27 @@ package dark.assembly.client.gui; +import java.awt.Color; + import net.minecraft.client.Minecraft; -import net.minecraft.client.gui.FontRenderer; import net.minecraft.client.gui.Gui; import net.minecraft.client.gui.ScaledResolution; import net.minecraft.util.ResourceLocation; import org.lwjgl.opengl.GL11; -import cpw.mods.fml.client.FMLClientHandler; - import universalelectricity.core.vector.Vector2; +import cpw.mods.fml.client.FMLClientHandler; +import dark.api.al.coding.ILogicTask; import dark.api.al.coding.IProgram; import dark.api.al.coding.IRedirectTask; import dark.api.al.coding.ITask; import dark.assembly.common.AssemblyLine; import dark.assembly.common.armbot.Program; +import dark.assembly.common.armbot.command.TaskEnd; +import dark.assembly.common.armbot.command.TaskGOTO; import dark.assembly.common.armbot.command.TaskGive; +import dark.assembly.common.armbot.command.TaskIF; +import dark.assembly.common.armbot.command.TaskStart; import dark.core.interfaces.IScroll; /** Not a gui itself but a component used to display task as a box inside of a gui @@ -27,6 +32,12 @@ public class GuiTaskList extends Gui implements IScroll protected IProgram program; protected int scroll = 0; + private final int desiredH = 240; + private final int desiredW = 427; + private final float scale = 0.52f; + + private int color = 14737632; + /** The string displayed on this control. */ public String displayString; @@ -36,7 +47,7 @@ public class GuiTaskList extends Gui implements IScroll { program = new Program(); program.setTaskAt(new Vector2(0, 0), new TaskGive()); - program.setTaskAt(new Vector2(0, 1), new TaskGive()); + program.setTaskAt(new Vector2(0, 1), new TaskIF(new Vector2(0, 2), new Vector2(1, 1))); program.setTaskAt(new Vector2(0, 2), new TaskGive()); program.setTaskAt(new Vector2(0, 3), new TaskGive()); program.setTaskAt(new Vector2(0, 4), new TaskGive()); @@ -45,6 +56,25 @@ public class GuiTaskList extends Gui implements IScroll program.setTaskAt(new Vector2(0, 7), new TaskGive()); program.setTaskAt(new Vector2(0, 8), new TaskGive()); program.setTaskAt(new Vector2(0, 9), new TaskGive()); + + program.setTaskAt(new Vector2(1, 1), new TaskGive()); + program.setTaskAt(new Vector2(1, 2), new TaskIF(new Vector2(1, 3), new Vector2(2, 2))); + program.setTaskAt(new Vector2(1, 3), new TaskGive()); + program.setTaskAt(new Vector2(1, 4), new TaskGive()); + program.setTaskAt(new Vector2(1, 5), new TaskGive()); + TaskGOTO ifEixt = new TaskGOTO(); + ifEixt.setExitPoint(0, new Vector2(0, 6)); + program.setTaskAt(new Vector2(1, 6), ifEixt); + + program.setTaskAt(new Vector2(2, 2), new TaskGive()); + program.setTaskAt(new Vector2(2, 3), new TaskGive()); + program.setTaskAt(new Vector2(2, 4), new TaskGive()); + program.setTaskAt(new Vector2(2, 5), new TaskGive()); + program.setTaskAt(new Vector2(2, 6), new TaskGive()); + program.setTaskAt(new Vector2(2, 7), new TaskGive()); + TaskGOTO ifEixt2 = new TaskGOTO(); + ifEixt2.setExitPoint(0, new Vector2(1, 8)); + program.setTaskAt(new Vector2(2, 8), ifEixt2); program.init(null); } @@ -74,37 +104,39 @@ public class GuiTaskList extends Gui implements IScroll public void drawConsole(Minecraft minecraft, int x, int y) { - int spacingY = 25; - int spacingX = 25; - int color = 14737632; - GL11.glPushMatrix(); //With everything scaled the gui will not align like a normal one so use a scaled distance from the main GUI - float scale = 0.52f; ScaledResolution scaledresolution = new ScaledResolution(minecraft.gameSettings, minecraft.displayWidth, minecraft.displayHeight); int scaleH = scaledresolution.getScaledHeight(); int scaleW = scaledresolution.getScaledWidth(); - this.drawCenteredString(minecraft.fontRenderer, "Scale - " + scaleW + "x " + scaleH + "y", 100, 100, color); - int desiredH = 240; - int desiredW = 427; + //this.drawCenteredString(minecraft.fontRenderer, "Scale - " + scaleW + "x " + scaleH + "y", 100, 100, color); + float sh = (scaleH / desiredH) / scale; float sW = (scaleW / desiredW) / scale; - spacingY = (int) (spacingY * sh); - spacingX = (int) (spacingX * sW); + int spacingY = (int) (40 * sh); + int spacingX = (int) (40 * sW); + //Start drawing after everying is scaled down GL11.glScalef(scale, scale, scale); - //TODO add zooming which will involve storing scales with distance translations factors + //Draw lines between tasks + color = Color.BLUE.getRGB(); for (int j = 0; j < 3; j++) { - for (int i = 0; i < 6; i++) + for (int i = 0; i < 4; i++) { - int currentLine = i + this.scroll; - - if (currentLine <= this.program.getSize().intY() && currentLine >= 0) + int currentLine = i + this.scroll - 1; + if (currentLine <= this.program.getSize().intY() + 1 && currentLine >= -1) { ITask task = this.program.getTaskAt(new Vector2(j, currentLine)); - + if (currentLine == -1 && j == 0) + { + task = new TaskStart(); + } + if (currentLine == this.program.getSize().intY() + 1 && j == 0) + { + task = new TaskEnd(); + } if (task != null) { if (task instanceof IRedirectTask && !((IRedirectTask) task).render()) @@ -130,13 +162,118 @@ public class GuiTaskList extends Gui implements IScroll case DECISION: xx = 50; yy = 50; - uu = 50; - vv = 0; + uu = 0; + vv = 78; + break; + case START: + case END: + xx = 39; + yy = 28; + uu = 0; + vv = 128; + break; + } + Vector2 center = new Vector2(((x + 35) - xx) * sW + (spacingX / 2), (y + 25 - (yy / 2)) * sh + (spacingY * i)); + if (task instanceof ILogicTask) + { + for (Vector2 vec : ((ILogicTask) task).getExits()) + { + //Task must be close so not to waste a shit ton of line rendering, as well it needs to stay on screen, and only be one column over + if (vec.distanceTo(task.getPosition()) < 5) + { + if (vec.x >= task.getPosition().x) + { + this.drawHorizontalLine(center.intX(), center.intY(), center.intX() + (spacingX / 2), color); + if (vec.y >= task.getPosition().y) + { + this.drawVerticalLine(center.intX() + (spacingX / 2), center.intY(), center.intY() + (spacingY * (vec.intY() - task.getPosition().intY())), color); + } + else if (vec.y < task.getPosition().y) + { + this.drawVerticalLine(center.intX() + (spacingX / 2), center.intY(), center.intY() - (spacingY * (task.getPosition().intY() - vec.intY())), color); + } + } + else if (vec.x < task.getPosition().x) + { + this.drawHorizontalLine(center.intX(), center.intY(), center.intX() - (spacingX / 2), color); + if (vec.y >= task.getPosition().y) + { + this.drawVerticalLine(center.intX() - (spacingX / 2), center.intY(), center.intY() + (spacingY * (vec.intY() - task.getPosition().intY())), color); + } + else if (vec.y < task.getPosition().y) + { + this.drawVerticalLine(center.intX() - (spacingX / 2), center.intY(), center.intY() - (spacingY * (task.getPosition().intY() - vec.intY())), color); + } + } + } + } + } + else + { + this.drawVerticalLine(center.intX(), center.intY(), center.intY() + spacingY, color); + } + } + } + } + + } + //Draw icons for task + color = 14737632; + for (int j = 0; j < 3; j++) + { + for (int i = 0; i < 4; i++) + { + int currentLine = i + this.scroll - 1; + if (currentLine <= this.program.getSize().intY() + 1 && currentLine >= -1) + { + ITask task = this.program.getTaskAt(new Vector2(j, currentLine)); + if (currentLine == -1 && j == 0) + { + task = new TaskStart(); + } + if (currentLine == this.program.getSize().intY() + 1 && j == 0) + { + task = new TaskEnd(); + } + if (task != null) + { + if (task instanceof IRedirectTask && !((IRedirectTask) task).render()) + { + continue; + } + int xx = 50; + int yy = 39; + int uu = 0; + int vv = 0; + switch (task.getType()) + { + case DATA: + break; + case PROCESS: + break; + case DEFINEDPROCESS: + xx = 50; + yy = 39; + uu = 0; + vv = 39; + break; + case DECISION: + xx = 50; + yy = 50; + uu = 0; + vv = 78; + break; + case START: + case END: + xx = 39; + yy = 28; + uu = 0; + vv = 128; break; } FMLClientHandler.instance().getClient().renderEngine.bindTexture(this.TEXTURE_PROCESS); GL11.glColor4f(1.0F, 1.0F, 1.0F, 1.0F); - Vector2 center = new Vector2(x * sW + (spacingX * j), y * sh + (spacingY * i)); + Vector2 center = new Vector2((x + 35 - (xx / 2)) * sW + (spacingX * j), (y + 25 - (yy / 2)) * sh + (spacingY * i)); this.drawTexturedModalRect(center.intX(), center.intY(), uu, vv, xx, yy); this.drawCenteredString(minecraft.fontRenderer, task.getMethodName(), center.intX() + (xx / 2), center.intY() + ((yy - 8) / 2), color); } diff --git a/src/minecraft/dark/assembly/common/armbot/command/TaskEnd.java b/src/minecraft/dark/assembly/common/armbot/command/TaskEnd.java new file mode 100644 index 000000000..704f3df33 --- /dev/null +++ b/src/minecraft/dark/assembly/common/armbot/command/TaskEnd.java @@ -0,0 +1,18 @@ +package dark.assembly.common.armbot.command; + +import dark.assembly.common.armbot.TaskBase; + +/** @author DarkGuardsman */ +public class TaskEnd extends TaskBase +{ + public TaskEnd() + { + super("end", TaskType.END); + } + + @Override + public TaskBase clone() + { + return new TaskEnd(); + } +} diff --git a/src/minecraft/dark/assembly/common/armbot/command/TaskGOTO.java b/src/minecraft/dark/assembly/common/armbot/command/TaskGOTO.java index 621520649..7d2d68bd4 100644 --- a/src/minecraft/dark/assembly/common/armbot/command/TaskGOTO.java +++ b/src/minecraft/dark/assembly/common/armbot/command/TaskGOTO.java @@ -1,5 +1,8 @@ package dark.assembly.common.armbot.command; +import java.util.ArrayList; +import java.util.List; + import net.minecraft.nbt.NBTTagCompound; import universalelectricity.core.vector.Vector2; import dark.api.al.coding.IRedirectTask; @@ -12,6 +15,7 @@ public class TaskGOTO extends TaskBase implements IRedirectTask protected ITask task; protected Vector2 taskPos; protected boolean render = true; + protected List exits = new ArrayList(); public TaskGOTO() { @@ -30,6 +34,21 @@ public class TaskGOTO extends TaskBase implements IRedirectTask return task; } + @Override + public void refresh() + { + super.refresh(); + if(task == null && taskPos != null) + { + this.task = this.program.getTaskAt(taskPos); + } + this.exits.clear(); + if (this.task != null) + { + this.exits.add(this.task.getPosition()); + } + } + @Override public void setExitPoint(int i, ITask task) { @@ -39,6 +58,14 @@ public class TaskGOTO extends TaskBase implements IRedirectTask } } + public void setExitPoint(int i, Vector2 vector2) + { + if (i == 0) + { + this.taskPos = vector2; + } + } + @Override public int getMaxExitPoints() { @@ -77,4 +104,11 @@ public class TaskGOTO extends TaskBase implements IRedirectTask return new TaskGOTO(); } + @Override + public List getExits() + { + // TODO Auto-generated method stub + return exits; + } + } diff --git a/src/minecraft/dark/assembly/common/armbot/command/TaskIF.java b/src/minecraft/dark/assembly/common/armbot/command/TaskIF.java index fa20676a8..f90a6aa24 100644 --- a/src/minecraft/dark/assembly/common/armbot/command/TaskIF.java +++ b/src/minecraft/dark/assembly/common/armbot/command/TaskIF.java @@ -1,5 +1,8 @@ package dark.assembly.common.armbot.command; +import java.util.ArrayList; +import java.util.List; + import net.minecraft.nbt.NBTTagCompound; import universalelectricity.core.vector.Vector2; import dark.api.al.coding.IProgrammableMachine; @@ -12,6 +15,8 @@ public class TaskIF extends TaskBaseLogic { protected ITask exitTruePoint = null; protected ITask exitFalsePoint = null; + protected List exits = new ArrayList(); + protected Vector2 exitA, exitB; protected boolean isTrue = false; public TaskIF() @@ -29,6 +34,14 @@ public class TaskIF extends TaskBaseLogic } + public TaskIF(Vector2 exitA, Vector2 exitB) + { + this(); + this.exitA = exitA; + this.exitB = exitB; + + } + @Override public void refresh() { @@ -37,6 +50,24 @@ public class TaskIF extends TaskBaseLogic { this.isTrue = this.getArg("check").equals(this.getArg("compare")); } + if (exitTruePoint == null && exitA != null) + { + exitTruePoint = this.program.getTaskAt(exitA); + } + if (exitFalsePoint == null && exitB != null) + { + exitFalsePoint = this.program.getTaskAt(exitB); + } + + this.exits.clear(); + if (this.exitFalsePoint != null) + { + this.exits.add(this.exitFalsePoint.getPosition()); + } + if (this.exitTruePoint != null) + { + this.exits.add(this.exitTruePoint.getPosition()); + } } @Override @@ -106,4 +137,10 @@ public class TaskIF extends TaskBaseLogic return true; } + @Override + public List getExits() + { + return this.exits; + } + } diff --git a/src/minecraft/dark/assembly/common/armbot/command/TaskStart.java b/src/minecraft/dark/assembly/common/armbot/command/TaskStart.java new file mode 100644 index 000000000..5435f95a2 --- /dev/null +++ b/src/minecraft/dark/assembly/common/armbot/command/TaskStart.java @@ -0,0 +1,22 @@ +package dark.assembly.common.armbot.command; + +import dark.assembly.common.armbot.TaskBase; + +/** Fake task as the player can not create, edit, or do anything with this task. Its only used to + * allow the gui to render the task as an actual task instance + * + * @author DarkGaurdsman */ +public class TaskStart extends TaskBase +{ + public TaskStart() + { + super("Start", TaskType.START); + } + + @Override + public TaskBase clone() + { + return new TaskStart(); + } + +}