Upgrade Meteor. Use keyboard for speed input.

This commit is contained in:
Juho Teperi
2013-05-07 11:24:49 +03:00
parent e19e4ad352
commit 9a97a998b6
14 changed files with 98 additions and 120 deletions

View File

@@ -16,6 +16,7 @@
{{/if}}
{{#if sim}}
{{> sim}}
<div class="speedSliderContainer"><div class="speedSlider"></div></li></div>
{{/if}}
{{#if frontpage}}
{{> frontpage}}
@@ -165,20 +166,9 @@
<ul class="speedometer">
<li class="distance">{{km distance}} km</li>
<li class="speed">{{kmh speed}} <sup>km</sup>/<sub>h<sub></li>
<li class="calories"></li>
</ul>
</template>
<template name="distance">
<span>{{distance}}</span> km
</template>
<template name="speed">
<span>{{speed}}</span> <sup>km</sup>/<sub>h</sub>
</template>
<template name="calories">
<span>{{calories}}</span> cal
</template>
<template name="points">
<h3>Points
<span><label class="checkbox inline"><input type="checkbox" id="points-autoadd" {{#if autoadd}}checked="checked"{{/if}}/>Auto add points</label></span>

View File

@@ -115,17 +115,16 @@ a.thumbnail
height 250px
left 0
top 0
opacity 0.8
display none
opacity 0.0
.street
filter(blur(4px))
// filter(blur(4px))
.show-map
.street
filter(blur(0))
// filter(blur(0))
.map
display block
opacity 0.8
.show-sidebar
.street, .map
@@ -138,7 +137,7 @@ a.thumbnail
bottom 42px
left 0
right 0
background rgba(0, 0, 0, 0.5)
// background rgba(0, 0, 0, 0.5)
padding-top 30px
overflow-y auto
@@ -186,6 +185,13 @@ ol.points
font-weight bold
line-height 150%
.speedSliderContainer
position absolute
bottom 100px
right 20px
.speedSlider
height 200px
::-webkit-scrollbar
background transparent
border none

View File

@@ -118,14 +118,14 @@ Template.editing.owner = function () {
return user.profile.name;
};
function init_edit() {
init_edit = function init_edit() {
Meteor.autorun(function () {
if (Session.equals('page', 'edit') && Session.get('route')) {
debug('sivu tai route vaihtui, route: ' + Session.get('route'));
full_clear_required = true;
Meteor.deps.isolate(function () {
Deps.nonreactive(function () {
var route = Routes.findOne({_id: Session.get('route')});
if (route) {
maps.travel(route.first, {route: true});
@@ -141,7 +141,7 @@ Meteor.autosubscribe(function () {
if (Session.equals('page', 'edit') && Session.get('route')) {
if (full_clear_required) {
Meteor.deps.isolate(function () {
Deps.nonreactive(function () {
debug('full clear');
maps.lines.route.clear();

View File

@@ -10,12 +10,12 @@ helpers = {
}
};
var activateInput = function (input) {
activateInput = function (input) {
input.focus();
input.select();
};
var okCancelEvents = function (selector, callbacks) {
okCancelEvents = function (selector, callbacks) {
var ok = callbacks.ok || function () {};
var cancel = callbacks.cancel || function () {};
@@ -38,9 +38,3 @@ var okCancelEvents = function (selector, callbacks) {
};
return events;
};
// From: https://github.com/tmeasday/meteor-deps-extensions
Meteor.deps.isolate = function(fn) {
var context = new Meteor.deps.Context();
return context.run(fn);
};

View File

@@ -1,4 +1,4 @@
function maps_loaded() {
maps_loaded = function maps_loaded() {
window.markers = []; // fuu
@@ -153,7 +153,7 @@ var Maps = function () {
var point = Points.findOne({_id: point_id});
if (point) {
street.setPosition(glatlng(point.latlng));
street.setPosition(glatlng(point.latlng));
map.setCenter(glatlng(point.latlng));
if (point.heading) street.setPov({zoom: 1, pitch: 0, heading: point.heading});
@@ -170,7 +170,7 @@ $(document).ready(function () {
init_edit();
});
}
};
window.onload = function () {
var script = document.createElement("script");

View File

@@ -164,7 +164,7 @@ Meteor.startup(function () {
Backbone.history.start({pushState: true});
});
function init_main() {
init_main = function init_main() {
Meteor.autosubscribe(function () {
// When changing page
@@ -182,4 +182,4 @@ function init_main() {
maps.mode('sim');
}
});
}
};

View File

@@ -1,30 +1,11 @@
window.point = null;
window.traveled = 0;
var createRingBuffer = function (length){
var pointer = 0, buffer = [], sum = 0;
function move () {
if (!window.point) return;
return {
push: function (item) {
if (buffer[pointer] > 0) {
sum -= buffer[pointer];
if (sum <= 0) sum = 0;
}
buffer[pointer] = item;
sum += item;
pointer = (length + pointer + 1) % length;
},
sum: function () {
return sum;
}
};
};
var revs = 0;
$(document).bind('keydown.space', function () {
revs += 1;
var dist = localStorage['multiplier'] * c();
// var dist = localStorage['multiplier'] * c();
var dist = localStorage['multiplier'] * 0.1 * Session.get('speed');
Session.set('distance', Session.get('distance') + dist);
window.traveled += dist;
@@ -39,22 +20,23 @@ $(document).bind('keydown.space', function () {
window.point = next;
}
}
}
setInterval(move, 100);
var line = '';
$(document).on('keydown', function (e) {
if (e.keyCode === 13) { // enter
if (line.length >= 1 && line[0] == 'S') {
var speed = Number(line.slice(1));
Session.set('speed', speed);
}
line = '';
} else {
line += String.fromCharCode(e.keyCode);
}
});
// function speedo() {
// speed_buffer.push(revs * c());
// revs = 0;
// Session.set('speed', speed_buffer.sum() / 5);
// }
// setInterval(speedo, 500);
// 5sec, 2 values / sec.
var speed_buffer = createRingBuffer(5 * 2);
var speed_sum = 0;
var speed_avg = 0;
Template.sim.speed = function () {
return Session.get('speed');
};
@@ -72,47 +54,7 @@ Template.sim.helpers({
}
});
var sock = new SockJS("http://localhost:9999/speed");
function init_sim() {
sock.onopen = function() {
console.log('open');
};
sock.onmessage = function(e) {
if (Session.equals('page', 'sim') && window.point) {
debug('message', e.data);
var dist = parseInt(e.data, 10) * c();
speed_buffer.push(dist);
Session.set('speed', speed_buffer.sum() / 5);
Session.set('distance', Session.get('distance') + 3 * dist);
window.traveled += 3 * dist;
if (window.traveled >= window.point.distance) {
var next = Points.findOne({_id: window.point.next});
// Stay on current point if no next point exists
if (next) {
window.traveled -= next.distance;
maps.travel(next._id, {route: true});
zoom = 1;
zoom_target = 1;
window.point = next;
}
}
}
};
sock.onclose = function() {
console.log('close');
};
init_sim = function init_sim() {
Meteor.autosubscribe(function () {
if (Session.equals('page', 'sim')) {
@@ -135,7 +77,18 @@ Meteor.autosubscribe(function () {
p = Points.findOne({_id: p.next});
}
}
$('.speedSlider').slider({
orientation: 'vertical',
range: 'min',
min: 0,
max: 22.2, // m/s
value: 0,
slide: function (event, ui) {
Session.set('speed', ui.value);
}
});
}
});
}
};