/* * Basic Joystick Input Device - a very simple and cool way of getting to know how a joystick works underneath the hood. * Copyright (C) 2018, Diogo Cordeiro. * * This program is free software: you can redistribute it and/or modify * it under the terms of the GNU Affero General Public License as published by * the Free Software Foundation, either version 3 of the License, or * (at your option) any later version. * * This program is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU Affero General Public License for more details. * * You should have received a copy of the GNU Affero General Public License * along with this program. If not, see . * * @category UI interaction * @package Basic Joystick Input Device * @author Diogo Cordeiro * @copyright 2018 Diogo Cordeiro. * @license http://www.fsf.org/licensing/licenses/agpl-3.0.html GNU Affero General Public License version 3.0 * @link https://www.diogo.site/projects/basic-joystick-input-device/ */ // ON and OFF leds srcs let LED_OFF = ""; let LED_ON = ""; let SQUARECSS = "border: solid darkred"; let current = "10"; //*********************************** /** * Create leds */ for (let i = 1; i <= 3; ++i) { for (let j = 0; j < 3; ++j) { // Led holder let figure = document.createElement("figure"); figure.setAttribute("class", "box"); // Led let img = document.createElement("img"); img.src = LED_OFF; img.setAttribute("value", "OFF"); img.id = "led" + i+j; img.setAttribute("class", "led"); img.setAttribute("onclick", "switch_led("+i+j+")"); figure.appendChild(img); document.getElementById("row"+i).appendChild(figure); } } // Draw the first square document.getElementById("led10").setAttribute("style", SQUARECSS); /** * Turn current answer bits accordingly */ function switch_led(led_id) { let image = document.getElementById("led"+led_id); if (image.getAttribute("value") == "ON") { image.setAttribute("value", "OFF"); image.src = LED_OFF; } else { image.setAttribute("value", "ON"); image.src = LED_ON; } } document.onkeydown = handleKey; function handleKey(e) { e = e || window.event; if (e.keyCode == '38') { // up arrow move_square("up"); } else if (e.keyCode == '40') { // down arrow move_square("down"); } else if (e.keyCode == '37') { // left arrow move_square("left"); } else if (e.keyCode == '39') { // right arrow move_square("right"); } else if (e.keyCode == '13') { // Enter key switch_led(current); } } function move_square(to) { switch (to) { case "up": if (current.charAt(0) == '1') { return; } to_id = String.fromCharCode(current.charCodeAt(0)-1)+current.charAt(1); document.getElementById("led"+current).setAttribute("style", ""); document.getElementById("led"+to_id).setAttribute("style", SQUARECSS); current = to_id; break; case "right": if (current.charAt(1) == '2') { return; } to_id = current.charAt(0)+String.fromCharCode(current.charCodeAt(1)+1); document.getElementById("led"+current).setAttribute("style", ""); document.getElementById("led"+to_id).setAttribute("style", SQUARECSS); current = to_id; break; case "down": if (current.charAt(0) == '3') { return; } to_id = String.fromCharCode(current.charCodeAt(0)+1)+current.charAt(1); document.getElementById("led"+current).setAttribute("style", ""); document.getElementById("led"+to_id).setAttribute("style", SQUARECSS); current = to_id; break; case "left": if (current.charAt(1) == '0') { return; } to_id = current.charAt(0)+String.fromCharCode(current.charCodeAt(1)-1); document.getElementById("led"+current).setAttribute("style", ""); document.getElementById("led"+to_id).setAttribute("style", SQUARECSS); current = to_id; break; } }