This repository has been archived on 2023-08-20. You can view files and clone it, but cannot push or open issues or pull requests.
basic-joystick-input-device/app/script.js

159 lines
12 KiB
JavaScript

/*
* 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 <http://www.gnu.org/licenses/>.
*
* @category UI interaction
* @package Basic Joystick Input Device
* @author Diogo Cordeiro <diogo@fc.up.pt>
* @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;
}
}