new file: Files/flashplayer_32_sa.exe new file: favicon.ico new file: globe.gif new file: imgs/download.png new file: imgs/zuck.jpg new file: index.html new file: other.ico new file: script.js new file: site.webmanifest new file: sitemap.html new file: styles/backround.css new file: styles/border.css new file: styles/fonts/Titillium_Web/OFL.txt new file: styles/fonts/Titillium_Web/TitilliumWeb-Black.ttf new file: styles/fonts/Titillium_Web/TitilliumWeb-Bold.ttf new file: styles/fonts/Titillium_Web/TitilliumWeb-BoldItalic.ttf new file: styles/fonts/Titillium_Web/TitilliumWeb-ExtraLight.ttf new file: styles/fonts/Titillium_Web/TitilliumWeb-ExtraLightItalic.ttf new file: styles/fonts/Titillium_Web/TitilliumWeb-Italic.ttf new file: styles/fonts/Titillium_Web/TitilliumWeb-Light.ttf new file: styles/fonts/Titillium_Web/TitilliumWeb-LightItalic.ttf new file: styles/fonts/Titillium_Web/TitilliumWeb-Regular.ttf new file: styles/fonts/Titillium_Web/TitilliumWeb-SemiBold.ttf new file: styles/fonts/Titillium_Web/TitilliumWeb-SemiBoldItalic.ttf new file: styles/fonts/webfontkit-20221027-163353/generator_config.txt new file: styles/fonts/webfontkit-20221027-163353/specimen_files/grid_12-825-55-15.css new file: styles/fonts/webfontkit-20221027-163353/specimen_files/specimen_stylesheet.css new file: styles/fonts/webfontkit-20221027-163353/stylesheet.css new file: styles/fonts/webfontkit-20221027-163353/titilliumweb-extralight-demo.html new file: styles/fonts/webfontkit-20221027-163353/titilliumweb-extralight-webfont.woff new file: styles/fonts/webfontkit-20221027-163353/titilliumweb-extralight-webfont.woff2 new file: styles/fonts/webfontkit-20221027-165950/generator_config.txt new file: styles/fonts/webfontkit-20221027-165950/specimen_files/grid_12-825-55-15.css new file: styles/fonts/webfontkit-20221027-165950/specimen_files/specimen_stylesheet.css new file: styles/fonts/webfontkit-20221027-165950/stylesheet.css new file: styles/fonts/webfontkit-20221027-165950/titilliumweb-bold-demo.html new file: styles/fonts/webfontkit-20221027-165950/titilliumweb-bold-webfont.woff new file: styles/fonts/webfontkit-20221027-165950/titilliumweb-bold-webfont.woff2 new file: styles/style.css new file: tools/2048/.gitignore new file: tools/2048/.jshintrc new file: tools/2048/CONTRIBUTING.md new file: tools/2048/LICENSE.txt new file: tools/2048/README.md new file: tools/2048/Rakefile new file: tools/2048/favicon.ico new file: tools/2048/index.html new file: tools/2048/js/animframe_polyfill.js new file: tools/2048/js/application.js new file: tools/2048/js/bind_polyfill.js new file: tools/2048/js/classlist_polyfill.js new file: tools/2048/js/game_manager.js new file: tools/2048/js/grid.js new file: tools/2048/js/html_actuator.js new file: tools/2048/js/keyboard_input_manager.js new file: tools/2048/js/local_storage_manager.js new file: tools/2048/js/tile.js new file: tools/2048/meta/apple-touch-icon.png new file: tools/webretro/cores/neocd_libretro.js new file: tools/webretro/cores/neocd_libretro.wasm new file: tools/webretro/cores/nestopia_libretro.js new file: tools/webretro/cores/nestopia_libretro.wasm new file: tools/webretro/cores/o2em_libretro.js new file: tools/webretro/cores/o2em_libretro.wasm new file: tools/webretro/cores/opera_libretro.js new file: tools/webretro/cores/opera_libretro.wasm
145 lines
3.9 KiB
JavaScript
145 lines
3.9 KiB
JavaScript
function KeyboardInputManager() {
|
|
this.events = {};
|
|
|
|
if (window.navigator.msPointerEnabled) {
|
|
//Internet Explorer 10 style
|
|
this.eventTouchstart = "MSPointerDown";
|
|
this.eventTouchmove = "MSPointerMove";
|
|
this.eventTouchend = "MSPointerUp";
|
|
} else {
|
|
this.eventTouchstart = "touchstart";
|
|
this.eventTouchmove = "touchmove";
|
|
this.eventTouchend = "touchend";
|
|
}
|
|
|
|
this.listen();
|
|
}
|
|
|
|
KeyboardInputManager.prototype.on = function (event, callback) {
|
|
if (!this.events[event]) {
|
|
this.events[event] = [];
|
|
}
|
|
this.events[event].push(callback);
|
|
};
|
|
|
|
KeyboardInputManager.prototype.emit = function (event, data) {
|
|
var callbacks = this.events[event];
|
|
if (callbacks) {
|
|
callbacks.forEach(function (callback) {
|
|
callback(data);
|
|
});
|
|
}
|
|
};
|
|
|
|
KeyboardInputManager.prototype.listen = function () {
|
|
var self = this;
|
|
|
|
var map = {
|
|
38: 0, // Up
|
|
39: 1, // Right
|
|
40: 2, // Down
|
|
37: 3, // Left
|
|
75: 0, // Vim up
|
|
76: 1, // Vim right
|
|
74: 2, // Vim down
|
|
72: 3, // Vim left
|
|
87: 0, // W
|
|
68: 1, // D
|
|
83: 2, // S
|
|
65: 3 // A
|
|
};
|
|
|
|
// Respond to direction keys
|
|
document.addEventListener("keydown", function (event) {
|
|
var modifiers = event.altKey || event.ctrlKey || event.metaKey ||
|
|
event.shiftKey;
|
|
var mapped = map[event.which];
|
|
|
|
if (!modifiers) {
|
|
if (mapped !== undefined) {
|
|
event.preventDefault();
|
|
self.emit("move", mapped);
|
|
}
|
|
}
|
|
|
|
// R key restarts the game
|
|
if (!modifiers && event.which === 82) {
|
|
self.restart.call(self, event);
|
|
}
|
|
});
|
|
|
|
// Respond to button presses
|
|
this.bindButtonPress(".retry-button", this.restart);
|
|
this.bindButtonPress(".restart-button", this.restart);
|
|
this.bindButtonPress(".keep-playing-button", this.keepPlaying);
|
|
|
|
// Respond to swipe events
|
|
var touchStartClientX, touchStartClientY;
|
|
var gameContainer = document.getElementsByClassName("game-container")[0];
|
|
|
|
gameContainer.addEventListener(this.eventTouchstart, function (event) {
|
|
if ((!window.navigator.msPointerEnabled && event.touches.length > 1) ||
|
|
event.targetTouches.length > 1) {
|
|
return; // Ignore if touching with more than 1 finger
|
|
}
|
|
|
|
if (window.navigator.msPointerEnabled) {
|
|
touchStartClientX = event.pageX;
|
|
touchStartClientY = event.pageY;
|
|
} else {
|
|
touchStartClientX = event.touches[0].clientX;
|
|
touchStartClientY = event.touches[0].clientY;
|
|
}
|
|
|
|
event.preventDefault();
|
|
});
|
|
|
|
gameContainer.addEventListener(this.eventTouchmove, function (event) {
|
|
event.preventDefault();
|
|
});
|
|
|
|
gameContainer.addEventListener(this.eventTouchend, function (event) {
|
|
if ((!window.navigator.msPointerEnabled && event.touches.length > 0) ||
|
|
event.targetTouches.length > 0) {
|
|
return; // Ignore if still touching with one or more fingers
|
|
}
|
|
|
|
var touchEndClientX, touchEndClientY;
|
|
|
|
if (window.navigator.msPointerEnabled) {
|
|
touchEndClientX = event.pageX;
|
|
touchEndClientY = event.pageY;
|
|
} else {
|
|
touchEndClientX = event.changedTouches[0].clientX;
|
|
touchEndClientY = event.changedTouches[0].clientY;
|
|
}
|
|
|
|
var dx = touchEndClientX - touchStartClientX;
|
|
var absDx = Math.abs(dx);
|
|
|
|
var dy = touchEndClientY - touchStartClientY;
|
|
var absDy = Math.abs(dy);
|
|
|
|
if (Math.max(absDx, absDy) > 10) {
|
|
// (right : left) : (down : up)
|
|
self.emit("move", absDx > absDy ? (dx > 0 ? 1 : 3) : (dy > 0 ? 2 : 0));
|
|
}
|
|
});
|
|
};
|
|
|
|
KeyboardInputManager.prototype.restart = function (event) {
|
|
event.preventDefault();
|
|
this.emit("restart");
|
|
};
|
|
|
|
KeyboardInputManager.prototype.keepPlaying = function (event) {
|
|
event.preventDefault();
|
|
this.emit("keepPlaying");
|
|
};
|
|
|
|
KeyboardInputManager.prototype.bindButtonPress = function (selector, fn) {
|
|
var button = document.querySelector(selector);
|
|
button.addEventListener("click", fn.bind(this));
|
|
button.addEventListener(this.eventTouchend, fn.bind(this));
|
|
};
|