You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

144 lines
3.5 KiB

var map = L.map('map', { zoomControl: false }).setView([45.516, -122.660], 14, null, null, 24);
var layer = L.esri.basemapLayer("Topographic");
layer.maxZoom = 24;
layer.maxNativeZoom = 24;
layer.addTo(map);
new L.Control.Zoom({ position: 'topleft' }).addTo(map);
var geojsonLineOptions = {
color: "#0033ff",
weight: 4,
opacity: 0.5
};
var visible_layers = [];
var visible_data = [];
var highlightedMarker;
var animatedMarker;
var timers = [];
function resetAnimation() {
if(animatedMarker) {
map.removeLayer(animatedMarker);
}
if(timers.length > 0) {
for(var i in timers) {
clearTimeout(timers[i]);
}
}
}
jQuery(function($){
$('.calendar a').click(function(evt){
var append = evt.altKey;
if(!append) {
$('.calendar a').removeClass('selected');
if(visible_layers.length) {
for(var i in visible_layers) {
map.removeLayer(visible_layers[i]);
}
}
visible_layers = [];
visible_data = [];
}
$(this).addClass('selected');
resetAnimation();
var db_name = $("#database").data("name");
var db_token = $("#database").data("token");
$.get("/api/query?format=linestring&date="+$(this).data('date')+"&tz=America/Los_Angeles&token="+db_token, function(response){
var data = response.linestring;
if(data.coordinates && data.coordinates.length > 0) {
// For any null coordinates, fill it in with the previous location
var lastCoord = null;
for(var i in data.coordinates) {
if(data.coordinates[i] == null) {
data.coordinates[i] = lastCoord;
} else {
lastCoord = data.coordinates[i];
}
}
visible_data.push(data);
visible_layers.push(L.geoJson(data, {
style: geojsonLineOptions
}).addTo(map));
// If the new layer is completely outside the current view, zoom the map to fit all layers
var layer = visible_layers[visible_layers.length - 1];
var is_outside = false;
if(!map.getBounds().intersects(layer.getBounds())) {
is_outside = true;
}
if(is_outside) {
var full_bounds;
for(var i in visible_layers) {
layer = visible_layers[i];
if(full_bounds) {
full_bounds.extend(layer.getBounds());
} else {
full_bounds = layer.getBounds();
}
}
map.fitBounds(full_bounds);
}
showBatteryGraph(response);
}
});
return false;
});
$('#btn-play').click(function(){
console.log(visible_data[0].coordinates[0]);
var point = pointFromGeoJSON(visible_data[0].coordinates[0]);
resetAnimation();
animatedMarker = L.marker(point);
animatedMarker.addTo(map);
timers = [];
var interval = 3;
for(var i in visible_data[0].coordinates) {
(function(i){
timers.push(setTimeout(function(){
point = pointFromGeoJSON(visible_data[0].coordinates[i]);
animatedMarker.setLatLng(point);
}, interval*i));
})(i);
}
});
$(".calendar a[data-date='"+((new Date()).toISOString().slice(0,10))+"']").focus().click();
});
function moveMarkerToPosition(point) {
if(point.location) {
var coord = pointFromGeoJSON(point.location);
if(coord) {
if(!highlightedMarker) {
highlightedMarker = L.marker(coord).addTo(map);
} else {
highlightedMarker.setLatLng(coord);
}
}
}
}
function pointFromGeoJSON(geo) {
return L.latLng(geo[1], geo[0])
}