routes generated

This commit is contained in:
jeanz6 2022-08-17 11:32:42 +02:00
parent 10901d73fd
commit 86ddf74d86
3 changed files with 236 additions and 106 deletions

View File

@ -104,9 +104,47 @@ async function createDb(){
//console.log(lasttime) //console.log(lasttime)
return lasttime; return lasttime;
} }
var buffer_for_i = 0;
async function getAllCoordinates(){ async function getAllCoordinates(){
var db2 = await createDb()
const all_coordinates = db2.all
// coordinates in this schema 49.123/8.2311
var coordinates = Object.values(all_coordinates)
// parse to string for split and then split by /
var coordinate_string = coordinates.toString()
var between_string = coordinate_string.split("/")
var final_string = between_string.toString()
//comma string looks now like this : 49.1212,8.1231,49.1231, ...
var comma_string = final_string.split(',')
// create new Array and put string back in to array for using paths/polylines with leafleat
var newArray =[];
// use for loop for iterating over string and put it in the right order
for (var i = 0; i < comma_string.length; i++) {
var increment = i+1;
newArray.push([comma_string[i], comma_string[increment]])
increment = increment+1
i = i+1
}
// its only for converting the string array to a float array, because leaflethjs wants only a float array
(function(elem) {
var callee = arguments.callee;
return elem instanceof Array ? elem.map(function(elem2) { return callee(elem2); })
: parseFloat(elem);
})
newArray = newArray.map(function(elem) {
return elem.map(function(elem2) {
return parseFloat(elem2);
});
});
console.log(newArray)
//console.log(newArray)
return newArray;
}
async function getAllRoutes(){
var buffer_for_i = 0;
var db2 = await createDb() var db2 = await createDb()
const current_route = db2.all const current_route = db2.all
// coordinates in this schema 49.123/8.2311 // coordinates in this schema 49.123/8.2311
@ -191,4 +229,88 @@ async function createlistitem() {
li.appendChild(document.createTextNode("Last travelled route on: " +currentime+"")); li.appendChild(document.createTextNode("Last travelled route on: " +currentime+""));
ul.appendChild(li); ul.appendChild(li);
} }
async function clearMap() {
for(i in map._layers) {
if(map._layers[i]._path != undefined) {
try {
map.removeLayer(map._layers[i]);
}
catch(e) {
console.log("problem with " + e + map._layers[i]);
}
}
}
}
async function allRoutes(number_of_ze_route) {
//color theming
var color = ["blue","red","green","purple","gray","yellow"];
var i = Math.floor(Math.random() * 5) ;
let current = await prepare();
const current_route = current[number_of_ze_route];
clearMap()
//var marker = L.marker([49.41607523,8.67220049]).addTo(map);
polyline = L.polyline(current_route, {color: color[i]}).addTo(map);
var currentime = await getCurrentTime();
// does stuff ??
var ul = document.getElementById("list");
var li = document.createElement("li");
li.appendChild(document.createTextNode("Route "+ (number_of_ze_route + 1) + " was travelled on: " + currentime + "" ));
ul.appendChild(li);
//important for maps
map.fitBounds(polyline.getBounds());
map.fitBounds(polyline.getBounds());
return currentime;
}
async function showRoutes(){
var len_of_Routes = await getAllRoutes();
var len = len_of_Routes.length ;
console.log("Gotten all routes");
console.log(len);
var i = 0;
/* Doesnt work yet
var btn = [];
console.log("Beginning while with i = " + i)
while (i < len){
console.log("this is i: " + i)
console.log("this is len: " + len)
btn[i] = document.createElement("button");
btn[i].innerHTML = ("Route " + (i + 1));
btn[i].onclick = function () {
console.log("i is " + i)
console.log("setting allroutes with i as " + (i-1));
allRoutes((i-1));
};
document.body.appendChild(btn[i]);
console.log("Button generated with i = "+ i)
i = i + 1;
}
*/
// WORKS
console.log("this is i: " + i)
console.log("this is len: " + len)
let btn0 = document.createElement("button");
btn0.innerHTML = ("Route 1");
btn0.onclick = function () {
allRoutes((0));
};
let btn1 = document.createElement("button");
btn1.innerHTML = ("Route 2");
btn1.onclick = function () {
allRoutes((1));
};
i = i + 1;
document.body.appendChild(btn0);
document.body.appendChild(document.createElement('br'));
document.body.appendChild(btn1);
//*/
}

View File

@ -17,8 +17,10 @@
</head> </head>
<body> <body>
<div>
<button onclick="showBike()"> Locate your Bike!</button> <button onclick="showBike()"> Locate your Bike!</button>
<button onclick="displayRoute()"> Show last travelled route</button> <button onclick="displayLastRoute()"> Show last travelled route</button>
</div>
<!-- <button onclick="createlistitem()"> create route</button> --> <!-- <button onclick="createlistitem()"> create route</button> -->
<ul id="list"> <ul id="list">
@ -34,7 +36,8 @@
</div> </div>
</li> </li>
</ul> </ul>
<div id="map"></div> <!-- The MAP-->
<div style="position: relative; float:left;" id="map"></div>
<script type="text/javascript" src="lib/orbitdb.js" charset="utf-8"></script> <script type="text/javascript" src="lib/orbitdb.js" charset="utf-8"></script>
@ -58,20 +61,25 @@
<style> #map { height: 600px; width: 600px; margin: auto }</style> <style> #map { height: 600px; width: 600px; margin: auto }</style>
<!-- Buttons for Route-->
<div class="routes">
<button onclick="showRoutes()"> Show Routes </button>
</div>
<style> <style>
/* /*
*{ *{
box-sizing: border-box; box-sizing: border-box;
} }
html, body { body {
height: 100%; height: 100%;
width: 100%; width: 100%;
display: flex; display: flex;
justify-content: center; justify-content: center;
align-items: center; align-items:flex-start;
font-family: 'Roboto', sans-serif; font-family: 'Roboto', sans-serif;
background: #d4d1d1; background: #bb753b;
overflow: hidden; overflow: hidden;
} }
@ -133,3 +141,10 @@ html, body {
flex-grow: 2; flex-grow: 2;
position: relative; position: relative;
} }
.routes {
float:right ;
position: bottom;
margin-right: 20%;
}
*/
</style>

41
map.js
View File

@ -8,30 +8,23 @@ L.tileLayer('https://{s}.tile.openstreetmap.org/{z}/{x}/{y}.png', {
// helper function for displayRoute() // helper function for displayRoute()
async function prepare(){ async function prepare(){
console.log("prepare") console.log("prepare")
var route = getAllCoordinates('coordinates'); var route = getAllRoutes('coordinates');
console.log(route);
return route; return route;
} }
async function displayRoute() {
//color array async function displayLastRoute() {
let color = ["blue","red","green","purple","gray","yellow"]; clearMap()
var i = 0; //color theming
let current_route = await prepare(); let color = ["blue","red","green","purple","cyan","yellow"];
console.log("after prepare"); var i = Math.floor(Math.random() * 5) ;
console.log(current_route); let current = await prepare();
console.log("Current_route"); console.log("Length:")
console.log(current_route); console.log(current.length);
const current_route0 = current_route[0]; var len = current.length - 1;
const current_route1 = current_route[1]; const current_route = current[len];
console.log("Route 0");
// this is test
console.log(current_route0);
console.log("Route 1");
console.log(current_route1);
//var marker = L.marker([49.41607523,8.67220049]).addTo(map); //var marker = L.marker([49.41607523,8.67220049]).addTo(map);
polyline0 = L.polyline(current_route0, {color: color[i]}).addTo(map); polyline = L.polyline(current_route, {color: color[i]}).addTo(map);
polyline1 = L.polyline(current_route1, {color: color[i+1]}).addTo(map);
var currentime = await getCurrentTime(); var currentime = await getCurrentTime();
// does stuff ?? // does stuff ??
var ul = document.getElementById("list"); var ul = document.getElementById("list");
@ -39,14 +32,14 @@ async function displayRoute() {
li.appendChild(document.createTextNode("Last travelled route on: " + currentime + "" )); li.appendChild(document.createTextNode("Last travelled route on: " + currentime + "" ));
ul.appendChild(li); ul.appendChild(li);
//important for maps //important for maps
map.fitBounds(polyline0.getBounds()); map.fitBounds(polyline.getBounds());
map.fitBounds(polyline0.getBounds()); map.fitBounds(polyline.getBounds());
map.fitBounds(polyline1.getBounds());
map.fitBounds(polyline1.getBounds());
return currentime; return currentime;
} }
async function showBike(){ async function showBike(){
var current_cord = await getCurrentCoordinate() var current_cord = await getCurrentCoordinate()
L.tileLayer('http://{s}.tile.openstreetmap.org/{z}/{x}/{y}.png').addTo(map); L.tileLayer('http://{s}.tile.openstreetmap.org/{z}/{x}/{y}.png').addTo(map);