|
|
@ -1,5 +1,20 @@ |
|
|
|
var canvas; |
|
|
|
var canvas; |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
const IMAGE_CONVEYOR = new Image(); |
|
|
|
|
|
|
|
IMAGE_CONVEYOR.src ="" |
|
|
|
|
|
|
|
const IMAGE_WRITER = new Image(); |
|
|
|
|
|
|
|
IMAGE_WRITER.src="" |
|
|
|
|
|
|
|
const IMAGE_ARROW = new Image(); |
|
|
|
|
|
|
|
IMAGE_ARROW.src="" |
|
|
|
|
|
|
|
const IMAGE_BOT = new Image(); |
|
|
|
|
|
|
|
IMAGE_BOT.src="" |
|
|
|
|
|
|
|
const IMAGE_BRANCH = new Image(); |
|
|
|
|
|
|
|
IMAGE_BRANCH.src="" |
|
|
|
|
|
|
|
const IMAGE_QUESTIONMARK = new Image(); |
|
|
|
|
|
|
|
IMAGE_QUESTIONMARK.src="" |
|
|
|
|
|
|
|
const IMAGE_WRITER = new Image(); |
|
|
|
|
|
|
|
IMAGE_WRITER.src="" |
|
|
|
|
|
|
|
|
|
|
|
const WAITING = 0; |
|
|
|
const WAITING = 0; |
|
|
|
const RUNNING = 1; |
|
|
|
const RUNNING = 1; |
|
|
|
const REVIEWING = 2; |
|
|
|
const REVIEWING = 2; |
|
|
@ -45,6 +60,12 @@ var WRITERRIGHT = {type:"WRITER",direction:RIGHT,color:RED} |
|
|
|
var WRITERUP = {type:"WRITER",direction:UP,color:RED} |
|
|
|
var WRITERUP = {type:"WRITER",direction:UP,color:RED} |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
var GRID_W = 32 |
|
|
|
|
|
|
|
var GRID_H = 32 |
|
|
|
|
|
|
|
var GRID_X = 20 |
|
|
|
|
|
|
|
var GRID_Y = 20 |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
var lastGameUpdate = 0; |
|
|
|
var lastGameUpdate = 0; |
|
|
|
var gameSpeed = 1000/1; |
|
|
|
var gameSpeed = 1000/1; |
|
|
|
|
|
|
|
|
|
|
@ -255,7 +276,7 @@ function runBot(testing) { |
|
|
|
gameState = REVIEWING |
|
|
|
gameState = REVIEWING |
|
|
|
BOT_STATE = DEAD |
|
|
|
BOT_STATE = DEAD |
|
|
|
} |
|
|
|
} |
|
|
|
if (!testing){renderGame()} |
|
|
|
//if (!testing){renderGame()}
|
|
|
|
} |
|
|
|
} |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
@ -273,11 +294,11 @@ function placeBot(x,y) { |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
function setupGame() { |
|
|
|
function setupGame() { |
|
|
|
canvas = document.createElement("CANVAS"); |
|
|
|
canvas = document.createElement("canvas"); |
|
|
|
canvas.style.width="100%" |
|
|
|
canvas.width=568 |
|
|
|
canvas.style.height="100%" |
|
|
|
canvas.height=320 |
|
|
|
document.getElementById("game").appendChild(canvas) |
|
|
|
document.getElementById("game").appendChild(canvas) |
|
|
|
|
|
|
|
canvas.addEventListener("mousemove",updateMouse) |
|
|
|
//gameGrid = [...createGrid(5,5)]
|
|
|
|
//gameGrid = [...createGrid(5,5)]
|
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
@ -309,23 +330,91 @@ function step() { |
|
|
|
} |
|
|
|
} |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
function updateMouse(e) { |
|
|
|
|
|
|
|
//console.log(getMousePos(canvas,e))
|
|
|
|
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
function getMousePos(canvas, evt) { |
|
|
|
|
|
|
|
var rect = canvas.getBoundingClientRect(); |
|
|
|
|
|
|
|
return { |
|
|
|
|
|
|
|
x: evt.clientX - rect.left, |
|
|
|
|
|
|
|
y: evt.clientY - rect.top |
|
|
|
|
|
|
|
}; |
|
|
|
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
function renderGame() { |
|
|
|
function renderGame() { |
|
|
|
var displayGrid = [] |
|
|
|
var displayGrid = [] |
|
|
|
displayGrid = deepCopy(gameGrid) |
|
|
|
displayGrid = deepCopy(gameGrid) |
|
|
|
if (BOT_X!==-1&&BOT_Y!==-1) { |
|
|
|
if (BOT_X!==-1&&BOT_Y!==-1) { |
|
|
|
displayGrid[BOT_Y][BOT_X]["BOT"]=true |
|
|
|
displayGrid[BOT_Y][BOT_X]["BOT"]=true |
|
|
|
} |
|
|
|
} |
|
|
|
console.log("Tape: "+BOT_TAPE) |
|
|
|
/*console.log("Tape: "+BOT_TAPE) |
|
|
|
console.log(displayGrid) |
|
|
|
console.log(displayGrid)*/ |
|
|
|
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
function colorToHex(r,g,b) { |
|
|
|
|
|
|
|
function hex(col) { |
|
|
|
|
|
|
|
function toHex(val) { |
|
|
|
|
|
|
|
switch (Math.floor(val)) { |
|
|
|
|
|
|
|
case 10:{ |
|
|
|
|
|
|
|
return "a"; |
|
|
|
|
|
|
|
}break; |
|
|
|
|
|
|
|
case 11:{ |
|
|
|
|
|
|
|
return "b"; |
|
|
|
|
|
|
|
}break; |
|
|
|
|
|
|
|
case 12:{ |
|
|
|
|
|
|
|
return "c"; |
|
|
|
|
|
|
|
}break; |
|
|
|
|
|
|
|
case 13:{ |
|
|
|
|
|
|
|
return "d"; |
|
|
|
|
|
|
|
}break; |
|
|
|
|
|
|
|
case 14:{ |
|
|
|
|
|
|
|
return "e"; |
|
|
|
|
|
|
|
}break; |
|
|
|
|
|
|
|
case 15:{ |
|
|
|
|
|
|
|
return "f"; |
|
|
|
|
|
|
|
}break; |
|
|
|
|
|
|
|
default:{ |
|
|
|
|
|
|
|
return String(Math.floor(val)); |
|
|
|
|
|
|
|
} |
|
|
|
|
|
|
|
} |
|
|
|
|
|
|
|
} |
|
|
|
|
|
|
|
var placeValue1=col%16; |
|
|
|
|
|
|
|
var placeValue2=col/16; |
|
|
|
|
|
|
|
return toHex(placeValue2)+toHex(placeValue1) |
|
|
|
|
|
|
|
} |
|
|
|
|
|
|
|
return "#"+hex(r)+hex(g)+hex(b); |
|
|
|
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
function drawImage(x,y,img,ctx,degrees){ |
|
|
|
|
|
|
|
//context.clearRect(0,0,canvas.width,canvas.height);
|
|
|
|
|
|
|
|
ctx.save(); |
|
|
|
|
|
|
|
ctx.translate(x,y); |
|
|
|
|
|
|
|
ctx.rotate(degrees*Math.PI/180); |
|
|
|
|
|
|
|
ctx.drawImage(img,-img.width/2,-img.height/2); |
|
|
|
|
|
|
|
ctx.restore(); |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
function draw() { |
|
|
|
function draw() { |
|
|
|
var ctx = canvas.getContext("2d") |
|
|
|
var ctx = canvas.getContext("2d") |
|
|
|
ctx.fillStyle="#FFF" |
|
|
|
if (Math.random()<0.01) { |
|
|
|
|
|
|
|
ctx.fillStyle="#a3adab" |
|
|
|
|
|
|
|
} else { |
|
|
|
|
|
|
|
ctx.fillStyle="#b5c4c1" |
|
|
|
|
|
|
|
} |
|
|
|
ctx.fillRect(0,0,canvas.width,canvas.height) |
|
|
|
ctx.fillRect(0,0,canvas.width,canvas.height) |
|
|
|
ctx.beginPath(); |
|
|
|
renderGame() |
|
|
|
|
|
|
|
for (var y=0;y<=gameGrid.length;y++) { |
|
|
|
|
|
|
|
ctx.moveTo(GRID_X, GRID_Y+GRID_H*y); |
|
|
|
|
|
|
|
ctx.lineTo(GRID_X+GRID_W*gameGrid.length, GRID_Y+GRID_H*y); |
|
|
|
|
|
|
|
} |
|
|
|
|
|
|
|
for (var x=0;x<=gameGrid.length;x++) { |
|
|
|
|
|
|
|
ctx.moveTo(GRID_X+GRID_W*x, GRID_Y); |
|
|
|
|
|
|
|
ctx.lineTo(GRID_X+GRID_W*x, GRID_Y+GRID_H*gameGrid.length); |
|
|
|
|
|
|
|
} |
|
|
|
|
|
|
|
ctx.fillStyle="#000000" |
|
|
|
ctx.stroke(); |
|
|
|
ctx.stroke(); |
|
|
|
|
|
|
|
//drawImage(0,0,IMAGE_CONVEYOR,ctx,0)
|
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
function ConsumeTape() { |
|
|
|
function ConsumeTape() { |
|
|
|