forked from sent/waves
681 lines
38 KiB
HTML
681 lines
38 KiB
HTML
<!DOCTYPE html>
|
|
<html lang="en">
|
|
<head>
|
|
<meta charset="UTF-8">
|
|
<title>Quake III Arena</title>
|
|
<style>
|
|
html,body{height:100%;padding:0;margin:0;background:#000;overflow:hidden;-webkit-user-select:none;-moz-user-select:none;user-select:none;touch-action:none}
|
|
#viewport-frame{position:absolute;top:0;left:0;bottom:0;right:0;overflow:hidden}
|
|
.loading_splash_container{position:fixed;width:64px;height:64px;left:0;right:0;top:0;bottom:0;margin:auto auto;border:0}
|
|
.lds-spinner{color:white;display:inline-block;position:relative;width:64px;height:64px}
|
|
.lds-spinner div{transform-origin:32px 32px;animation:lds-spinner 1.2s linear infinite}
|
|
.lds-spinner div:after{content:" ";display:block;position:absolute;top:3px;left:29px;width:5px;height:14px;border-radius:20%;background:white}
|
|
.lds-spinner div:nth-child(1){transform:rotate(0deg);animation-delay:-1.1s}
|
|
.lds-spinner div:nth-child(2){transform:rotate(30deg);animation-delay:-1s}
|
|
.lds-spinner div:nth-child(3){transform:rotate(60deg);animation-delay:-0.9s}
|
|
.lds-spinner div:nth-child(4){transform:rotate(90deg);animation-delay:-0.8s}
|
|
.lds-spinner div:nth-child(5){transform:rotate(120deg);animation-delay:-0.7s}
|
|
.lds-spinner div:nth-child(6){transform:rotate(150deg);animation-delay:-0.6s}
|
|
.lds-spinner div:nth-child(7){transform:rotate(180deg);animation-delay:-0.5s}
|
|
.lds-spinner div:nth-child(8){transform:rotate(210deg);animation-delay:-0.4s}
|
|
.lds-spinner div:nth-child(9){transform:rotate(240deg);animation-delay:-0.3s}
|
|
.lds-spinner div:nth-child(10){transform:rotate(270deg);animation-delay:-0.2s}
|
|
.lds-spinner div:nth-child(11){transform:rotate(300deg);animation-delay:-0.1s}
|
|
.lds-spinner div:nth-child(12){transform:rotate(330deg);animation-delay:0s}
|
|
.gui_download{position:fixed;right:10px;top:10px;z-index:999;width:64px;height:64px;cursor:pointer;display:none;background-repeat:no-repeat;background-image:url("")}
|
|
.gui_download:hover{filter:brightness(110%)}
|
|
@keyframes lds-spinner{0%{opacity:1}100%{opacity:0}}
|
|
|
|
.gui_mobile_patch{display:none;position:fixed;left:0;right:0;top:0;bottom:0;z-index:70}
|
|
.gui_mobile_look{display:none;position:fixed;left:290px;right:0;top:0;bottom:115px;z-index:75}
|
|
.gui_keyesc{display:none;position:fixed;left:5px;top:5px;width:86px;height:86px;background-color:rgba(0,0,0,0.25);border:1px solid rgba(255,255,255,0.2);font-family:Arial;font-size:35px;line-height:2.5;color:rgba(255,255,255,0.3);text-align:center;border-radius:50px;cursor:default;z-index:98}
|
|
.gui_keytab{display:none;position:fixed;left:100px;top:5px;width:86px;height:86px;background-color:rgba(0,0,0,0.25);border:1px solid rgba(255,255,255,0.2);font-family:Arial;font-size:35px;line-height:2.5;color:rgba(255,255,255,0.3);text-align:center;border-radius:50px;cursor:default;z-index:98}
|
|
.gui_keyok{display:none;position:fixed;left:195px;top:5px;width:86px;height:86px;background-color:rgba(0,0,0,0.25);border:1px solid rgba(255,255,255,0.2);font-family:Arial;font-size:35px;line-height:2.5;color:rgba(255,255,255,0.3);text-align:center;border-radius:50px;cursor:default;z-index:98}
|
|
.gui_download_mobile{display:none;position:fixed;right:5px;top:5px;width:86px;height:86px;background-color:rgba(0,0,0,0.25);border:1px solid rgba(255,255,255,0.2);font-family:Arial;font-size:35px;line-height:2.5;color:rgba(255,255,255,0.3);text-align:center;border-radius:50px;cursor:default;z-index:98}
|
|
.gui_download_mobile_icon{width:86px;height:86px;background:url("");background-repeat:no-repeat;background-position:center center;opacity:0.3}
|
|
.gui_keyfire{display:none;position:fixed;right:90px;bottom:55px;width:86px;height:86px;background-color:rgba(0,0,0,0.25);border:1px solid rgba(255,255,255,0.2);font-family:Arial;font-size:50px;line-height:1.8;color:rgba(255,255,255,0.3);text-align:center;border-radius:50px;cursor:default;z-index:98}
|
|
.gui_keyfire_icon{width:86px;height:86px;background:url("");background-repeat:no-repeat;background-position:center center;opacity:0.3}
|
|
.gui_keyjump{display:none;position:fixed;right:5px;bottom:100px;width:86px;height:86px;background-color:rgba(0,0,0,0.25);border:1px solid rgba(255,255,255,0.2);font-family:Arial;font-size:50px;line-height:1.8;color:rgba(255,255,255,0.3);text-align:center;border-radius:50px;cursor:default;z-index:98}
|
|
.gui_keyjump_icon{width:86px;height:86px;background:url("");background-repeat:no-repeat;background-position:center center;opacity:0.3}
|
|
.gui_keycrouch{display:none;position:fixed;right:5px;bottom:5px;width:86px;height:86px;background-color:rgba(0,0,0,0.25);border:1px solid rgba(255,255,255,0.2);font-family:Arial;font-size:50px;line-height:1.8;color:rgba(255,255,255,0.3);text-align:center;border-radius:50px;cursor:default;z-index:98}
|
|
.gui_keycrouch_icon{width:86px;height:86px;background:url("");background-repeat:no-repeat;background-position:center center;opacity:0.3}
|
|
.gui_nextweapon{display:none;position:fixed;right:175px;bottom:5px;width:86px;height:86px;background-color:rgba(0,0,0,0.25);border:1px solid rgba(255,255,255,0.2);font-family:Arial;font-size:35px;line-height:2.5;color:rgba(255,255,255,0.3);text-align:center;border-radius:50px;cursor:default;z-index:98}
|
|
.gui_nextweapon_icon{width:86px;height:86px;background:url("");background-repeat:no-repeat;background-position:center center;opacity:0.3}
|
|
.gui_joystick{display:none;position:fixed;left:0;bottom:0;width:205px;height:203px;z-index:98}
|
|
|
|
</style>
|
|
</head>
|
|
<body>
|
|
|
|
<div class="gui_mobile_patch" oncontextmenu="return false;"></div>
|
|
<div class="gui_mobile_look" oncontextmenu="return false;"></div>
|
|
<div class="gui_keyesc" oncontextmenu="return false;">ESC</div>
|
|
<div class="gui_keytab" oncontextmenu="return false;">TAB</div>
|
|
<div class="gui_keyok" oncontextmenu="return false;">OK</div>
|
|
<div class="gui_download_mobile" onclick="downloadProfileData()" oncontextmenu="return false;"><div class="gui_download_mobile_icon"></div></div>
|
|
<div class="gui_nextweapon" oncontextmenu="return false;"><div class="gui_nextweapon_icon"></div></div>
|
|
<div class="gui_keyfire" oncontextmenu="return false;"><div class="gui_keyfire_icon"></div></div>
|
|
<div class="gui_keyjump" oncontextmenu="return false;"><div class="gui_keyjump_icon"></div></div>
|
|
<div class="gui_keycrouch" oncontextmenu="return false;"><div class="gui_keycrouch_icon"></div></div>
|
|
<div class="gui_joystick" id="joyDiv"></div>
|
|
|
|
<div class="loading_splash_container" id="loading">
|
|
<div class="lds-spinner"><div></div><div></div><div></div><div></div><div></div><div></div><div></div><div></div><div></div><div></div><div></div><div></div></div>
|
|
</div>
|
|
<div class="gui_download" onclick="downloadProfileData()"></div>
|
|
<div id="viewport-frame"></div>
|
|
<script src="Quake3Game.js"></script>
|
|
<script>
|
|
|
|
// --------------------------------------------------------------------------------------------------------
|
|
// DESKTOP FUNCTIONS
|
|
// --------------------------------------------------------------------------------------------------------
|
|
|
|
var CTRLS_IDLE = 0;
|
|
|
|
function mouseChecker()
|
|
{
|
|
if(document.pointerLockElement==null)
|
|
{
|
|
goBackButtonResetIncrement();
|
|
}
|
|
else
|
|
{
|
|
goBackButtonTimerIncrement();
|
|
}
|
|
}
|
|
|
|
function goBackButtonResetIncrement()
|
|
{
|
|
try
|
|
{
|
|
CTRLS_IDLE = 0;
|
|
|
|
if (isMobileDevice()==false)
|
|
{
|
|
// SHOWS THE DOWNLOAD BUTTON
|
|
document.getElementsByClassName("gui_download")[0].style.display = "block";
|
|
}
|
|
}
|
|
catch(err)
|
|
{
|
|
}
|
|
}
|
|
|
|
function goBackButtonTimerIncrement()
|
|
{
|
|
try
|
|
{
|
|
CTRLS_IDLE = CTRLS_IDLE + 1;
|
|
if (CTRLS_IDLE >= 3)
|
|
{
|
|
// HIDES THE DOWNLOAD BUTTON
|
|
document.getElementsByClassName("gui_download")[0].style.display = "none";
|
|
}
|
|
}
|
|
catch(err)
|
|
{
|
|
}
|
|
}
|
|
|
|
// --------------------------------------------------------------------------------------------------------
|
|
// PROFILE MANAGMENT FUNCTIONS
|
|
// --------------------------------------------------------------------------------------------------------
|
|
|
|
function getProfileData()
|
|
{
|
|
var myTempProfile = parent.profileData;
|
|
return myTempProfile;
|
|
}
|
|
|
|
function clearProfileData()
|
|
{
|
|
parent.profileData = null;
|
|
}
|
|
|
|
function downloadProfileData()
|
|
{
|
|
try
|
|
{
|
|
var rawReading = FS.readFile("/base/baseq3/q3config.cfg");
|
|
var fileAsArray = new Uint8Array(rawReading);
|
|
download_Blob(fileAsArray, "q3config.cfg", "application/octet-stream");
|
|
}
|
|
catch(err)
|
|
{
|
|
}
|
|
}
|
|
|
|
function download_Blob(data, fileName, mimeType)
|
|
{
|
|
var blob, url;
|
|
blob = new Blob([data], {type: mimeType});
|
|
url = window.URL.createObjectURL(blob);
|
|
download_URL(url, fileName);
|
|
setTimeout(function()
|
|
{
|
|
return window.URL.revokeObjectURL(url);
|
|
}, 1000);
|
|
}
|
|
|
|
function download_URL(data, fileName)
|
|
{
|
|
var a;
|
|
a = document.createElement("a");
|
|
a.href = data;
|
|
a.download = fileName;
|
|
document.body.appendChild(a);
|
|
a.style = "display: none";
|
|
a.click();
|
|
a.remove();
|
|
}
|
|
|
|
// --------------------------------------------------------------------------------------------------------
|
|
// MOBILE CHECKER FUNCTION
|
|
// --------------------------------------------------------------------------------------------------------
|
|
|
|
function isMobileDevice()
|
|
{
|
|
if(navigator.userAgent.match(/Android/i) ||
|
|
navigator.userAgent.match(/webOS/i) ||
|
|
navigator.userAgent.match(/iPhone/i) ||
|
|
navigator.userAgent.match(/iPad/i) ||
|
|
navigator.userAgent.match(/iPod/i) ||
|
|
navigator.userAgent.match(/BlackBerry/i) ||
|
|
navigator.userAgent.match(/Windows Phone/i))
|
|
{
|
|
return true;
|
|
}
|
|
else
|
|
{
|
|
return false;
|
|
}
|
|
}
|
|
|
|
// --------------------------------------------------------------------------------------------------------
|
|
// DEFINING KEY STATUS FOR MOBILE DEVICES
|
|
// --------------------------------------------------------------------------------------------------------
|
|
|
|
var keyUpActive = false;
|
|
var keyDownActive = false;
|
|
var keyLeftActive = false;
|
|
var keyRightActive = false;
|
|
|
|
var keyEscActive = false;
|
|
var keyTabActive = false;
|
|
var keyOkActive = false;
|
|
var keyNextWeaponActive = false;
|
|
var keyFireActive = false;
|
|
var keyJumpActive = false;
|
|
var keyCrouchActive = false;
|
|
|
|
var lookLeftActive = false;
|
|
var lookRightActive = false;
|
|
|
|
var joystickActive = false;
|
|
|
|
// --------------------------------------------------------------------------------------------------------
|
|
// VIRTUAL JOYSTICK FOR MOBILE DEVICES
|
|
// --------------------------------------------------------------------------------------------------------
|
|
|
|
var JoyStick=function(t,e){var i=void 0===(e=e||{}).title?"joystick":e.title,n=void 0===e.width?0:e.width,o=void 0===e.height?0:e.height,h=void 0===e.internalFillColor?"rgba(0,0,0,0.25)":e.internalFillColor,r=void 0===e.internalLineWidth?2:e.internalLineWidth,d=(void 0===e.internalStrokeColor||e.internalStrokeColor,void 0===e.externalLineWidth?2:e.externalLineWidth),a=void 0===e.externalStrokeColor?"rgba(0,0,0,0)":e.externalStrokeColor,c=document.getElementById(t),l=document.createElement("canvas");l.id=i,0==n&&(n=c.clientWidth),0==o&&(o=c.clientHeight),l.width=n,l.height=o,c.appendChild(l);var u=l.getContext("2d"),g=0,s=2*Math.PI,f=(l.width-110)/2,v=f+5,w=f+30,p=l.width/2,C=l.height/2,L=l.width/10,W=-1*L,k=l.height/10,E=-1*k,m=p,S=C;function x(){u.beginPath(),u.arc(p,C,w,0,s,!1),u.lineWidth=d,u.strokeStyle=a,u.stroke()}function y(){u.beginPath(),m<f&&(m=v),m+f>l.width&&(m=l.width-v),S<f&&(S=v),S+f>l.height&&(S=l.height-v),u.arc(m,S,f,0,s,!1),u.fillStyle=h,u.fill(),u.lineWidth=r,u.strokeStyle="rgba(255,255,255,0.175)",u.stroke()}l.addEventListener("touchstart",function(t){g=1},!1),l.addEventListener("touchmove",function(t){if(t.preventDefault(),1==g)try{for(var e=l.getBoundingClientRect(),i=e.left+l.offsetWidth,n=e.top,o=-1,h=0;h<t.touches.length;h++)t.touches[h].pageX<=i&&t.touches[h].pageY>=n&&(o=h);o>-1&&(m=t.touches[o].pageX,S=l.height-(window.innerHeight-t.touches[o].pageY),m-=l.offsetLeft,u.clearRect(0,0,l.width,l.height),x(),y())}catch(t){}},!1),l.addEventListener("touchend",function(t){g=0,m=p,S=C,u.clearRect(0,0,l.width,l.height),x(),y()},!1),l.addEventListener("mousedown",function(t){g=1},!1),l.addEventListener("mousemove",function(t){1==g&&(m=t.pageX,S=l.height-(window.innerHeight-t.pageY),m-=l.offsetLeft,S-=l.offsetTop,u.clearRect(0,0,l.width,l.height),x(),y())},!1),l.addEventListener("mouseup",function(t){g=0,m=p,S=C,u.clearRect(0,0,l.width,l.height),x(),y()},!1),x(),y(),this.GetWidth=function(){return l.width},this.GetHeight=function(){return l.height},this.GetPosX=function(){return m},this.GetPosY=function(){return S},this.GetX=function(){return((m-p)/v*100).toFixed()},this.GetY=function(){return((S-C)/v*100*-1).toFixed()},this.GetDir=function(){var t="",e=m-p,i=S-C;return i>=E&&i<=k&&(t="C"),i<E&&(t="N"),i>k&&(t="S"),e<W&&("C"==t?t="W":t+="W"),e>L&&("C"==t?t="E":t+="E"),t}};
|
|
|
|
var joystick = null;
|
|
|
|
function joystickSetActive(a)
|
|
{
|
|
joystickActive = a;
|
|
}
|
|
|
|
function showVirtualJoystick()
|
|
{
|
|
joystick = new JoyStick("joyDiv");
|
|
setInterval(function()
|
|
{
|
|
var joystickDirection = joystick.GetDir();
|
|
switch(joystickDirection)
|
|
{
|
|
case "N":
|
|
try{keyUp(true);keyDown(false);keyLeft(false);keyRight(false)}catch(err){}
|
|
break;
|
|
|
|
case "S":
|
|
try{keyUp(false);keyDown(true);keyLeft(false);keyRight(false)}catch(err){}
|
|
break;
|
|
|
|
case "W":
|
|
try{keyUp(false);keyDown(false);keyLeft(true);keyRight(false)}catch(err){}
|
|
break;
|
|
|
|
case "E":
|
|
try{keyUp(false);keyDown(false);keyLeft(false);keyRight(true)}catch(err){}
|
|
break;
|
|
|
|
case "NW":
|
|
try{keyUp(true);keyDown(false);keyLeft(true);keyRight(false)}catch(err){}
|
|
break;
|
|
|
|
case "NE":
|
|
try{keyUp(true);keyDown(false);keyLeft(false);keyRight(true)}catch(err){}
|
|
break;
|
|
|
|
case "SE":
|
|
try{keyUp(false);keyDown(true);keyLeft(false);keyRight(true)}catch(err){}
|
|
break;
|
|
|
|
case "SW":
|
|
try{keyUp(false);keyDown(true);keyLeft(true);keyRight(false)}catch(err){}
|
|
break;
|
|
|
|
default:
|
|
try{keyUp(false);keyDown(false);keyLeft(false);keyRight(false)}catch(err){}
|
|
break;
|
|
}
|
|
}, 25);
|
|
}
|
|
|
|
// --------------------------------------------------------------------------------------------------------
|
|
// VIRTUAL KEYS FUNCTIONS FOR MOBILE DEVICES
|
|
// --------------------------------------------------------------------------------------------------------
|
|
|
|
function sendEvent(eventType, eventCode)
|
|
{
|
|
try
|
|
{
|
|
var oEvent = document.createEvent("KeyboardEvent");
|
|
|
|
Object.defineProperty(oEvent,"keyCode",{get:function(){return this.keyCodeVal}}); // CHROMIUM HACK
|
|
Object.defineProperty(oEvent,"which",{get:function(){return this.keyCodeVal}}); // CHROMIUM HACK
|
|
|
|
if (oEvent.initKeyboardEvent)
|
|
{
|
|
oEvent.initKeyboardEvent(eventType, true, true, document.defaultView, false, false, false, false, eventCode, eventCode);
|
|
}
|
|
else
|
|
{
|
|
oEvent.initKeyEvent(eventType, true, true, document.defaultView, false, false, false, false, eventCode, eventCode);
|
|
}
|
|
|
|
oEvent.keyCodeVal = eventCode;
|
|
|
|
Module["canvas"].dispatchEvent(oEvent);
|
|
}
|
|
catch(err)
|
|
{
|
|
}
|
|
}
|
|
|
|
function keyUp(active)
|
|
{
|
|
if (active==true && keyUpActive==false)
|
|
{
|
|
sendEvent("keydown",87);
|
|
sendEvent("keydown",38);
|
|
keyUpActive = true;
|
|
}
|
|
else if (active==false && keyUpActive==true)
|
|
{
|
|
sendEvent("keyup",87);
|
|
sendEvent("keyup",38);
|
|
keyUpActive = false;
|
|
}
|
|
}
|
|
|
|
function keyDown(active)
|
|
{
|
|
if (active==true && keyDownActive==false)
|
|
{
|
|
sendEvent("keydown",83);
|
|
sendEvent("keydown",40);
|
|
keyDownActive = true;
|
|
}
|
|
else if (active==false && keyDownActive==true)
|
|
{
|
|
sendEvent("keyup",83);
|
|
sendEvent("keyup",40);
|
|
keyDownActive = false;
|
|
}
|
|
}
|
|
|
|
function keyLeft(active)
|
|
{
|
|
if (active==true && keyLeftActive==false)
|
|
{
|
|
sendEvent("keydown",65);
|
|
keyLeftActive = true;
|
|
}
|
|
else if (active==false && keyLeftActive==true)
|
|
{
|
|
sendEvent("keyup",65);
|
|
keyLeftActive = false;
|
|
}
|
|
}
|
|
|
|
function keyRight(active)
|
|
{
|
|
if (active==true && keyRightActive==false)
|
|
{
|
|
sendEvent("keydown",68);
|
|
keyRightActive = true;
|
|
}
|
|
else if (active==false && keyRightActive==true)
|
|
{
|
|
sendEvent("keyup",68);
|
|
keyRightActive = false;
|
|
}
|
|
}
|
|
|
|
function keyEsc(active)
|
|
{
|
|
if (active==true && keyEscActive==false)
|
|
{
|
|
sendEvent("keydown",27);
|
|
keyEscActive = true;
|
|
}
|
|
else if (active==false && keyEscActive==true)
|
|
{
|
|
sendEvent("keyup",27);
|
|
keyEscActive = false;
|
|
}
|
|
}
|
|
|
|
function keyTab(active)
|
|
{
|
|
if (active==true && keyTabActive==false)
|
|
{
|
|
sendEvent("keydown",9);
|
|
keyTabActive = true;
|
|
}
|
|
else if (active==false && keyTabActive==true)
|
|
{
|
|
sendEvent("keyup",9);
|
|
keyTabActive = false;
|
|
}
|
|
}
|
|
|
|
function keyOk(active)
|
|
{
|
|
if (active==true && keyOkActive==false)
|
|
{
|
|
sendEvent("keydown",13);
|
|
keyOkActive = true;
|
|
}
|
|
else if (active==false && keyOkActive==true)
|
|
{
|
|
sendEvent("keyup",13);
|
|
keyOkActive = false;
|
|
}
|
|
}
|
|
|
|
function keyNextWeapon(active)
|
|
{
|
|
if (active==true && keyNextWeaponActive==false)
|
|
{
|
|
sendEvent("keydown",191);
|
|
keyNextWeaponActive = true;
|
|
}
|
|
else if (active==false && keyNextWeaponActive==true)
|
|
{
|
|
sendEvent("keyup",191);
|
|
keyNextWeaponActive = false;
|
|
}
|
|
}
|
|
|
|
function keyFire(active)
|
|
{
|
|
if (active==true && keyFireActive==false)
|
|
{
|
|
sendEvent("keydown",17);
|
|
keyFireActive = true;
|
|
}
|
|
else if (active==false && keyFireActive==true)
|
|
{
|
|
sendEvent("keyup",17);
|
|
keyFireActive = false;
|
|
}
|
|
}
|
|
|
|
function keyJump(active)
|
|
{
|
|
if (active==true && keyJumpActive==false)
|
|
{
|
|
sendEvent("keydown",32);
|
|
keyJumpActive = true;
|
|
}
|
|
else if (active==false && keyJumpActive==true)
|
|
{
|
|
sendEvent("keyup",32);
|
|
keyJumpActive = false;
|
|
}
|
|
}
|
|
|
|
function keyCrouch(active)
|
|
{
|
|
if (active==true && keyCrouchActive==false)
|
|
{
|
|
sendEvent("keydown",67);
|
|
keyCrouchActive = true;
|
|
}
|
|
else if (active==false && keyCrouchActive==true)
|
|
{
|
|
sendEvent("keyup",67);
|
|
keyCrouchActive = false;
|
|
}
|
|
}
|
|
|
|
function lookLeft(active)
|
|
{
|
|
if (active==true && lookLeftActive==false)
|
|
{
|
|
sendEvent("keydown",37);
|
|
lookLeftActive = true;
|
|
}
|
|
else if (active==false && lookLeftActive==true)
|
|
{
|
|
sendEvent("keyup",37);
|
|
lookLeftActive = false;
|
|
}
|
|
}
|
|
|
|
function lookRight(active)
|
|
{
|
|
if (active==true && lookRightActive==false)
|
|
{
|
|
sendEvent("keydown",39);
|
|
lookRightActive = true;
|
|
}
|
|
else if (active==false && lookRightActive==true)
|
|
{
|
|
sendEvent("keyup",39);
|
|
lookRightActive = false;
|
|
}
|
|
}
|
|
|
|
// --------------------------------------------------------------------------------------------------------
|
|
// LOOKING FUNCTIONS FOR MOBILE DEVICES
|
|
// --------------------------------------------------------------------------------------------------------
|
|
|
|
var xDown = 0;
|
|
var yDown = 0;
|
|
|
|
var currentFingerLook = -1;
|
|
|
|
document.getElementsByClassName("gui_mobile_look")[0].addEventListener("touchstart", function(event)
|
|
{
|
|
var tempObject1 = document.getElementsByClassName("gui_mobile_look")[0].getBoundingClientRect();
|
|
var tempObject1_Left = tempObject1.left;
|
|
var tempObject1_Top = tempObject1.top + document.getElementsByClassName("gui_mobile_look")[0].offsetHeight;
|
|
|
|
for (var i=0; i < event.touches.length; i++)
|
|
{
|
|
// TEMP OBJECT 1 VALIDATION
|
|
if (event.touches[i].pageX>=tempObject1_Left && event.touches[i].pageY<=tempObject1_Top)
|
|
{
|
|
currentFingerLook = i;
|
|
}
|
|
}
|
|
|
|
if (currentFingerLook>-1)
|
|
{
|
|
var firstTouch = event.touches[currentFingerLook];
|
|
xDown = firstTouch.clientX;
|
|
yDown = firstTouch.clientY;
|
|
}
|
|
});
|
|
|
|
document.getElementsByClassName("gui_mobile_look")[0].addEventListener("touchmove", function(event)
|
|
{
|
|
if (!xDown || !yDown)
|
|
{
|
|
return;
|
|
}
|
|
|
|
var tempObject1 = document.getElementsByClassName("gui_mobile_look")[0].getBoundingClientRect();
|
|
var tempObject1_Left = tempObject1.left;
|
|
var tempObject1_Top = tempObject1.top + document.getElementsByClassName("gui_mobile_look")[0].offsetHeight;
|
|
|
|
for (var i=0; i < event.touches.length; i++)
|
|
{
|
|
// TEMP OBJECT 1 VALIDATION
|
|
if (event.touches[i].pageX>=tempObject1_Left && event.touches[i].pageY<=tempObject1_Top)
|
|
{
|
|
currentFingerLook = i;
|
|
}
|
|
}
|
|
|
|
if (currentFingerLook>-1)
|
|
{
|
|
var xUp = event.touches[currentFingerLook].clientX;
|
|
var yUp = event.touches[currentFingerLook].clientY;
|
|
var xDiff = xDown - xUp;
|
|
var yDiff = yDown - yUp;
|
|
|
|
var eventCatched = false;
|
|
|
|
if (Math.abs(xDiff)>Math.abs(yDiff))
|
|
{
|
|
if (xDiff > 30)
|
|
{
|
|
lookLeft(true);
|
|
lookRight(false);
|
|
xDown = xUp;
|
|
yDown = yUp;
|
|
eventCatched = true;
|
|
}
|
|
else if (xDiff < -30)
|
|
{
|
|
lookLeft(false);
|
|
lookRight(true);
|
|
xDown = xUp;
|
|
yDown = yUp;
|
|
eventCatched = true;
|
|
}
|
|
}
|
|
else
|
|
{
|
|
if (yDiff > 25)
|
|
{
|
|
// LOOK UP
|
|
}
|
|
else if (yDiff < -25)
|
|
{
|
|
// LOOK DOWN
|
|
}
|
|
}
|
|
|
|
if (eventCatched = false)
|
|
{
|
|
lookLeft(false);
|
|
lookRight(false);
|
|
}
|
|
}
|
|
});
|
|
|
|
document.getElementsByClassName("gui_mobile_look")[0].addEventListener("touchend", function(event)
|
|
{
|
|
lookLeft(false);
|
|
lookRight(false);
|
|
xDown = null;
|
|
yDown = null;
|
|
currentFingerLook = -1;
|
|
});
|
|
|
|
// --------------------------------------------------------------------------------------------------------
|
|
// WINDOW ONLOAD AND ONRESIZE FUNCTIONS
|
|
// --------------------------------------------------------------------------------------------------------
|
|
|
|
window.addEventListener("load", function()
|
|
{
|
|
document.getElementById("loading").style.display = "none";
|
|
|
|
if (isMobileDevice()==true)
|
|
{
|
|
document.getElementsByClassName("gui_mobile_patch")[0].style.display = "block";
|
|
document.getElementsByClassName("gui_mobile_look")[0].style.display = "block";
|
|
document.getElementsByClassName("gui_keyesc")[0].style.display = "block";
|
|
document.getElementsByClassName("gui_keyesc")[0].addEventListener("touchstart",function(event){keyEsc(true)});
|
|
document.getElementsByClassName("gui_keyesc")[0].addEventListener("touchend",function(event){keyEsc(false)});
|
|
document.getElementsByClassName("gui_keytab")[0].style.display = "block";
|
|
document.getElementsByClassName("gui_keytab")[0].addEventListener("touchstart",function(event){keyTab(true)});
|
|
document.getElementsByClassName("gui_keytab")[0].addEventListener("touchend",function(event){keyTab(false)});
|
|
document.getElementsByClassName("gui_keyok")[0].style.display = "block";
|
|
document.getElementsByClassName("gui_keyok")[0].addEventListener("touchstart",function(event){keyOk(true)});
|
|
document.getElementsByClassName("gui_keyok")[0].addEventListener("touchend",function(event){keyOk(false)});
|
|
document.getElementsByClassName("gui_keyfire")[0].style.display = "block";
|
|
document.getElementsByClassName("gui_keyfire")[0].addEventListener("touchstart",function(event){keyFire(true)});
|
|
document.getElementsByClassName("gui_keyfire")[0].addEventListener("touchend",function(event){keyFire(false)});
|
|
document.getElementsByClassName("gui_keyjump")[0].style.display = "block";
|
|
document.getElementsByClassName("gui_keyjump")[0].addEventListener("touchstart",function(event){keyJump(true)});
|
|
document.getElementsByClassName("gui_keyjump")[0].addEventListener("touchend",function(event){keyJump(false)});
|
|
document.getElementsByClassName("gui_keycrouch")[0].style.display = "block";
|
|
document.getElementsByClassName("gui_keycrouch")[0].addEventListener("touchstart",function(event){keyCrouch(true)});
|
|
document.getElementsByClassName("gui_keycrouch")[0].addEventListener("touchend",function(event){keyCrouch(false)});
|
|
document.getElementsByClassName("gui_download_mobile")[0].style.display = "block";
|
|
document.getElementsByClassName("gui_nextweapon")[0].style.display = "block";
|
|
document.getElementsByClassName("gui_nextweapon")[0].addEventListener("touchstart",function(event){keyNextWeapon(true)});
|
|
document.getElementsByClassName("gui_nextweapon")[0].addEventListener("touchend",function(event){keyNextWeapon(false)});
|
|
document.getElementsByClassName("gui_joystick")[0].style.display = "block";
|
|
document.getElementsByClassName("gui_joystick")[0].addEventListener("touchstart",function(event){joystickSetActive(true)});
|
|
document.getElementsByClassName("gui_joystick")[0].addEventListener("touchend",function(event){joystickSetActive(false)});
|
|
document.getElementsByClassName("gui_download")[0].style.display = "none";
|
|
showVirtualJoystick();
|
|
}
|
|
|
|
setInterval(goBackButtonTimerIncrement, 1000);
|
|
document.addEventListener("click", mouseChecker, false);
|
|
document.addEventListener("dblclick", mouseChecker, false);
|
|
document.addEventListener("mousemove", mouseChecker, false);
|
|
document.addEventListener("pointerlockchange", mouseChecker, false);
|
|
document.addEventListener("mozpointerlockchange", mouseChecker, false);
|
|
document.addEventListener("webkitpointerlockchange", mouseChecker, false);
|
|
|
|
ioq3.viewport = document.getElementById("viewport-frame");
|
|
ioq3.elementPointerLock = true;
|
|
ioq3.exitHandler = function (err)
|
|
{
|
|
if (err!=null)
|
|
{
|
|
alert(err);
|
|
}
|
|
parent.unloadContainer();
|
|
}
|
|
|
|
var args = ["+set","cl_yawspeed","240"]; // FOR A FASTER 'MOUSE LOOK' IN MOBILE DEVICES
|
|
ioq3.callMain(args);
|
|
});
|
|
|
|
window.addEventListener("resize", function()
|
|
{
|
|
try
|
|
{
|
|
if (!ioq3.canvas){return}
|
|
if ((document["webkitFullScreenElement"] || document["webkitFullscreenElement"] || document["mozFullScreenElement"] || document["mozFullscreenElement"] || document["fullScreenElement"] || document["fullscreenElement"])){return}
|
|
ioq3.setCanvasSize(ioq3.viewport.offsetWidth, ioq3.viewport.offsetHeight);
|
|
}
|
|
catch(err)
|
|
{
|
|
}
|
|
});
|
|
</script>
|
|
</body>
|
|
</html> |