-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathcanvasLife-9.min.html
1 lines (1 loc) · 12.5 KB
/
canvasLife-9.min.html
1
<!doctype html><html lang="de" id="*"><head><meta charset="utf-8" /><meta name="viewport" content="width=device-width, initial-scale=1.0" /><meta http-equiv="X-UA-Compatible" content="IE=Edge" /><style>*{text-align:center}table{font-family:sans-serif;font-size:small;border-collapse:collapse}table.center{margin-left:auto;margin-right:auto}tr,td{text-align:left}</style><title>canvasLife</title></head><body id="body" onload="showCanvasParam(); showControlsParam(); showStatisticParam();"><p><canvas id="canvas" width="300" height="300" style="border: 2px solid black;">Ihr Browser ist veraltet. Bitte installieren Sie eine aktuelle Version des Browsers.</canvas></p><p id="controls"> <input id="probabilityRange" name="probabilityRange" type="range" min="0" max="100" value="50" step="1" placeholder="Wahrscheinlichkeit für eine Zelle, dass sie in das Feld gelangt (0-100%, Standard: 50%)" onmousemove="rangeProbMove();" title="Wahrscheinlichkeit für eine Zelle, dass sie in das Feld gelangt (0-100%, Standard: 50%)" /> <span id="probabilityRangeTextContent" style="font-family:sans-serif; font-size:small;">50%</span> <button id="restart" name="restart" onclick="restart();" title="Startet die Simulation neu" value="restart"><img style="vertical-align : middle;" src="" alt="restart-logo" />Restart</button> <button id="stop" name="stop" onclick="stop();" title="Stoppt die Simulation" value="stop"><img style="vertical-align : middle;" src="" alt="stop-logo" />Stop</button> <button id="go" name="go" onclick="go();" title="Führt die Simulation weiter aus" value="go" disabled="disabled"><img style="vertical-align : middle;" src="" alt="go-logo" />Go</button> <br /> <button id="showCanvas" name="showCanvas" onclick="showCanvas();" title="Zeigt die Zeichenfläche an" value="showCanvas"><img style="vertical-align : middle;" src="" alt="showcanvas-logo" />Zeichenfläche an/aus</button> <br /> <button id="showControls" name="showControls" onclick="showControls();" title="Versteckt den Bereich der Kontrolle" value="showControls"><img style="vertical-align : middle;" src="" alt="showcontrols-logo" />Bedienelemente an/aus</button> <button id="showStatistic" name="showStatistic" onclick="showStatistic();" title="Zeigt den Bereich der Statistik an" value="showStatistic"><img style="vertical-align : middle;" src="" alt="showstatistic-logo" />Statistik an/aus</button></p><table id="statistic" class="center"><tr><td>Feldgröße:</td><td id="gridSizeTextContent">---</td></tr><tr><td>Zellplätze:</td><td id="maxCellPlacesTextContent">---</td></tr><tr><td>Wahrscheinlichkeit:</td><td id="probabilityCellsTextContent">---</td></tr><tr><td>Lebende Zellen zu Startbeginn:</td><td id="livingCellsStartStateTextContent">---</td></tr><tr><td>Generationen:</td><td id="generationsTextContent">---</td></tr><tr><td>Lebende Zellen:</td><td id="livingCellsTextContent">---</td></tr><tr><td>Zelldichte global:</td><td id="celluarityGlobalTextContent">---</td></tr><tr><td>Zelldichte lebend:</td><td id="celluarityLivingTextContent">---</td></tr><tr><td>Totale lebende Zellen:</td><td id="totalLivingCellsTextContent">---</td></tr><tr><td>Totale sterbende Zellen:</td><td id="totalDyingCellsTextContent">---</td></tr><tr><td>Verhältnis totaler lebender und sterbender Zellen:</td><td id="totalRatioOfLivingAndDyingCellsTextContent">---</td></tr><tr><td>Laufzeit in Millisekunden:</td><td id="runtimeTextContent">---</td></tr><tr><td>Verarbeitete Generationen pro Sekunde:</td><td id="measuredTimeOfGenerationsTextContent">---</td></tr></table> <script>"use strict";var gridWidth=findGetParameter("width"),gridHeight=findGetParameter("height"),drawColor=findGetParameter("color"),bgColor=findGetParameter("backgroundcolor"),probability=findGetParameter("probability");if(gridWidth!==null){document.getElementById("canvas").setAttribute("width",gridWidth);}else gridWidth=document.getElementById("canvas").width;if(gridHeight!==null){document.getElementById("canvas").setAttribute("height",gridHeight);}else gridHeight=document.getElementById("canvas").height;if(drawColor!==null){document.getElementById("canvas").style.borderColor=drawColor;document.getElementById("body").style.color=drawColor;} if(bgColor!==null){document.getElementById("body").style.backgroundColor=bgColor;} if(probability!==null){document.getElementById("probabilityRange").value=probability;document.getElementById("probabilityRangeTextContent").textContent=probability+"%";document.getElementById("probabilityCellsTextContent").textContent=probability+"%";} var theGrid=createArray(gridWidth),mirrorGrid=createArray(gridWidth),repeater,maxCellPlaces=gridWidth*gridHeight,generations=0,livingCells=0,livingCellsStartState=0,celluarityGlobal=0,celluarityLiving=0,totalLivingCells=0,totalDyingCells=0,startTime=0,measuredTimeOfGenerations=0;document.getElementById("gridSizeTextContent").textContent=gridWidth+"x"+gridHeight;document.getElementById("maxCellPlacesTextContent").textContent=maxCellPlaces;startTime=performance.now();fillRandom();tick();function RoundFloat(x,n){if(n<1||n>14)return false;var e=Math.pow(10,n);var k=(Math.round(x*e)/e).toString();if(k.indexOf(".")==-1)k+=".";k+=e.toString().substring(1);return k.substring(0,k.indexOf(".")+n+1);} function rangeProbMove(){document.getElementById("probabilityRangeTextContent").textContent=document.getElementById("probabilityRange").value+"%";} function restart(){stop();generations=0;livingCells=0;livingCellsStartState=0;totalLivingCells=0;totalDyingCells=0;measuredTimeOfGenerations=0;startTime=performance.now();fillRandom();drawGrid();} function stop(){document.getElementById("go").disabled="";document.getElementById("stop").disabled="disabled";cancelAnimationFrame(repeater);} function go(){stop();document.getElementById("go").disabled="disabled";document.getElementById("stop").disabled="";tick();} function showCanvasParam(){var showcanvas=findGetParameter("showcanvas") var element=document.getElementById("canvas");if(showcanvas==0||showcanvas=="false"||showcanvas=="no"||showcanvas=="disabled")element.style.display="none";} function showControlsParam(){var showcontrols=findGetParameter("showcontrols") var element=document.getElementById("controls");if(showcontrols==0||showcontrols=="false"||showcontrols=="no"||showcontrols=="disabled")element.style.visibility="hidden";} function showStatisticParam(){var showstatistic=findGetParameter("showstatistic");var element=document.getElementById("statistic");if(showstatistic===0||showstatistic==="false"||showstatistic==="no"||showstatistic==="disabled")element.style.visibility="hidden";} function showCanvas(){var element=document.getElementById("canvas");if(element.style.display==="none"){element.style.display="initial";}else{element.style.display="none";}} function showControls(){var element=document.getElementById("controls");if(element.style.display==="none"){element.style.display="initial";}else{element.style.display="none";}} function showStatistic(){var element=document.getElementById("statistic");if(element.style.display==="none"){element.style.display="initial";}else{element.style.display="none";}} function findGetParameter(parameterName){var result=null,tmp=[];var items=location.search.substr(1).split("&");for(var index=0;index<items.length;index++){tmp=items[index].split("=");if(tmp[0]===parameterName)result=decodeURIComponent(tmp[1]);} return result;} function tick(){drawGrid();updateGrid();repeater=requestAnimationFrame(tick);} function createArray(rows){var arr=[];for(var i=0;i<rows;i++){arr[i]=[];} return arr;} function fillRandom(){var max=document.getElementById("probabilityRange").getAttribute("max");var value=document.getElementById("probabilityRange").value;var arr=new Array(max);for(var i=0;i<max;i++){if(i<value)arr[i]=1;} livingCellsStartState=0;for(var j=0;j<gridHeight;j++){for(var k=0;k<gridWidth;k++){var rawRandom=Math.random();var improvedNum=(rawRandom*max);var randomBinary=Math.floor(improvedNum);if(arr[randomBinary]===1){theGrid[j][k]=1;livingCellsStartState++;totalLivingCells++;}else{theGrid[j][k]=0;}}} document.getElementById("livingCellsStartStateTextContent").textContent=livingCellsStartState;document.getElementById("probabilityCellsTextContent").textContent=value+"%";} function drawGrid(){livingCells=0;var c=document.getElementById("canvas");if(c.getContext){var ctx=c.getContext("2d");ctx.clearRect(0,0,c.width,c.height);for(var j=0;j<gridHeight;j++){for(var k=0;k<gridWidth;k++){if(theGrid[j][k]===1){livingCells++;ctx.fillStyle=drawColor;ctx.fillRect(j,k,1,1);}}} celluarityGlobal=(livingCells/maxCellPlaces)*100;celluarityLiving=(livingCells/livingCellsStartState)*100;measuredTimeOfGenerations=generations/(performance.now()-startTime)*1000;document.getElementById("generationsTextContent").textContent=generations;document.getElementById("livingCellsTextContent").textContent=livingCells;document.getElementById("celluarityGlobalTextContent").textContent=RoundFloat(celluarityGlobal,3)+"%";document.getElementById("celluarityLivingTextContent").textContent=RoundFloat(celluarityLiving,3)+"%";document.getElementById("totalLivingCellsTextContent").textContent=totalLivingCells;document.getElementById("totalDyingCellsTextContent").textContent=totalDyingCells;document.getElementById("totalRatioOfLivingAndDyingCellsTextContent").textContent=RoundFloat(totalLivingCells/totalDyingCells,3);document.getElementById("runtimeTextContent").textContent=Math.round(performance.now()-startTime);document.getElementById("measuredTimeOfGenerationsTextContent").textContent=RoundFloat(measuredTimeOfGenerations,3);}} function updateGrid(){generations++;for(var j=0;j<gridHeight;j++){for(var k=0;k<gridWidth;k++){var totalCells=0;if(j!==0) if(k!==0)totalCells+=theGrid[j-1][k-1];if(j!==0)totalCells+=theGrid[j-1][k];if(j!==0) if(k!==gridWidth-1)totalCells+=theGrid[j-1][k+1];if(k!==0)totalCells+=theGrid[j][k-1];if(k!==gridWidth-1)totalCells+=theGrid[j][k+1];if(j!==gridHeight-1) if(k!==0)totalCells+=theGrid[j+1][k-1];if(j!==gridHeight-1)totalCells+=theGrid[j+1][k];if(j!==gridHeight-1) if(k!==gridWidth-1)totalCells+=theGrid[j+1][k+1];if(theGrid[j][k]===0){switch(totalCells){case 3:mirrorGrid[j][k]=1;totalLivingCells++;break;default:mirrorGrid[j][k]=0;totalDyingCells++;}}else if(theGrid[j][k]===1){switch(totalCells){case 0:case 1:mirrorGrid[j][k]=0;totalDyingCells++;break;case 2:case 3:mirrorGrid[j][k]=1;totalLivingCells++;break;case 4:case 5:case 6:case 7:case 8:mirrorGrid[j][k]=0;totalDyingCells++;break;default:mirrorGrid[j][k]=0;totalDyingCells++;}}}} for(var j=0;j<gridHeight;j++){for(var k=0;k<gridWidth;k++){theGrid[j][k]=mirrorGrid[j][k];}}}</script> </body></html>