vis.js is a dynamic, browser-based visualization library
 
 
 

126 lines
3.7 KiB

<!DOCTYPE HTML>
<html>
<head>
<meta content="text/html;charset=utf-8" http-equiv="Content-Type">
<meta content="utf-8" http-equiv="encoding">
<title>Graph2d | Basic Example</title>
<style type="text/css">
body, html {
font-family: sans-serif;
}
</style>
<script src="../dist/vis.js"></script>
<script src="./locationTrace_processed.js"></script>
<script src="./timeTraveled_processed.js"></script>
<link href="../dist/vis.css" rel="stylesheet" type="text/css" />
<body>
<h2>Graph2d | Basic Example</h2>
<div style="width:700px; font-size:14px; text-align: justify;">
</div>
<br />
<div id="visualization"></div>
<div id="visualization2"></div>
<div id="visualization3"></div>
<script type="text/javascript">
var groups = new vis.DataSet();
groups.add({
id: 'accuracy',
content: 'accuracy'
});
//
groups.add({
id: 'latitude',
content: 'latitude'
})
groups.add({
id: 'longitude',
content: 'longitude'
})
groups.add({
id: 'timeTraveled',
content: 'timeTraveled',
options:{
yAxisOrientation:'right',
drawPoints:{style:"square", size:10}
}
})
groups.add({
id: 'db',
content: 'db',
options:{
yAxisOrientation:'right',
drawPoints:{style:"circle"}
}
})
var items = [];
var checkItems = [];
for (var i = 0; i < locationTraceData.length; i++) {
items.push({x:Number(locationTraceData[i].date+'000'), y:locationTraceData[i].value.accuracy === undefined ? 50 : locationTraceData[i].value.accuracy, group:'accuracy', label: {content:locationTraceData[i].value.event}});
items.push({x:Number(locationTraceData[i].date+'000'), y:locationTraceData[i].value.latitude === undefined ? -6.8 : locationTraceData[i].value.latitude, group:'latitude'});
items.push({x:Number(locationTraceData[i].date+'000'), y:locationTraceData[i].value.longitude === undefined ? 107.6 : locationTraceData[i].value.longitude, group:'longitude'});
}
for (var i = 0; i < timeTraveledData.length; i++) {
items.push({x:Number(timeTraveledData[i].date+'000'), y:timeTraveledData[i].value, group:'timeTraveled'});
}
var lastValue = 0;
var timeTraveled = 0;
var dt = 0;
var start = Number(locationTraceData[0].date);
var departed = false;
for (var i = 0; i < locationTraceData.length; i++) {
var event = locationTraceData[i].value.event;
if (event === 'depart') {
dt = Number(locationTraceData[i].date);
departed = true;
}
else {
if (departed === true) {
timeTraveled += Number(locationTraceData[i].date) - dt;
}
departed = false;
dt = 0;
}
checkItems.push({x:Number(locationTraceData[i].date+'000'), y:timeTraveled, group:'db'});
}
var matchingItems = [];
for (var i = 0; i < checkItems.length; i++) {
for (var j = 0; j < items.length; j++) {
if (items[j].group === 'timeTraveled') {
if (items[j].x === checkItems[i].x) {
console.log("check @ ", checkItems[i].x, items[j].y - checkItems[i].y);
matchingItems.push(checkItems[i]);
break;
}
}
}
}
items = items.concat(checkItems)
var container = document.getElementById('visualization');
var dataset = new vis.DataSet(items);
var options = {
interpolation:false,
height:800,
sort:true
};
var graph2d = new vis.Graph2d(container, dataset,groups, options);
</script>
</body>
</html>