diff --git a/base64/delete.png.64 b/base64/delete.png.64
new file mode 100644
index 0000000..58e3684
--- /dev/null
+++ b/base64/delete.png.64
@@ -0,0 +1 @@
+iVBORw0KGgoAAAANSUhEUgAAABUAAAAgCAYAAAD9oDOIAAAACXBIWXMAAADGAAAAxgGwdJvFAAAAGXRFWHRTb2Z0d2FyZQB3d3cuaW5rc2NhcGUub3Jnm+48GgAAA0BJREFUSIntlV9oW1Ucxz/n3DviTYO9NrFlTToQ2j5YyqIIa1YK4theSsEw5gJ9EP9QweoQFCllreCGdb5UfEspWEFwIAPtQx+a0ILifKjo8uBmpY6aVEi70lwTcps/N/f4sC5aUBJkj/2+HDi/3/nw/Z0fv3MEgILLwBWrre2VL65e/U7TtLvA++VyeebNS5ds4HugDQgLKNBA+sH6ITDiKxQ+8dn2I7bPlxVCBD0ezxPAL8DTwLPNAAEkgAAHeFGAd+D6dU0IEdzc3MSfyVx0pZz+9fTpn+fi8aFmgAB6PB4/AbwcV+qlcCIhTt24wWe2zcfr69z1+9kLBsU3o6P9SqnfmoVKKeXjwHuFQuHElWKRtWPHGL99m49qNR67d49Pz5zB1XWUUs/Nzc29oJQSDaGapqWVUramaSRWVhitVmkF3gAmlOLdhQWWlpaQUj6qlLoohFANodVq9XMhhLelpYWBgQEcoHYQNAHDMIhEIriumwdea6Z83XGcVzVN+1oI8VRnRwcfABngW2ASKEYimKaJlPKHsbGx3Wagcnx8PGPb9iCgnl9f5xTwumHwthD8DryTSkGpRK1We7KZ+wSoJ305OVmLXrsmfzp7lh+jUSzLorK8zOWVFW6dO8fa+fNF4A+lVEkI4bquW5FS2kAe+FMptV8vH0CBJ7ewgHX8OLdGRgBobW2FCxe4U61ycnmZdH9/S7anpxdAKYUQAqX+7pnrukgpFSDEAXTWlfKtryYmyAaDpNNpVldXsSyLno4O4jdvUq7VOAkUhcAwDHRdx+/3EwgECAaDDA0N4fP5Dpcfj8czQAggm82SzWbZ3d0ln8+zv7+P4ziUy+U60DAMTNMkEAgQCoUwTfOB2/rsA2xvbW2FUqkUfX199Pb2Eg6HGzbFcRw2NjZIJBJ0dnYyODh4f/YfqFwus7i4SDKZxOv1AjA7O8v09DTJZBKAvb09pqammJmZud8UXWd+fp5kMkmpVAI4DP035XI5tre3yeVydWc7OztYlvWfZxpC/4+OoEfQI+gR9KHpn480gUCAWCxGe3t7fW94eBjbtunq6gLA5/MRi8XweDz1nGg0SqVSobu7Gzj8nawBzzwMp38BxWJHOyltKE0AAAAASUVORK5CYII=
\ No newline at end of file
diff --git a/base64/pause.png.64 b/base64/pause.png.64
new file mode 100644
index 0000000..4b516c6
--- /dev/null
+++ b/base64/pause.png.64
@@ -0,0 +1 @@
+iVBORw0KGgoAAAANSUhEUgAAABIAAAAbCAYAAABxwd+fAAAACXBIWXMAAADGAAAAxgGwdJvFAAAAGXRFWHRTb2Z0d2FyZQB3d3cuaW5rc2NhcGUub3Jnm+48GgAAALxJREFUOI3t1TGKwzAQQNE/JoXQGQTGpbFP5HJhXfsoKo0XUupCSWpj0BmMKk8KJ2QXglnYcvXLQfNQNzKO40VEWl5tIvLZ9/2ZN03T9KGqX0DxnKnq9SQi7bquLMuCMYaqqgqgeYc8aoBinmdSSpRlibW2LQBijHjvCSEc7P8shID3nhgjfP/eX8tQhjKUoQz9Q+gE4JxjGAaMMb9e7LqOlBLOuR1S1au1tq3r+vlmA24Hxg3YHocU2C/tHUseO6D31KjVAAAAAElFTkSuQmCC
\ No newline at end of file
diff --git a/base64/play.png.64 b/base64/play.png.64
new file mode 100644
index 0000000..5adac51
--- /dev/null
+++ b/base64/play.png.64
@@ -0,0 +1 @@
+iVBORw0KGgoAAAANSUhEUgAAABkAAAAgCAYAAADnnNMGAAAACXBIWXMAAACbAAAAmwEPcaP1AAAAGXRFWHRTb2Z0d2FyZQB3d3cuaW5rc2NhcGUub3Jnm+48GgAAAj9JREFUSIm11rtrFVkcB/DPmdwbbx7GRK+IQbbQVQwIK0RIYSciguBa6RaKCxa+UCu1EDvZXaxstBAr8Q/QwifIrgirLrusq2ChyD6qKCJ41U2MuXMsJiM+gibm5FtNcc7vM2f48ZsDD3ASVdOYiCi4jgXTh8yrRi2hKXiKddODrOyMdtSj2ZUmchxDLRWQvX2aV2V7PbO8PWCf4HcsS4tAa+DbWWzsYUbWJ/gDBz9aNyWkTF+NnfXMV61V/IQr6E2LQFcLW+cEa7vIrBLcxfq0CAQMdLCtHvRUunEWx9GWDinTWy0+30BHwC7BbfSnRaASWNvFph5q2deCmziElnRImaU1ds/NLKlVcERwA4vTItCR8V0PG7qphH7BHexLi5T5po1dczMLWlsVU+IS5qdFoLuF7+dkVs8ks2bsVO+1+tSRssrKzrLVZ+McTqMzHVKmt8qOemZFO2wR/IWBtAhUA+tm0d9OtBAXKsmRR6+52Ij+HQmCh6Ld6ZDhnF9e8NvLiGEcFf2IV1NHIu4McbmRG8oDzuAABsslU0P+GeHis9zj0Wxsnu3Brx8u+zKk0eTq8+IEwRMcFp1S/Lo/yuSQ0citl1x7kRuNOU6IDqPxqW0TR+4Pc6GRe9bM8DP24t5Etn4eGRxryf9GguBvxSA8P+GX+yQylHNt/JacDDA+kuPP/7n6vGkozxQtuR+PJlt8fGT8lrzxpcXfTbSsLeqrFXfizCA2K64RyVJeuEfwg7HxnDbBA8VVZ1H64kXeAM9RoeriawdYAAAAAElFTkSuQmCC
\ No newline at end of file
diff --git a/base64/reset.png.64 b/base64/reset.png.64
new file mode 100644
index 0000000..958ab8a
--- /dev/null
+++ b/base64/reset.png.64
@@ -0,0 +1 @@
+iVBORw0KGgoAAAANSUhEUgAAAB4AAAAgCAYAAAAFQMh/AAAACXBIWXMAAACIAAAAiAHr3JJSAAAAGXRFWHRTb2Z0d2FyZQB3d3cuaW5rc2NhcGUub3Jnm+48GgAAAltJREFUSImt18tvTVEUx/HP1WiiRNVE1YCItJWiBiIxMRADA21MxCPxiAQTI/+AgUc8ykRUhH9AJQy8JiVmJhJpQkSISBRtJQZarRZlsM9N9729r3N7f8ka3HPWWt+799l7rb1Jpzrsw0MMYQrv0IO1KXNVrM14jX9FbApnUV9L6JEkcTFobE+xqBbQkxUCY+vH/FJJ68pAD6IXmejZXzzBLdzBABrRHPmsxlI8KjusAurEuNyR3Ed7Ad8MDmEsz78rLXQJ3kcJJnGsgritGI3ivmBxGvC9KHgc21PE7pU76guVBu6KgqawMwU0q74oxwRaygU04GMUdKAKqAQ0EeW5VC7gXOR8o0poVtejXD/QFL+Mt9MqXMNvvBK+1Z+UsGWJNeETtiXQX8IMjCTvUi24StSJb8oXmBO1BhOaxdcS0MvFAjvQOkd4u7CH86EPFKmWzcKqHkr+wFzUhs8R9AUWFnJcgOeR4zDWzRHeisHEVhRymIe7Zk/NMNbXAF509q4UgGZtBBvmCC+ooyWgWfuOTbWEZrDSzErrFho/MyVzMPn9U5j6NGrAM6wROtwWYfHOUpNQabIj7U0JytfNKNeZcs49kfMEllcJPRzl+SDsmpJqEWprNuh2FdBuoeZnc1TcWi/KXVx7UkB3yG2JfSliNcoteaPCsaaUMkLxj0f6VhWdqEvuqMeE75Yp4Nsh3C7y/auufFfN3tMDwoHhOE4JB/i/eT7T2F8tlHAo7y8AL2XTatRvG/C4QuikcAmomepxWun700tsrCU0VhvO441QvweFM/huocNVrP+6PgXaCh5PhAAAAABJRU5ErkJggg==
\ No newline at end of file
diff --git a/base64/rotation_clockwise.png.64 b/base64/rotation_clockwise.png.64
new file mode 100644
index 0000000..feb796d
--- /dev/null
+++ b/base64/rotation_clockwise.png.64
@@ -0,0 +1 @@
+iVBORw0KGgoAAAANSUhEUgAAACAAAAAYCAYAAACbU/80AAAACXBIWXMAAADbAAAA2wHwUOacAAAAGXRFWHRTb2Z0d2FyZQB3d3cuaW5rc2NhcGUub3Jnm+48GgAAAXRJREFUSInF1r9OFFEUgPHfriawu1ESCdgZGkIhWkJhYYQHoLDRxNLwACQklDwAFQ3lJhI6okJB3AcwsbIhtFpBhf8SIya6QHF3ks3A7t47MnKSU8095/vmzp0zw9XHMm7FLq6WIPAIb2MlyhCAObyJkShLAOaxg5HrEoAneI3bvRZUCjSt4SEmMYV7wlYPda5NYyxX8w5P8asAD4ziJbbxHWcFcg/1VPA4VvGlIDSfLTRi4S9wfEXgJIkhvCoB3J27wnm5EDXh/S0TnuXOZRIb/wme5VY3/BlO/6HZET7jR8TaNjYxkcEb+JQI/IYmFnC360bWB9R9wOP81i8lgP92IOP5JgMEDrGIG/mCCvYj4T+FidYv8gInWMOdXgWzkfA2ng+A5wV2cX9QwUqkQDMCngkcCGcjKjYj4CfCRycmZjAcC4f3EQLbKQ1ToqrrXewTrbIEiBscD65T4I/EZ5oSN/FRGCr1DrAi/OFkA+MrfpclcA5HFShV5l7kTwAAAABJRU5ErkJggg==
\ No newline at end of file
diff --git a/base64/rotation_counterclockwise.png.64 b/base64/rotation_counterclockwise.png.64
new file mode 100644
index 0000000..a7e2468
--- /dev/null
+++ b/base64/rotation_counterclockwise.png.64
@@ -0,0 +1 @@
+iVBORw0KGgoAAAANSUhEUgAAACAAAAAYCAYAAACbU/80AAAACXBIWXMAAADbAAAA2wHwUOacAAAAGXRFWHRTb2Z0d2FyZQB3d3cuaW5rc2NhcGUub3Jnm+48GgAAAXRJREFUSInF1r1LHFEUxuEnLgRdVoJpFKuktg02KdJaCEkhWKRTsLXSvyGFlaZWRNJEAhqCWlslnUhsNCSk0CKLSAh+gR8pZhfGDZs5szrrCweGO+fe98c9nMshrm5M5cgPqSOYV8Z7PL9rgKj5Gq6x0m7zCjZq5m0HqGA9ZV4IwIMm62V8wFDDehVfcYpz/MFP7GIP27V/t1K65nnjCMsYw+NWzDvxqUXzxjjEG/Tfh3k6qhjPMu/CxwLM0zGPh83MVws2r8dy7aZv6F2bzOsx1wjwBEu4DGz+jR84uAXAFUYaIeAFPmdsnk3l9+EVFiTtlwfim6Td/1EJE9gPAKTVi7fBW6zHZJOzkDwiM5JXLQJQ1yiOgwBbGWeBATfbMwsAXkvqHIF4FoGAl9gJAsBiEGA6CkDSv4PB3Kc4CwAs5gHIq5UAwGapQIBHGM7IKUVnwlb0JZBTKdBfGRf+X4KjZhPRXek7emrfl5IJ6loyiZ3g119x6S+ogBYJVgAAAABJRU5ErkJggg==
\ No newline at end of file
diff --git a/convertAll.sh b/convertAll.sh
new file mode 100644
index 0000000..99faa89
--- /dev/null
+++ b/convertAll.sh
@@ -0,0 +1 @@
+find *.png -type f -exec ./convertto64.sh {} +
\ No newline at end of file
diff --git a/convertto64.sh b/convertto64.sh
new file mode 100644
index 0000000..fd232f5
--- /dev/null
+++ b/convertto64.sh
@@ -0,0 +1,5 @@
+rm *.64
+for i in "$@"; do
+ echo "Converting $i to base 64."
+ base64 $i > $i.64
+done
\ No newline at end of file
diff --git a/delete.png b/delete.png
new file mode 100644
index 0000000..81d4ce9
Binary files /dev/null and b/delete.png differ
diff --git a/delete_cursor.png b/delete_cursor.png
new file mode 100644
index 0000000..c41a135
Binary files /dev/null and b/delete_cursor.png differ
diff --git a/dot.svg b/dot.svg
index 2038606..2e890f8 100644
--- a/dot.svg
+++ b/dot.svg
@@ -26,11 +26,11 @@
borderopacity="1.0"
inkscape:pageopacity="0.0"
inkscape:pageshadow="2"
- inkscape:zoom="1.4"
- inkscape:cx="566.11657"
- inkscape:cy="502.60366"
+ inkscape:zoom="0.49497475"
+ inkscape:cx="343.44105"
+ inkscape:cy="757.79528"
inkscape:document-units="mm"
- inkscape:current-layer="layer2"
+ inkscape:current-layer="layer8"
inkscape:document-rotation="0"
showgrid="false"
inkscape:window-width="1274"
@@ -54,7 +54,7 @@
inkscape:groupmode="layer"
id="layer2"
inkscape:label="Writer"
- style="display:inline">
+ style="display:none">
+ style="fill:#206476;fill-opacity:1;stroke:#999999;stroke-width:0.264583px;stroke-linecap:butt;stroke-linejoin:miter;stroke-opacity:1" />
@@ -93,7 +93,7 @@
inkscape:label="Dot"
inkscape:groupmode="layer"
id="layer1"
- style="display:inline">
+ style="display:none">
+
+
+
+
+
+
+
+
+
+
+
+
+
+ X
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
0) {
+ BOT_TAPE=BOT_QUEUE[0]
+ } else {
+ BOT_TAPE="BR"
+ }
+ BOT_STATE=ALIVE
+ gameState=WAITING
+ BOT_X=gameStage.start.x
+ BOT_Y=gameStage.start.y
+ BOT_DIR=RIGHT
+ gameState=RUNNING
+ for (var i=0;i{
+ if (tape.length===0) {
+ return false;
+ }
for (var i=0;i0) {
- BUTTON_SELECTED=button;
- SUBMENU.visible=true;
- SUBMENU.buttons=[]
- var index = 0;
- for (var button2 of BUTTON_SELECTED.submenu_buttons) {
- var buttonX = ((index%3)*48)+16
- var buttonY = canvas.height*0.8-(Math.floor(index/3)*48)-40
- SUBMENU.buttons.push({def:button2,img:button2.img,x:buttonX,y:buttonY,w:32,h:32})
- index++;
+ if (button.cb!==undefined) {
+ button.cb()
+ return;
+ } else {
+ DELETEMODE=false
+ document.body.style.cursor="url('cursor.png') 8 8,auto"
+ if (button.submenu_buttons&&button.submenu_buttons.length>0) {
+ BUTTON_SELECTED=button;
+ SUBMENU.visible=true;
+ SUBMENU.buttons=[]
+ var index = 0;
+ for (var button2 of BUTTON_SELECTED.submenu_buttons) {
+ var buttonX = ((index%3)*48)+16
+ var buttonY = canvas.height*0.8-(Math.floor(index/3)*48)-40
+ SUBMENU.buttons.push({def:button2,img:button2.img,x:buttonX,y:buttonY,w:32,h:32})
+ index++;
+ }
}
+ ITEM_SELECTED=button.lastselected
+ //console.log(button)
+ return
}
- ITEM_SELECTED=button.lastselected
- //console.log(button)
- return
}
}
}
//console.log(getGridCoords(getMousePos(e)))
- if (ITEM_SELECTED!==undefined) {
+ if (ITEM_SELECTED!==undefined||DELETEMODE) {
var clickCoords = getGridCoords(getMousePos(e))
if (clickCoords.x>=0&&clickCoords.y>=0&&clickCoords.ywidth-24) {
+ xOffset=0;
+ yOffset+=24;
+ }
+ }
+}
+
+function createVerticalGradient(x,y,up,ctx) {
+ var gradient = ctx.createLinearGradient(x, y+32*((up)?1:0), x, y+32*((up)?0:1));
+ gradient.addColorStop(0,"rgb(124,162,157)")
+ gradient.addColorStop(0.31,"black")
+ gradient.addColorStop(0.6,"rgb(124,162,157)")
+ gradient.addColorStop(0.61,"black")
+ gradient.addColorStop(0.9,"rgb(124,162,157)")
+ gradient.addColorStop(0.91,"white")
+ gradient.addColorStop(1,"white")
+ return gradient
+}
+
+function createHorizontalGradient(x,y,right,ctx) {
+ var gradient = ctx.createLinearGradient(x+32*((right)?0:1), y, x+32*((right)?1:0), y);
+ gradient.addColorStop(0,"rgb(124,162,157)")
+ gradient.addColorStop(0.31,"black")
+ gradient.addColorStop(0.6,"rgb(124,162,157)")
+ gradient.addColorStop(0.61,"black")
+ gradient.addColorStop(0.9,"rgb(124,162,157)")
+ gradient.addColorStop(0.91,"white")
+ gradient.addColorStop(1,"white")
+ return gradient
+}
+
+function DrawSingleConveyor(x,y,dir,ctx) {
+ ctx.lineWidth = 16;
+ ctx.lineCap = "square"
+ ctx.strokeStyle="rgb(124,162,157)"
+ ctx.setLineDash([])
+ if (dir===LEFT||dir===RIGHT) {
+ ctx.beginPath()
+ ctx.moveTo(x+8,y+16)
+ ctx.lineTo(x+24,y+16)
+ ctx.stroke()
+ ctx.setLineDash([5,5])
+ ctx.lineDashOffset = -dashOffset*((dir===LEFT)?-1:1);
+ ctx.strokeStyle=createHorizontalGradient(x,y,dir===RIGHT,ctx)
+ ctx.lineWidth = 3.5;
+ ctx.beginPath()
+ ctx.moveTo(x+2,y+16)
+ ctx.lineTo(x+30,y+16)
+ ctx.stroke()
+ } else {
+ ctx.beginPath()
+ ctx.moveTo(x+16,y+8)
+ ctx.lineTo(x+16,y+24)
+ ctx.stroke()
+ ctx.strokeStyle="rgb(34,62,57)"
+ ctx.setLineDash([5,5])
+ ctx.lineDashOffset = -dashOffset*((dir===DOWN)?1:-1);
+ ctx.strokeStyle=createVerticalGradient(x,y,dir===UP,ctx)
+ ctx.lineWidth = 3.5;
+ ctx.beginPath()
+ ctx.moveTo(x+16,y+2)
+ ctx.lineTo(x+16,y+30)
+ ctx.stroke()
+ }
+}
+
+function GetOppositeDirection(dir) {
+ switch (dir) {
+ case UP:{return DOWN}
+ case DOWN:{return UP}
+ case LEFT:{return RIGHT}
+ case RIGHT:{return LEFT}
+ }
+}
+
+function DrawConnectedConveyor(x,y,ctx,connections,dir,pass=0) {
+ ctx.lineWidth = 15;
+ ctx.lineCap = "round"
+ ctx.strokeStyle="rgb(124,162,157)"
+ switch (Object.keys(connections).length) {
+ case 0:{
+ DrawSingleConveyor(x,y,dir,ctx)
+ }break;
+ default:{
+ ctx.lineWidth = 15;
+ ctx.lineCap = "square"
+ ctx.strokeStyle="rgb(124,162,157)"
+ ctx.setLineDash([])
+ ctx.beginPath()
+ ctx.moveTo(x+16,y+16)
+ var endingPoint={x:0,y:0}
+ switch (dir) {
+ case UP:{startingPoint={x:0,y:-12};endingPoint={x:0,y:-14}}break;
+ case DOWN:{startingPoint={x:0,y:12};endingPoint={x:0,y:14}}break;
+ case RIGHT:{startingPoint={x:12,y:0};endingPoint={x:14,y:0}}break;
+ case LEFT:{startingPoint={x:-12,y:0};endingPoint={x:-14,y:0}}break;
+ }
+ ctx.moveTo(x+16+startingPoint.x,y+16+startingPoint.y)
+ ctx.lineTo(x+16+endingPoint.x,y+16+endingPoint.y)
+ if (pass===0) {ctx.stroke();}
+ for (var connection of Object.keys(connections)) {
+ var startingPoint={x:x,y:y}
+ switch (Number(connection)) {
+ case UP:{startingPoint={x:x+16,y:y+8}}break;
+ case DOWN:{startingPoint={x:x+16,y:y+24}}break;
+ case RIGHT:{startingPoint={x:x+24,y:y+16}}break;
+ case LEFT:{startingPoint={x:x+8,y:y+16}}break;
+ }
+ ctx.lineWidth = 16;
+ ctx.lineCap = "square"
+ ctx.strokeStyle="rgb(124,162,157)"
+ ctx.setLineDash([])
+ ctx.beginPath()
+ ctx.moveTo(startingPoint.x,startingPoint.y)
+ ctx.lineTo(x+16,y+16)
+ if (pass===0) {ctx.stroke()}
+ ctx.setLineDash([5,5])
+ ctx.lineDashOffset = -dashOffset*1;
+ if (Number(connection)===RIGHT||Number(connection)===LEFT) {
+ ctx.strokeStyle=createHorizontalGradient(x,y,Number(connection)===LEFT,ctx)
+ } else {
+ ctx.strokeStyle=createVerticalGradient(x,y,Number(connection)===UP,ctx)
+ }
+ ctx.lineWidth = 3.5;
+ ctx.beginPath()
+ startingPoint={x:x,y:y}
+ switch (Number(connection)) {
+ case UP:{startingPoint={x:x+16,y:y+2}}break;
+ case DOWN:{startingPoint={x:x+16,y:y+30}}break;
+ case RIGHT:{startingPoint={x:x+30,y:y+16}}break;
+ case LEFT:{startingPoint={x:x+2,y:y+16}}break;
+ }
+ ctx.moveTo(startingPoint.x,startingPoint.y)
+ ctx.lineTo(x+16,y+16)
+ if (pass===1) {ctx.stroke()}
+ }
+
+ if (dir===RIGHT||dir===LEFT) {
+ ctx.strokeStyle=createHorizontalGradient(x,y,dir===LEFT,ctx)
+ } else {
+ ctx.strokeStyle=createVerticalGradient(x,y,dir===UP,ctx)
+ }
+ ctx.setLineDash([5,5])
+ ctx.lineWidth = 3.5;
+ ctx.beginPath()
+ switch (dir) {
+ case UP:{startingPoint={x:0,y:-14}}break;
+ case DOWN:{startingPoint={x:0,y:14}}break;
+ case RIGHT:{startingPoint={x:14,y:0}}break;
+ case LEFT:{startingPoint={x:-14,y:0}}break;
+ }
+ ctx.moveTo(x+16,y+16)
+ ctx.lineTo(x+16+startingPoint.x,y+16+startingPoint.y)
+ if (pass===1) {ctx.stroke();}
+ }break;
+ }
+}
+
+function RenderConveyor(x,y,ctx,icon_definition,dir=0,background=undefined,grid=undefined) {
+ if (grid===undefined) {
+ DrawSingleConveyor(x,y,dir,ctx)
+ } else {
+ var connections = {}
+ if (grid.x>0) {if (gameGrid[grid.y][grid.x-1].direction===RIGHT){connections[LEFT]=true}}
+ if (grid.x0) {if (gameGrid[grid.y-1][grid.x].direction===DOWN){connections[UP]=true}}
+ if (grid.y=buttonX&&LAST_MOUSE_X<=buttonX+32&&LAST_MOUSE_Y>=buttonY&&LAST_MOUSE_Y<=buttonY+32)?"#555555":"#b5b5b5")
+ RenderIcon(buttonX,buttonY,ctx,button,ITEM_DIRECTION,(LAST_MOUSE_X>=buttonX&&LAST_MOUSE_X<=buttonX+32&&LAST_MOUSE_Y>=buttonY&&LAST_MOUSE_Y<=buttonY+32)?"#555555":"#b5b5b5")
index++;
}
}
@@ -655,9 +1030,9 @@ function RenderMenu(ctx) {
var buttonY = canvas.height*0.8+16
for (var button of MENU.buttons) {
if (button.lastselected) {
- RenderIcon(buttonX,buttonY,ctx,button.lastselected,0,"#b5b5b5")
+ RenderIcon(buttonX,buttonY,ctx,button.lastselected,(button.cb===undefined)?ITEM_DIRECTION:0,"#b5b5b5")
} else {
- AddButton(button.img,buttonX,buttonY,ctx,button,0)
+ AddButton(button.img,buttonX,buttonY,ctx,button,(button.cb===undefined)?ITEM_DIRECTION:0)
}
button.x=buttonX
button.y=buttonY
@@ -668,10 +1043,14 @@ function RenderMenu(ctx) {
}
}
-function AddButton(img,x,y,ctx,button,rot=0) {
+function AddButton(img,x,y,ctx,button,dir=0) {
ctx.fillStyle="#b5b5b5"
ctx.fillRect(x,y,32,32)
- drawImage(x+16,y+16,img,ctx,rot)
+ if (img===IMAGE_WRITER) {
+ drawImage(x+16,y+16,img,ctx,dir*90-90)
+ } else {
+ drawImage(x+16,y+16,img,ctx,dir*90)
+ }
}
function ConsumeTape() {
diff --git a/game.test.js b/game.test.js
index f85e408..6eb08b4 100644
--- a/game.test.js
+++ b/game.test.js
@@ -442,9 +442,9 @@ function runTests() {
.it("Run a TESTING state to see if an acceptable player-built level has no bots in queue.",()=>{
loadStage(STAGE2)
gameGrid=[
- [{},{},{},{},{},],
- [{},{...BELTDOWN},{},{},{},],
- [{},{...BRANCHRIGHT},{...BELTRIGHT},{...BELTRIGHT},{type:"EXIT"},],
+ [{},{...BELTRIGHT},{...BELTRIGHT},{...BELTDOWN},{},],
+ [{...BELTRIGHT},{...BRANCHUP},{},{...BELTDOWN},{},],
+ [{},{...BRANCHRIGHT},{},{...BELTRIGHT},{type:"EXIT"},],
[{},{},{},{},{},],
[{},{},{},{},{},],
]
@@ -469,13 +469,15 @@ function runTests() {
console.log("ALL TESTS: "+totalTestsPassed+" passed, "+(totalTests-totalTestsPassed)+" failed, "+totalTests+" total")
if (testsPass===undefined) {
testsPass=true
- }
+ }
+ resetGame();
}
function runGame() {
+ resetGame();
setupGame();
- loadLevel(LEVEL2,0,2)
+ //loadLevel(LEVEL2,0,2)
setInterval(()=>{
step()
draw()
diff --git a/image_data.js b/image_data.js
index 923efc4..ec9a2f1 100644
--- a/image_data.js
+++ b/image_data.js
@@ -41,4 +41,16 @@ IMAGE_DOT_P.src="
const IMAGE_DOT_R = new Image();
IMAGE_DOT_R.src=""
const IMAGE_DOT_Y = new Image();
-IMAGE_DOT_Y.src=""
\ No newline at end of file
+IMAGE_DOT_Y.src=""
+const IMAGE_ROTATE_CLOCKWISE = new Image();
+IMAGE_ROTATE_CLOCKWISE.src=""
+const IMAGE_ROTATE_COUNTERCLOCKWISE = new Image();
+IMAGE_ROTATE_COUNTERCLOCKWISE.src=""
+const IMAGE_DELETE = new Image();
+IMAGE_DELETE.src=""
+const IMAGE_RESET = new Image();
+IMAGE_RESET.src=""
+const IMAGE_PLAY = new Image();
+IMAGE_PLAY.src=""
+const IMAGE_PAUSE = new Image();
+IMAGE_PAUSE.src=""
\ No newline at end of file
diff --git a/pause.png b/pause.png
new file mode 100644
index 0000000..44b7aaf
Binary files /dev/null and b/pause.png differ
diff --git a/play.png b/play.png
new file mode 100644
index 0000000..5ee66b9
Binary files /dev/null and b/play.png differ
diff --git a/reset.png b/reset.png
new file mode 100644
index 0000000..b4f1fed
Binary files /dev/null and b/reset.png differ
diff --git a/rotation_clockwise.png b/rotation_clockwise.png
new file mode 100644
index 0000000..02d0a75
Binary files /dev/null and b/rotation_clockwise.png differ
diff --git a/rotation_counterclockwise.png b/rotation_counterclockwise.png
new file mode 100644
index 0000000..e391e92
Binary files /dev/null and b/rotation_counterclockwise.png differ