waves/public/assets/g/quake3/Quake3Game.htm
2025-04-09 17:11:14 -05:00

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>