added ore routes

This commit is contained in:
DoomKitty87 2023-08-25 15:34:52 -07:00
parent 352861f945
commit 94a7313470
3 changed files with 200 additions and 4 deletions

File diff suppressed because one or more lines are too long

File diff suppressed because one or more lines are too long

View file

@ -17,6 +17,7 @@
</div> </div>
<div class="menubutton" onclick="resetMenu()"><h2 class="buttontext">GENERATE</h2></div> <div class="menubutton" onclick="resetMenu()"><h2 class="buttontext">GENERATE</h2></div>
<div class="menubutton" onclick="routeMenu()""><h2 class="buttontext">OLD ROUTES</h2></div> <div class="menubutton" onclick="routeMenu()""><h2 class="buttontext">OLD ROUTES</h2></div>
<div class="menubutton" onclick="oreMenu()""><h2 class="buttontext">ORE ROUTES</h2></div>
</div> </div>
<div class="main"> <div class="main">
<div class="menucontainer" id="menua"> <div class="menucontainer" id="menua">
@ -122,7 +123,13 @@
<div class="settingbox"> <div class="settingbox">
<h2 class="settingdesc">Set allowed out of bounds range from the 8x8 chunk area (only use if you know what that means).</h2> <h2 class="settingdesc">Set allowed out of bounds range from the 8x8 chunk area (only use if you know what that means).</h2>
<form> <form>
<input class="oobform" type="number" value="0"> <input class="oobform" type="number" id="oobform" value="0">
</form>
</div>
<div class="settingbox">
<h2 class="settingdesc">Set minimum teleport pad separation (3 for dillo, 5 for manual).</h2>
<form>
<input class="oobform" type="number" id="minpad" value="3">
</form> </form>
</div> </div>
<div class="settingbox"> <div class="settingbox">
@ -187,10 +194,166 @@
</div> </div>
</div> </div>
</div> </div>
<div class="menucontainer" id="menuc">
<div class="menuscreen" id="menuc1">
<div class="lefttextcontainer">
<div class="infobox">
<h1 class="infotitle">ORE ROUTES</h1>
<h3 class="infodesc">Set preferences then click generate.</h3>
</div>
<div class="settingbox">
<form>
<input class="priorityform" id="coal" type="radio" value="coal" name="oretype" checked>
<label class="priorityform" for="coal">Coal</label>
<br>
<input class="priorityform" id="iron" type="radio" value="iron" name="oretype">
<label class="priorityform" for="iron">Iron</label>
<br>
<input class="mfbox" type="checkbox" id="mfore">
<label class="mfbox" for="mfore">Magma Fields Only (Ruby/Topaz)</label>
<br><br>
<input class="oobform" type="number" id="wps" value="100">
<label class="anglesettings" for="wps">Waypoint count</label>
<br><br>
<input class="oobform" type="number" id="minpaddist" value="7">
<label class="anglesettings" for="minpaddist">Minimum vein distance (to prevent overlap)</label>
<br><br>
<input class="oobform" type="number" id="originx" value="512">
<input class="oobform" type="number" id="originy" value="150">
<input class="oobform" type="number" id="originz" value="512">
<br>
<h3 class="settingdesc">Desired origin point (x, y, z). Route will start as close as possible to origin.</label>
</form>
</div>
<div class="routeresults">
<div class="routebox">
<p id="oreout" class="routeoutput"></p>
</div>
</div>
<div class="nextbutton">
<h2 class="nextbuttontext" onclick="genOre()">GENERATE</h2>
</div>
</div>
</div>
</div> </div>
</div> </div>
<script> <script>
async function generateRoute(sector, allowedOOB, priority, waypointCount, angleEnable, angle22, angle33, mfOnly, checkingLOS, ignoreDens) { async function oreRoute(oreType, waypointCount, mfOnly, minDist, originX, originY, originZ) {
originX -= 202;
originZ -= 202;
originY = parseInt(originY);
console.log(originX, originY, originZ);
const readTextFile = window.__TAURI__.fs.readTextFile;
const resolveResource = window.__TAURI__.path.resolveResource;
const orePath = await resolveResource('assets/' + oreType + '.json');
const oreFile = await readTextFile(orePath);
const oreData = JSON.parse(oreFile);
//Determine starting block somehow
const oreArray = [];
for (let x = 0; x < 640; x++) {
oreArray[x] = [];
oreArray[x].length = 256;
for (let y = 0; y < 256; y++) {
oreArray[x][y] = [];
oreArray[x][y].length = 640;
for (let z = 0; z < 640; z++) {
oreArray[x][y][z] = 0;
}
}
}
console.log(oreData.length);
for (let i = 0; i < oreData.length; i++) {
oreArray[oreData[i][0] - 202][oreData[i][1]][oreData[i][2] - 202] = 1;
}
console.log("Done loading ore.");
var foundStart = false;
const path = [];
const usedPositions = [];
/*
while (!foundStart) {
var x = Math.floor(Math.random() * 640);
var y = Math.floor(Math.random() * 256);
var z = Math.floor(Math.random() * 640);
if (oreArray[x][y][z] == 1) foundStart = true;
else continue;
path.push(x, y, z);
usedPositions.push(x, y, z);
}
*/
var startX = 25;
var startY = 25;
var startZ = 25;
while (!foundStart) {
for (let x = -startX; x < startX; x++) {
for (let y = -startY; y < startY; y++) {
for (let z = -startZ; z < startZ; z++) {
if (mfOnly && y >= 64) continue;
if (originX + x < 0 || originX + x > 639 || originY + y < 0 || originY + y > 255 || originZ + z < 0 || originZ + z > 639) continue;
if (oreArray[originX + x][originY + y][originZ + z] != 1) continue;
path.push(originX + x, originY + y, originZ + z);
usedPositions.push(originX + x, originY + y, originZ + z);
foundStart = true;
break;
}
if (foundStart) break;
}
if (foundStart) break;
}
startX++;
startY++;
startZ++;
}
while (path.length / 3 != waypointCount) {
//console.log(path.length / 3);
var foundNext = false;
var xRad = minDist;
var yRad = minDist;
var zRad = minDist;
while (!foundNext) {
for (let x = -xRad; x < xRad; x++) {
for (let y = -yRad; y < yRad; y++) {
for (let z = -zRad; z < zRad; z++) {
if (x == 0 && y == 0 && z == 0) continue;
if (Math.abs(x) < minDist && Math.abs(y) < minDist && Math.abs(z) < minDist) continue;
if (mfOnly && path[path.length - 2] + y >= 64) continue;
if (path[path.length - 3] + x < 0 || path[path.length - 3] + x > 639 || path[path.length - 2] + y < 0 || path[path.length - 2] + y > 255 || path[path.length - 1] + z < 0 || path[path.length - 1] + z > 639) continue;
if (oreArray[path[path.length - 3] + x][path[path.length - 2] + y][path[path.length - 1] + z] != 1) continue;
var cntue = false;
for (let i = 0; i < usedPositions.length / 3; i++) {
if (Math.abs(usedPositions[i * 3] - (path[path.length - 3] + x)) < minDist && Math.abs(usedPositions[i * 3 + 1] - (path[path.length - 2] + y)) < minDist && Math.abs(usedPositions[i * 3 + 2] - (path[path.length - 1] + z)) < minDist) {
cntue = true;
break;
}
}
if (cntue) continue;
var newx = path[path.length - 3] + x;
var newy = path[path.length - 2] + y;
var newz = path[path.length - 1] + z;
path.push(newx, newy, newz);
usedPositions.push(path[path.length - 3]);
usedPositions.push(path[path.length - 2]);
usedPositions.push(path[path.length - 1]);
foundNext = true;
break;
}
if (foundNext) break;
}
if (foundNext) break;
}
xRad++;
yRad++;
zRad++;
}
}
var pathOutput = "[";
for (var i = 0; i < path.length / 3; i++) {
pathOutput += "{\"x\":" + (path[i * 3] + 202) + ",\"y\":" + path[i * 3 + 1] + ",\"z\":" + (path[i * 3 + 2] + 202) + ",\"r\":0,\"g\":1,\"b\":0,\"options\":{\"name\":\"" + (i + 1) + "\"}}";
if (i != path.length / 3 - 1) pathOutput += ",";
}
pathOutput += "]";
document.getElementById("oreout").innerHTML = pathOutput;
}
async function generateRoute(sector, allowedOOB, priority, waypointCount, angleEnable, angle22, angle33, mfOnly, checkingLOS, ignoreDens, minPadDist) {
const angle3 = Math.min(angle33, 360 - angle33); const angle3 = Math.min(angle33, 360 - angle33);
const angle2 = Math.min(angle22, 360 - angle22); const angle2 = Math.min(angle22, 360 - angle22);
allowedOOB = parseInt(allowedOOB); allowedOOB = parseInt(allowedOOB);
@ -364,7 +527,7 @@
weightChart[j] = Infinity; weightChart[j] = Infinity;
break; break;
} }
if (Math.abs(padCoords[j * 3] - padCoords[usedPads[k] * 3]) < 3 && Math.abs(padCoords[j * 3 + 1] - padCoords[usedPads[k] * 3 + 1]) < 3 && Math.abs(padCoords[j * 3 + 2] - padCoords[usedPads[k] * 3 + 2]) < 3) { if (Math.abs(padCoords[j * 3] - padCoords[usedPads[k] * 3]) < minPadDist && Math.abs(padCoords[j * 3 + 1] - padCoords[usedPads[k] * 3 + 1]) < minPadDist && Math.abs(padCoords[j * 3 + 2] - padCoords[usedPads[k] * 3 + 2]) < minPadDist) {
weightChart[j] = Infinity; weightChart[j] = Infinity;
break; break;
} }
@ -480,6 +643,7 @@
var mfOnly = false; var mfOnly = false;
var checkingLOS = true; var checkingLOS = true;
var noDens = false; var noDens = false;
var minPadDist = 3;
var waypointNumber = 150; var waypointNumber = 150;
@ -493,6 +657,7 @@
document.getElementById("menua1").style.opacity = 1; document.getElementById("menua1").style.opacity = 1;
document.getElementById("menua1").style.display = "flex"; document.getElementById("menua1").style.display = "flex";
document.getElementById("menub").style.height = 0; document.getElementById("menub").style.height = 0;
document.getElementById("menuc").style.height = 0;
function selectSquare(index) { function selectSquare(index) {
if (activeSquareIndex != -1) { if (activeSquareIndex != -1) {
@ -506,7 +671,15 @@
function getRoute() { function getRoute() {
var output = generateRoute(activeSquareIndex, allowedOOB, priority, waypointNumber, angleEnable, angle22, angle33, mfOnly, checkingLOS, noDens); var output = generateRoute(activeSquareIndex, allowedOOB, priority, waypointNumber, angleEnable, angle22, angle33, mfOnly, checkingLOS, noDens);
} }
function genOre() {
var oreType;
if (document.getElementById("coal").checked) oreType = "coal";
else oreType = "iron";
oreRoute(oreType, document.getElementById("wps").value, document.getElementById("mfore").checked, document.getElementById("minpaddist").value, document.getElementById("originx").value, document.getElementById("originy").value, document.getElementById("originz").value);
}
async function resetMenu() { async function resetMenu() {
document.getElementById("menuc").style.height = 0;
document.getElementById("menuc" + (currentStep)).style.display = "none";
document.getElementById("menub").style.height = 0; document.getElementById("menub").style.height = 0;
document.getElementById("menub1").style.opacity = 0; document.getElementById("menub1").style.opacity = 0;
document.getElementById("menua" + (currentStep)).style.opacity = 0; document.getElementById("menua" + (currentStep)).style.opacity = 0;
@ -538,6 +711,8 @@
if (step == 4) getRoute(); if (step == 4) getRoute();
} }
async function routeMenu() { async function routeMenu() {
document.getElementById("menuc").style.height = 0;
document.getElementById("menuc" + (currentStep)).style.display = "none";
document.getElementsByClassName("progressbar")[0].style.opacity = 0; document.getElementsByClassName("progressbar")[0].style.opacity = 0;
document.getElementById("menua" + (currentStep)).style.opacity = 0; document.getElementById("menua" + (currentStep)).style.opacity = 0;
document.getElementsByClassName("progressitem")[currentStep - 1].setAttribute("data-active", "false"); document.getElementsByClassName("progressitem")[currentStep - 1].setAttribute("data-active", "false");
@ -552,6 +727,24 @@
document.getElementById("menub1").style.display = "flex"; document.getElementById("menub1").style.display = "flex";
document.getElementById("menub1").style.opacity = 1; document.getElementById("menub1").style.opacity = 1;
} }
async function oreMenu() {
document.getElementById("menub").style.height = 0;
document.getElementById("menub1").style.opacity = 0;
document.getElementsByClassName("progressbar")[0].style.opacity = 0;
document.getElementById("menua" + (currentStep)).style.opacity = 0;
document.getElementsByClassName("progressitem")[currentStep - 1].setAttribute("data-active", "false");
document.getElementsByClassName("dot")[currentStep - 1].setAttribute("data-active", "false");
await new Promise(r => setTimeout(r, 500));
document.getElementById("menua" + (currentStep)).style.display = "none";
document.getElementById("menua").style.height = 0;
document.getElementById("menub1").style.display = "none";
currentStep = 1;
if (activeSquareIndex != -1) document.getElementById(activeSquareIndex).style.backgroundColor = "#0e141b";
activeSquareIndex = -1;
document.getElementById("menuc").style.height = "100%";
document.getElementById("menuc1").style.display = "flex";
document.getElementById("menuc1").style.opacity = 1;
}
function moveStep() { function moveStep() {
if (currentStep == 1 && activeSquareIndex == -1) return; if (currentStep == 1 && activeSquareIndex == -1) return;
if (currentStep == 1) { if (currentStep == 1) {
@ -561,7 +754,7 @@
if (currentStep == 2) waypointNumber = document.getElementById("wpform").value; if (currentStep == 2) waypointNumber = document.getElementById("wpform").value;
if (currentStep == 3) { if (currentStep == 3) {
if (document.getElementById("tp").checked) priority = "tp"; else priority = "dens"; if (document.getElementById("tp").checked) priority = "tp"; else priority = "dens";
allowedOOB = document.getElementsByClassName("oobform")[0].value; allowedOOB = document.getElementById("oobform").value;
if (document.getElementById("anglecheck").checked) { if (document.getElementById("anglecheck").checked) {
angleEnable = true; angleEnable = true;
angle22 = document.getElementById("angle22").value; angle22 = document.getElementById("angle22").value;
@ -569,6 +762,7 @@
} else angleEnable = false; } else angleEnable = false;
if (document.getElementById("los").checked) checkingLOS = true; if (document.getElementById("los").checked) checkingLOS = true;
else checkingLOS = false; else checkingLOS = false;
minPadDist = document.getElementById("minpad").value;
document.getElementById("routeout").innerHTML = "Route loading..."; document.getElementById("routeout").innerHTML = "Route loading...";
document.getElementById("routestats").innerHTML = ""; document.getElementById("routestats").innerHTML = "";
} }