Skip to content

Instantly share code, notes, and snippets.

@nikcub
Created September 19, 2012 09:13
Show Gist options
  • Star 0 You must be signed in to star a gist
  • Fork 0 You must be signed in to fork a gist
  • Save nikcub/3748621 to your computer and use it in GitHub Desktop.
Save nikcub/3748621 to your computer and use it in GitHub Desktop.
keyboard nav for xkcd 1110
// get the map element
var el = $('.map')[0];
// amount in pixels we want to move each keypress/hold
var move = 200;
function fakeMouseEvent(type, x, y) {
var evt = document.createEvent("MouseEvents");
evt.initMouseEvent(type, true, true, window,
0, 0, 0, x, y, false, false, false, false, 0, null);
el.dispatchEvent(evt);
}
$(window).keydown(function(e) {
var key = e.which;
if (key >= 37 && key <= 40) {
e.preventDefault();
var left=0, top=0;
if (key == 37) { left += move; }
if (key == 38) { top += move; }
if (key == 39) { left -= move; }
if (key == 40) { top -= move; }
fakeMouseEvent('mousedown', 0, 0);
setTimeout(function() {
fakeMouseEvent('mousemove', left, top);
setTimeout(function() {
fakeMouseEvent('mouseup', left, top);
}, 0);
}, 0);
}
});
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment