Path: blob/main/projects/1/js/keyboard_input_manager.js
1834 views
function KeyboardInputManager() {1this.events = {};23if (window.navigator.msPointerEnabled) {4//Internet Explorer 10 style5this.eventTouchstart = "MSPointerDown";6this.eventTouchmove = "MSPointerMove";7this.eventTouchend = "MSPointerUp";8} else {9this.eventTouchstart = "touchstart";10this.eventTouchmove = "touchmove";11this.eventTouchend = "touchend";12}1314this.listen();15}1617KeyboardInputManager.prototype.on = function (event, callback) {18if (!this.events[event]) {19this.events[event] = [];20}21this.events[event].push(callback);22};2324KeyboardInputManager.prototype.emit = function (event, data) {25var callbacks = this.events[event];26if (callbacks) {27callbacks.forEach(function (callback) {28callback(data);29});30}31};3233KeyboardInputManager.prototype.listen = function () {34var self = this;3536var map = {3738: 0, // Up3839: 1, // Right3940: 2, // Down4037: 3, // Left4175: 0, // vim keybindings4276: 1,4374: 2,4472: 3,4587: 0, // W4668: 1, // D4783: 2, // S4865: 3 // A49};5051document.addEventListener("keydown", function (event) {52var modifiers = event.altKey || event.ctrlKey || event.metaKey ||53event.shiftKey;54var mapped = map[event.which];5556if (!modifiers) {57if (mapped !== undefined) {58event.preventDefault();59self.emit("move", mapped);60}6162if (event.which === 32) self.restart.bind(self)(event);63}64});6566var retry = document.querySelector(".retry-button");67retry.addEventListener("click", this.restart.bind(this));68retry.addEventListener(this.eventTouchend, this.restart.bind(this));6970var keepPlaying = document.querySelector(".keep-playing-button");71keepPlaying.addEventListener("click", this.keepPlaying.bind(this));72keepPlaying.addEventListener("touchend", this.keepPlaying.bind(this));7374// Listen to swipe events75var touchStartClientX, touchStartClientY;76var gameContainer = document.getElementsByClassName("game-container")[0];7778gameContainer.addEventListener(this.eventTouchstart, function (event) {79if (( !window.navigator.msPointerEnabled && event.touches.length > 1) || event.targetTouches > 1) return;8081if(window.navigator.msPointerEnabled){82touchStartClientX = event.pageX;83touchStartClientY = event.pageY;84} else {85touchStartClientX = event.touches[0].clientX;86touchStartClientY = event.touches[0].clientY;87}8889event.preventDefault();90});9192gameContainer.addEventListener(this.eventTouchmove, function (event) {93event.preventDefault();94});9596gameContainer.addEventListener(this.eventTouchend, function (event) {97if (( !window.navigator.msPointerEnabled && event.touches.length > 0) || event.targetTouches > 0) return;9899var touchEndClientX, touchEndClientY;100if(window.navigator.msPointerEnabled){101touchEndClientX = event.pageX;102touchEndClientY = event.pageY;103} else {104touchEndClientX = event.changedTouches[0].clientX;105touchEndClientY = event.changedTouches[0].clientY;106}107108var dx = touchEndClientX - touchStartClientX;109var absDx = Math.abs(dx);110111var dy = touchEndClientY - touchStartClientY;112var absDy = Math.abs(dy);113114if (Math.max(absDx, absDy) > 10) {115// (right : left) : (down : up)116self.emit("move", absDx > absDy ? (dx > 0 ? 1 : 3) : (dy > 0 ? 2 : 0));117}118});119};120121KeyboardInputManager.prototype.restart = function (event) {122event.preventDefault();123this.emit("restart");124};125126KeyboardInputManager.prototype.keepPlaying = function (event) {127event.preventDefault();128this.emit("keepPlaying");129};130131