// Cloned by Sophie Renshaw on 10 Nov 2021 from World "Complex World (clone by Sophie Renshaw) - V5" by Sophie Renshaw
// Please leave this clone trail here.
AB.clockTick=1e3,AB.maxSteps=10,AB.screenshotStep=50;const show3d=!0,TEXTURE_WALL="/uploads/starter/door.jpg",TEXTURE_MAZE="/uploads/starter/latin.jpg",TEXTURE_AGENT="/uploads/starter/pacman.jpg",TEXTURE_ENEMY="/uploads/starter/ghost.3.png",TEXTURE_PATH="/uploads/50ph/mjolnir.jpeg",gridsize=20,NOBOXES=Math.trunc(gridsize*gridsize/10),squaresize=100,MAXPOS=gridsize*squaresize,SKYCOLOR=14548957,startRadiusConst=.8*MAXPOS,maxRadiusConst=10*MAXPOS;ABHandler.MAXCAMERAPOS=maxRadiusConst,ABHandler.GROUNDZERO=!0;const SKYBOX_ARRAY=["/uploads/starter/dawnmountain-xpos.png","/uploads/starter/dawnmountain-xneg.png","/uploads/starter/dawnmountain-ypos.png","/uploads/starter/dawnmountain-yneg.png","/uploads/starter/dawnmountain-zpos.png","/uploads/starter/dawnmountain-zneg.png"],ACTION_LEFT=0,ACTION_RIGHT=1,ACTION_UP=2,ACTION_DOWN=3,ACTION_STAYSTILL=4,GRID_BLANK=0,GRID_WALL=1,GRID_MAZE=2;var BOXHEIGHT,theagent,theenemy,thepath,wall_texture,agent_texture,enemy_texture,maze_texture,path_texture,ei,ej,ai,aj,badsteps,goodsteps,GRID=new Array(gridsize);function loadResources(){var e=new THREE.TextureLoader,t=new THREE.TextureLoader,n=new THREE.TextureLoader,o=new THREE.TextureLoader,a=new THREE.TextureLoader;e.load(TEXTURE_WALL,function(e){e.minFilter=THREE.LinearFilter,wall_texture=e,asynchFinished()&&initScene()}),t.load(TEXTURE_AGENT,function(e){e.minFilter=THREE.LinearFilter,agent_texture=e,asynchFinished()&&initScene()}),n.load(TEXTURE_ENEMY,function(e){e.minFilter=THREE.LinearFilter,enemy_texture=e,asynchFinished()&&initScene()}),o.load(TEXTURE_MAZE,function(e){e.minFilter=THREE.LinearFilter,maze_texture=e,asynchFinished()&&initScene()}),a.load(TEXTURE_PATH,function(e){e.minFilter=THREE.LinearFilter,path_texture=e})}function asynchFinished(){return!!(wall_texture&&agent_texture&&enemy_texture&&maze_texture)}function occupied(e,t){return ei==e&&ej==t||(ai==e&&aj==t||(GRID[e][t]==GRID_WALL||GRID[e][t]==GRID_MAZE))}function translate(e,t){var n=new THREE.Vector3;return n.y=0,n.x=e*squaresize-MAXPOS/2,n.z=t*squaresize-MAXPOS/2,n}function initScene(){var e,t,n,o;for(e=0;e<gridsize;e++)GRID[e]=new Array(gridsize);for(e=0;e<gridsize;e++)for(t=0;t<gridsize;t++)0==e||e==gridsize-1||0==t||t==gridsize-1?(GRID[e][t]=GRID_WALL,n=new THREE.BoxGeometry(squaresize,BOXHEIGHT,squaresize),(o=new THREE.Mesh(n)).material=new THREE.MeshBasicMaterial({map:wall_texture}),o.position.copy(translate(e,t)),ABWorld.scene.add(o)):GRID[e][t]=GRID_BLANK;for(var a=1;a<=NOBOXES;a++)e=AB.randomIntAtoB(1,gridsize-2),t=AB.randomIntAtoB(1,gridsize-2),GRID[e][t]=GRID_MAZE,n=new THREE.BoxGeometry(squaresize,BOXHEIGHT,squaresize),(o=new THREE.Mesh(n)).material=new THREE.MeshBasicMaterial({map:maze_texture}),o.position.copy(translate(e,t)),ABWorld.scene.add(o);do{e=AB.randomIntAtoB(1,gridsize-2),t=AB.randomIntAtoB(1,gridsize-2)}while(occupied(e,t));ei=e,ej=t,n=new THREE.BoxGeometry(squaresize,BOXHEIGHT,squaresize),(theenemy=new THREE.Mesh(n)).material=new THREE.MeshBasicMaterial({map:enemy_texture}),ABWorld.scene.add(theenemy),drawEnemy();do{e=AB.randomIntAtoB(1,gridsize-2),t=AB.randomIntAtoB(1,gridsize-2)}while(occupied(e,t));ai=e,aj=t,n=new THREE.BoxGeometry(squaresize,BOXHEIGHT,squaresize),(theagent=new THREE.Mesh(n)).material=new THREE.MeshBasicMaterial({map:agent_texture}),ABWorld.scene.add(theagent),drawAgent(),ABWorld.scene.background=(new THREE.CubeTextureLoader).load(SKYBOX_ARRAY,function(){ABWorld.render(),AB.removeLoading(),AB.runReady=!0})}function drawEnemy(){theenemy.position.copy(translate(ei,ej)),ABWorld.lookat.copy(theenemy.position)}function drawAgent(){theagent.position.copy(translate(ai,aj)),ABWorld.follow.copy(theagent.position)}function drawPath(e,t){thepath.position.copy(translate(e,t))}function clearPath(e,t){thepath.position.copy(translate(e,t))}function heuristic(e,t){return Math.abs(t.i-e.i)+Math.abs(t.j-e.j)}function node(e,t){this.i=e,this.j=t,this.g=0,this.h=0,this.f=0,this.previous}function removeFromArray(e,t){for(var n=e.length-1;n>=0;n--)e[n]==t&&e.splice(n,1)}function drawNode(e,t){var n=new THREE.BoxGeometry(100,100,100),o=new THREE.MeshBasicMaterial({color:t}),a=new THREE.Mesh(n,o);a.position.copy(translate(e.i,e.j)),ABWorld.scene.add(a)}function removePath(){console.log("removing");for(var e=0;e<starArray.length;e++){var t=starArray[e];console.log("t",t);const n=ABWorld.scene.getObjectByProperty("uuid",t);ABWorld.scene.remove(n)}}function getNeighbors(e){var t=[];return e.i>1&&!occupied(e.i,e.j-1)&&t.push(new node(e.i,e.j-1)),e.i<gridsize-2&&!occupied(e.i,e.j+1)&&t.push(new node(e.i,e.j+1)),e.j>1&&!occupied(e.i-1,e.j)&&t.push(new node(e.i-1,e.j)),e.j<gridsize-2&&!occupied(e.i-1,e.j)&&t.push(new node(e.i+1,e.j)),t}function aStar(){var e=[],t=[],n=[],o=new node(ei,ej),a=new node(ai,aj);console.log("sophie - startNode",o),console.log("sophie - endNode",a),e.push(o);for(var r=0;r<e.length;r++)for(var i=0,s=0;s<e.length;s++){e[s].f<e[i].f&&(i=s);var d=e[i];if(d.i===a.i&&d.j===a.j){for(var u=d;u.previous;)n.push(u),u=u.previous;return n.reverse()}removeFromArray(e,d),t.includes(d)||(t.push(d),drawNode(d,"#ff0000"));for(var c=getNeighbors(d),l=0;l<c.length;l++){var p=c[l];if(!t.includes(p)){var A=d.g+heuristic(p,d),g=!1;e.includes(p)?A<p.g&&(p.g=A,g=!0):(p.g=A,g=!0,e.push(p)),g&&(p.h=heuristic(a,p),p.f=p.g+p.h,p.previous=d)}}}for(var E=0;E<n.length;E++)console.log("sophie - drawNode"),drawNode(n[E],"#ff0000");return n}function moveLogicalEnemy(){console.log("STARTING ENEMY TURN");var e=aStar();console.log("sophie - path",e),e.length>0&&(ei=e[0].i,ej=e[0].j),console.log("ENDING ENEMY TURN & removing path")}function moveLogicalAgent(e){var t=ai,n=aj;e==ACTION_LEFT?t--:e==ACTION_RIGHT?t++:e==ACTION_UP?n++:e==ACTION_DOWN&&n--,occupied(t,n)||(ai=t,aj=n)}var OURKEYS=[37,38,39,40];function ourKeys(e){return OURKEYS.includes(e.keyCode)}function keyHandler(e){return!AB.runReady||(!ourKeys(e)||(37==e.keyCode&&moveLogicalAgent(ACTION_LEFT),38==e.keyCode&&moveLogicalAgent(ACTION_DOWN),39==e.keyCode&&moveLogicalAgent(ACTION_RIGHT),40==e.keyCode&&moveLogicalAgent(ACTION_UP),e.stopPropagation(),e.preventDefault(),!1))}function badstep(){return Math.abs(ei-ai)<2&&Math.abs(ej-aj)<2}function agentBlocked(){return occupied(ai-1,aj)&&occupied(ai+1,aj)&&occupied(ai,aj+1)&&occupied(ai,aj-1)}function updateStatusBefore(e){var t=AB.world.getState();AB.msg(" Step: "+AB.step+" x = ("+t.toString()+") a = ("+e+") ")}function updateStatusAfter(){var e=AB.world.getState(),t=goodsteps/AB.step*100;AB.msg(" y = ("+e.toString()+") <br> Bad steps: "+badsteps+" Good steps: "+goodsteps+" Score: "+t.toFixed(2)+"% ",2)}AB.world.newRun=function(){AB.loadingScreen(),AB.runReady=!1,badsteps=0,goodsteps=0,BOXHEIGHT=squaresize,ABWorld.init3d(startRadiusConst,maxRadiusConst,14548957),loadResources(),document.onkeydown=keyHandler},AB.world.getState=function(){return[ai,aj,ei,ej]},AB.world.takeAction=function(e){updateStatusBefore(e),moveLogicalAgent(e),AB.step%2==0&&moveLogicalEnemy(),badstep()?badsteps++:goodsteps++,drawAgent(),drawEnemy(),updateStatusAfter(),agentBlocked()&&(AB.abortRun=!0,goodsteps=0,musicPause(),soundAlarm())},AB.world.endRun=function(){musicPause(),AB.abortRun?AB.msg(" <br> <font color=red> <B> Agent trapped. Final score zero. </B> </font> ",3):AB.msg(" <br> <font color=green> <B> Run over. </B> </font> ",3)},AB.world.getScore=function(){var e=goodsteps/AB.maxSteps*100;return Math.round(100*e)/100};var backmusic=AB.backgroundMusic(MUSIC_BACK);function musicPlay(){backmusic.play()}function musicPause(){backmusic.pause()}function soundAlarm(){new Audio(SOUND_ALARM).play()}