Create basic images

master
sigonasr2 4 years ago
parent fa21e1af27
commit f6bad295e3
  1. BIN
      arrow.png
  2. BIN
      bot.png
  3. BIN
      branch.png
  4. BIN
      conveyor.png
  5. BIN
      dot.png
  6. 101
      dot.svg
  7. 109
      game.js
  8. 19
      game.test.js
  9. 10
      index.html
  10. BIN
      path839.png
  11. BIN
      questionmark.png
  12. BIN
      writer.png

Binary file not shown.

After

Width:  |  Height:  |  Size: 380 B

Binary file not shown.

After

Width:  |  Height:  |  Size: 646 B

Binary file not shown.

After

Width:  |  Height:  |  Size: 1.3 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 689 B

Binary file not shown.

After

Width:  |  Height:  |  Size: 498 B

@ -0,0 +1,101 @@
<?xml version="1.0" encoding="UTF-8" standalone="no"?>
<svg
xmlns:dc="http://purl.org/dc/elements/1.1/"
xmlns:cc="http://creativecommons.org/ns#"
xmlns:rdf="http://www.w3.org/1999/02/22-rdf-syntax-ns#"
xmlns:svg="http://www.w3.org/2000/svg"
xmlns="http://www.w3.org/2000/svg"
xmlns:sodipodi="http://sodipodi.sourceforge.net/DTD/sodipodi-0.dtd"
xmlns:inkscape="http://www.inkscape.org/namespaces/inkscape"
inkscape:version="1.0 (4035a4fb49, 2020-05-01)"
sodipodi:docname="dot.svg"
inkscape:export-ydpi="5.0500002"
inkscape:export-xdpi="5.0500002"
inkscape:export-filename="C:\Users\sigon\OneDrive\Documents\ProjectM\ProjectM\dot.png"
id="svg8"
version="1.1"
viewBox="0 0 210 297"
height="297mm"
width="210mm">
<defs
id="defs2" />
<sodipodi:namedview
inkscape:window-maximized="0"
inkscape:window-y="0"
inkscape:window-x="1946"
inkscape:window-height="1074"
inkscape:window-width="1274"
showgrid="false"
inkscape:document-rotation="0"
inkscape:current-layer="layer3"
inkscape:document-units="mm"
inkscape:cy="881.92457"
inkscape:cx="514.30548"
inkscape:zoom="0.49497475"
inkscape:pageshadow="2"
inkscape:pageopacity="0.0"
borderopacity="1.0"
bordercolor="#666666"
pagecolor="#ffffff"
id="base" />
<metadata
id="metadata5">
<rdf:RDF>
<cc:Work
rdf:about="">
<dc:format>image/svg+xml</dc:format>
<dc:type
rdf:resource="http://purl.org/dc/dcmitype/StillImage" />
<dc:title></dc:title>
</cc:Work>
</rdf:RDF>
</metadata>
<g
style="display:none"
inkscape:label="Writer"
id="layer2"
inkscape:groupmode="layer">
<rect
inkscape:export-ydpi="4.0677924"
inkscape:export-xdpi="4.0677924"
ry="0"
y="52.919369"
x="83.388092"
height="198.84853"
width="44.901279"
id="rect1010"
style="fill:#206476;fill-opacity:1;fill-rule:evenodd;stroke:#bcbcbc;stroke-width:0.964999;stroke-miterlimit:4;stroke-dasharray:none;stroke-opacity:1" />
<rect
inkscape:export-ydpi="4.0677924"
inkscape:export-xdpi="4.0677924"
transform="rotate(90)"
style="fill:#206476;fill-opacity:1;fill-rule:evenodd;stroke:#bcbcbc;stroke-width:0.964999;stroke-miterlimit:4;stroke-dasharray:none;stroke-opacity:1"
id="rect1010-9"
width="44.901279"
height="198.84853"
x="128.82391"
y="-205.79753"
ry="0" />
</g>
<g
style="display:none"
id="layer1"
inkscape:groupmode="layer"
inkscape:label="Dot">
<circle
r="34.773811"
cy="149.80829"
cx="104.04629"
id="path889"
style="fill:#a1a1a1;fill-opacity:1;fill-rule:evenodd;stroke:#000000;stroke-width:10;stroke-miterlimit:4;stroke-dasharray:none;stroke-opacity:1" />
</g>
<g
inkscape:label="Arrow"
id="layer3"
inkscape:groupmode="layer">
<path
id="path1032"
d="M 130.96875,97.895832 V 234.9122 l 70.96503,-70.96503 -71.15402,-71.154016 z"
style="fill:#c0c0c0;fill-opacity:1;stroke:#888888;stroke-width:10;stroke-linecap:butt;stroke-linejoin:miter;stroke-opacity:1;stroke-miterlimit:4;stroke-dasharray:none" />
</g>
</svg>

After

Width:  |  Height:  |  Size: 3.2 KiB

@ -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() {

@ -15,7 +15,7 @@ var TestSuite;
class describe { class describe {
constructor(testname) { constructor(testname) {
this.testname=testname this.testname=testname
this.beforecb = undefined; this.beforecb = ()=>{};
this.cb = undefined; this.cb = undefined;
this.totaltests = 0; this.totaltests = 0;
this.passedtests = 0; this.passedtests = 0;
@ -46,7 +46,7 @@ class describe {
function expect(testval1,testval2,name) { function expect(testval1,testval2,name) {
if (testval1!==testval2) { if (testval1!==testval2) {
console.log(" Test Failed!"+" ("+(new Date().getTime()-TestSuite.starttime)+"ms)"+((name)?` - ${name}`:"")) console.log(" Test Failed! Expected "+testval2+" but got "+testval1+". ("+(new Date().getTime()-TestSuite.starttime)+"ms)"+((name)?` - ${name}`:""))
TestSuite.totaltests++ TestSuite.totaltests++
testsPass=false testsPass=false
} else } else
@ -453,6 +453,15 @@ function runTests() {
}) })
.showResults() .showResults()
TestSuite = new describe("Color Hex Conversion")
TestSuite
.it("converts a color to hex",()=>{
expect(colorToHex(0,0,0),"#000000")
expect(colorToHex(66, 135, 245),"#4287f5")
expect(colorToHex(245, 66, 221),"#f542dd")
expect(colorToHex(58, 79, 55),"#3a4f37")
}).showResults()
if (testsPass===undefined) { if (testsPass===undefined) {
testsPass=true testsPass=true
} }
@ -469,6 +478,9 @@ function runGame() {
console.log("Running") console.log("Running")
} }
var RUNTESTS = true;
if (RUNTESTS) {
loadScript("game.js",runTests) loadScript("game.js",runTests)
initializeGame() initializeGame()
@ -482,3 +494,6 @@ function initializeGame() {
},1000) },1000)
} }
} }
} else {
loadScript("game.js",runGame)
}

@ -1,4 +1,10 @@
<body> <body style="background-color:gray;">
<div id="game"></div> <center>
<div id="game" style="margin: 0;
position: absolute;
top: 50%;
left: 50%;
transform: translate(-50%, -50%);"></div>
</center>
<script type="text/javascript" src="game.test.js"></script> <script type="text/javascript" src="game.test.js"></script>
</body> </body>

Binary file not shown.

After

Width:  |  Height:  |  Size: 171 B

Binary file not shown.

After

Width:  |  Height:  |  Size: 638 B

Binary file not shown.

After

Width:  |  Height:  |  Size: 347 B

Loading…
Cancel
Save