javaScript實現(xiàn)網(wǎng)頁版的彈球游戲
利用javeScript對象以及方法實現(xiàn)的網(wǎng)頁彈球游戲,供大家參考,具體內(nèi)容如下
<!DOCTYPE html><html><head><tilie>呼呼哈嘿的網(wǎng)頁彈球</title></head><body><canvas id='canvas'width='400'height='400'></canvas> <script src='https://cdn.bootcdn.net/ajax/libs/jquery/3.6.0/jquery.js'></script><script>var canv=document.getElementById('canvas');var ctx=canv.getContext('2d');//創(chuàng)建一個小球?qū)ο髒ar ball={x: 100,y: 100,xSpeed: -5,ySpeed: -5};//定義繪制小球的方法ball.draw=function(){ ctx.beginPath(); ctx.arc(this.x,this.y,10,0,Math.PI*2,false); ctx.fill();};//定義小球運動的方法ball.move=function(){ this.x =this.x+this.xSpeed; this.y =this.y+this.ySpeed;};//邊界判斷ball.checkCanvas=function(panelStart,panelEnd){ if(this.x<0||this.x>400) this.xSpeed=-this.xSpeed;if(this.y<0) this.ySpeed=-this.ySpeed;if(this.y>390){ if(this.x>panelStart && this.x<panelEnd) this.ySpeed=-this.ySpeed; else{ alert('GAME OVER!!!'); this.x= 50; this.y=100;}}};//定時功能使得小球動起來setInterval(function(){ ctx.clearRect(0,0,400,400); ball.draw(); panel.draw(); ball.move(); ball.checkCanvas(panel.x,panel.x+panel.xSize); ctx.strokeRect(0,0,400,400);},30); //定時函數(shù),每30ms執(zhí)行一次大括號中的代碼;//創(chuàng)建擋板的對象;var panel ={ x:200, y:390, xSize: 50, ySize: 5};//擋板移動方法panel.draw=function(){ ctx.fillRect(this.x,this.y,this.xSize,this.ySize);};//利用jquery實現(xiàn)按鍵交互;$('body').keydown(function(event){console.log(event.keyCode);if(event.keyCode==37){ panel.x=panel.x-5; if(panel.x<0){panel.x=0; } }if(event.keyCode==39){ panel.x=panel.x+5;if(panel.x>400-50){panel.x=350; } }} );</script></body></html>
以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持好吧啦網(wǎng)。
相關(guān)文章:
1. jsp網(wǎng)頁實現(xiàn)貪吃蛇小游戲2. ASP.NET MVC遍歷驗證ModelState的錯誤信息3. jsp實現(xiàn)textarea中的文字保存換行空格存到數(shù)據(jù)庫的方法4. ASP 信息提示函數(shù)并作返回或者轉(zhuǎn)向5. ASP中if語句、select 、while循環(huán)的使用方法6. asp中response.write("中文")或者js中文亂碼問題7. 將properties文件的配置設(shè)置為整個Web應(yīng)用的全局變量實現(xiàn)方法8. PHP設(shè)計模式中工廠模式深入詳解9. 刪除docker里建立容器的操作方法10. asp(vbs)Rs.Open和Conn.Execute的詳解和區(qū)別及&H0001的說明
