Add touch overlay

This commit is contained in:
Varun Patil 2020-10-19 11:41:49 +05:30
parent c4342bdb54
commit ca7f72dfc0
1 changed files with 196 additions and 38 deletions

View File

@ -3,6 +3,7 @@
<head> <head>
<meta charset="utf-8"> <meta charset="utf-8">
<meta http-equiv="Content-Type" content="text/html; charset=utf-8"> <meta http-equiv="Content-Type" content="text/html; charset=utf-8">
<meta name="viewport" content="width=device-width, initial-scale=1, minimum-scale=1, maximum-scale=1, user-scalable=no">
<script src="js/localforage.min.js"></script> <script src="js/localforage.min.js"></script>
<script src="gameasync/mapping.js"></script> <script src="gameasync/mapping.js"></script>
@ -26,7 +27,10 @@
border: 0px none; border: 0px none;
background-color: black; background-color: black;
height: 100%; height: 100%;
max-height: 100vh;
max-width: 100vw;
} }
#spinner { #spinner {
position: fixed; position: fixed;
bottom: 40px; bottom: 40px;
@ -90,6 +94,45 @@
padding: 3px 10px; padding: 3px 10px;
border-top-right-radius: 5px; border-top-right-radius: 5px;
} }
#dpad, #apad {
position: fixed;
bottom: 0; left: 0;
height: 30vh; max-height: 30vw;
width: 30vh; max-width: 30vw;
transform: translate(55%, -5%);
}
#apad {
right: 0; left: unset;
transform: unset;
width: 15vh; max-width: 15vw;
}
#dpad *, #apad * {
position: absolute;
height: 15vh; max-height: 15vw;
width: 15vh; max-width: 15vw;
background-color: gray;
opacity: 0.3;
}
#apad * {
border-radius: 50%;
}
#d-up { transform: translateY(-100%); }
#d-left { transform: translateX(-100%); }
#d-down { transform: translateY(100%); }
#d-right { transform: translateX(100%); }
#ap-b { transform: translate(-130%, 90%); }
#ap-c { transform: translate(-15%, -25%); }
#ap-a {
height: 7vh; max-height: 7vw;
width: 7vh; max-width: 7vw;
top: 50%;
transform: translate(25%, 25%);
}
</style> </style>
</head> </head>
<body> <body>
@ -100,6 +143,20 @@
<div id="progress">Loading ...</div> <div id="progress">Loading ...</div>
<canvas class="emscripten" id="canvas" oncontextmenu="event.preventDefault()" tabindex=-1 width="640" height="480"></canvas> <canvas class="emscripten" id="canvas" oncontextmenu="event.preventDefault()" tabindex=-1 width="640" height="480"></canvas>
<div id="dpad">
<div id="d-up"></div>
<div id="d-right"></div>
<div id="d-down"></div>
<div id="d-left"></div>
<div id="d-pl"></div>
</div>
<div id="apad">
<div id="ap-c"></div>
<div id="ap-b"></div>
<div id="ap-a"></div>
</div>
</div> </div>
<div onclick="fullscreen()" id="fullscreen"> <div onclick="fullscreen()" id="fullscreen">
@ -201,6 +258,7 @@
function fullscreen() { function fullscreen() {
document.getElementById('main').requestFullscreen(); document.getElementById('main').requestFullscreen();
screen.orientation.lock("landscape")
} }
window.onerror = function() { window.onerror = function() {
@ -291,6 +349,106 @@
document.body.appendChild(s); document.body.appendChild(s);
}); });
}, 500); }, 500);
function simulateKeyEvent(eventType, keyCode, charCode) {
var e = document.createEventObject ? document.createEventObject() : document.createEvent("Events");
if (e.initEvent) e.initEvent(eventType, true, true);
e.keyCode = keyCode;
e.which = keyCode;
e.charCode = charCode;
// Dispatch directly to Emscripten's html5.h API (use this if page uses emscripten/html5.h event handling):
if (typeof JSEvents !== 'undefined' && JSEvents.eventHandlers && JSEvents.eventHandlers.length > 0) {
for(var i = 0; i < JSEvents.eventHandlers.length; ++i) {
if ((JSEvents.eventHandlers[i].target == Module['canvas'] || JSEvents.eventHandlers[i].target == window)
&& JSEvents.eventHandlers[i].eventTypeString == eventType) {
JSEvents.eventHandlers[i].handlerFunc(e);
}
}
} else {
// Dispatch to browser for real (use this if page uses SDL or something else for event handling):
Module['canvas'].dispatchEvent ? Module['canvas'].dispatchEvent(e) : Module['canvas'].fireEvent("on" + eventType, e);
}
}
// Mappings
const keyMap = {};
const keysDown = {};
/** Add virtual key binding */
function bindKey(elem, key) {
keyMap[elem] = key;
const ne = document.getElementById(elem);
ne.addEventListener('touchstart', function(e) {
e.preventDefault();
simulateKeyEvent('keydown', key);
keysDown[e.target.id] = elem;
});
ne.addEventListener('touchend', function(e) {
e.preventDefault();
if (keysDown[e.target.id] && keyMap[keysDown[e.target.id]]) {
simulateKeyEvent('keyup', keyMap[keysDown[e.target.id]]);
}
keysDown[e.target.id] = 0;
});
ne.addEventListener('touchmove', function(event) {
const myLocation = event.changedTouches[0];
const realTarget = document.elementFromPoint(myLocation.clientX, myLocation.clientY).id;
const origTarget = keysDown[myLocation.target.id];
if (origTarget !== realTarget) {
if (origTarget) {
simulateKeyEvent('keyup', keyMap[origTarget]);
keysDown[myLocation.target.id] = 0;
}
if (keyMap[realTarget]) {
simulateKeyEvent('keydown', keyMap[realTarget]);
keysDown[myLocation.target.id] = realTarget;
}
}
});
}
function is_touch_device() {
try {
document.createEvent("TouchEvent");
return true;
} catch (e) {
return false;
}
}
if (!is_touch_device()) {
document.getElementById('dpad').style.display = 'none';
document.getElementById('apad').style.display = 'none';
}
// Add all bindings
bindKey('d-up', 38);
bindKey('d-right', 39);
bindKey('d-down', 40);
bindKey('d-left', 37);
bindKey('ap-c', 67);
bindKey('ap-b', 88);
bindKey('ap-a', 90);
const resize = function() {
const el = document.getElementById('canvas');
if (window.innerHeight > window.innerWidth) {
el.style.height = 'unset';
el.style.width = '100%';
} else {
el.style.width = 'unset';
el.style.height = '100%';
}
}
window.addEventListener('resize', resize);
resize();
</script> </script>
<!-- {{{ SCRIPT }}} --> <!-- {{{ SCRIPT }}} -->