为了账号安全,请及时绑定邮箱和手机立即绑定

js飞机大战

js飞机大战

哎呀呀哎呦呦 2017-10-28 09:15:22
<!DOCTYPE html> <html> <head> <meta charset="UTF-8"> <title>Game Of Plan</title> <style> *{ margin:0px; padding:0px; } </style> </head> <body> <script> window.onload=function(){ Game.exe(); } var Game={ //启动程序 exe:function(){ this.init(); }, //初始化 init:function(){ document.body.style.background='#000'; var This=this; var oDiv=document.createElement("div"); oDiv.id='box'; oDiv.style.cssText="width:300px;height:500px;border:10px solid #fff;margin:50px auto;position:relative;"; document.body.appendChild(oDiv); var hh=document.createElement("h2"); hh.innerHTML="飞机大战V1.0"; hh.style.cssText="font-family:'Microsoft yahei';font-size:26px;color:#fff;margin:50px auto;text-align:center"; oDiv.appendChild(hh); for(var i=0;i<4;i++){ var pp=document.createElement("p"); pp.index=i; pp.style.cssText="font-size:14px;width:150px;height:40px; margin:50px auto;background:#fff;color:#000;text-align:center;line-height:40px;cursor:pointer;overflow:hidden;"; var html=""; pp.onmouseenter=function(){ this.style.background='#FB6A0F'; this.style.color='#000'; } pp.onmouseleave=function(){ this.style.background='#fff'; this.style.color='#000'; } //点击进入第二个页面 pp.onclick=function(e){ e=e||window.event; This.start(this.index,oDiv,e); }; switch(i){ case 0: html="简单难度"; break; case 1: html="中等难度"; break; case 2: html="困难难度"; break; case 3: html="复仇者飞机"; pp.style.background='#0f0'; pp.style.color='#000'; pp.style.fontWeight='bold'; pp.onmouseenter=function(){ pp.style.background='#FE3535'; pp.style.color='#0F0505'; } pp.onmouseleave=function(){ pp.style.background='#0f0'; pp.style.color='#000'; } break; } pp.innerHTML=html; oDiv.appendChild(pp); } }, //游戏开始 start:function(index,oGameBox,e){ oGameBox.innerHTML=""; this.plane(oGameBox,e); }, //关于飞机 plane:function(oGameBox,e){ var x=e.pageX; var y=e.pageY; var oplane=new Image(); oplane.src="AirplaneResource/plane2.png"; oplane.width=44; oplane.height=45; var ty=oGameBox.offsetTop+parseInt(oGameBox.style.borderWidth)+oplane.height/2; var lx=oGameBox.offsetLeft+parseInt(oGameBox.style.borderWidth)+oplane.width/2; //页面窗口变化情况 window.onresize=function(){ lx=oGameBox.offsetLeft+parseInt(oGameBox.style.borderWidth)+oplane.width/2; } var top=y-ty; var left=x-lx; oplane.style.cssText="display:block;position:absolute;top:'+top+'px;left'+left+'px;"; oGameBox.appendChild(oplane); //寻找飞机在盒子里移动范围 var leftmin=-oplane.width/2; var leftmax=oGameBox.clientWidth-oplane.width/2; var topmin=0; var topmax=oGameBox.clientHeight-oplane.height; document.onmouseover=function(e){ e=e||window.event; var top=e.pageY-ty; var left=e.pageX-lx; //限制飞机移动 top=Math.min(top,topmax); top=Math.max(top,topmin); left=Math.min(left,leftmax); left=Math.max(left,leftmin); oplane.style.left=left+'px'; oplane.style.top=top+'px'; }; this.biubiubiu(oplane,oGameBox); }, biubiubiu:function(oplane,oGameBox){ var timer=setInterval(function(){ var biu=new Image(); biu.src="AirplaneResource/bullet1.png"; biu.width=5; biu.height=11; var top=oplane.offsetTop-biu.height+3; var left=oplane.offsetLeft+oplane.width/2-parseInt(biu.width/2); biu.style.cssText="display:block;position:absolute;top:'+top+'px;left:'+left+'px;"; oGameBox.appendChild(biu); biu.timer=setInterval(function(){ biu.style.top=biu.offsetTop-10+"px"; if(biu.offsetTop<-biu.height){ clearInterval(biu.timer); biu.parentNode.removeChild(biu); } },13); },100); }, }; </script> </body> </html> 后面子弹(biu)不能跟着飞机移动  top和left值试了好几遍  找不到合适的  子弹一直在左上角  求大神干货讲解
查看完整描述

目前暂无任何回答

  • 0 回答
  • 0 关注
  • 2526 浏览
慕课专栏
更多

添加回答

举报

0/150
提交
取消
意见反馈 帮助中心 APP下载
官方微信